C# - Simple CRUD Application With SQLite



In this tutorial we will create a Simple CRUD Application With SQLite using C#. C# is a general-purpose, object-oriented programming language. C# is expected to make it faster and less expensive to develop new application. The potential of C# is great when it comes in developing desktop application. It has a friendly environment for all new developers. So let's do the coding...


Getting Started


First you will have to download & install the Visual Studio. Visual Studios is an open source development feel free to create any application that you want.
Here's the link for the Visual Studio https://www.visualstudio.com/.
Here's the link for the SQLite Browser http://sqlitebrowser.org/.

Setting up SQLite


SQLite is very carefully tested prior to every release and relevant to use in some way. SQLite is very usable in any environments especially in embedded devices. First all you need to do is to install the components of the SQLIte database, by right clicking in the Main project title in the solution explorer then selecting the Manage NuGet Packages.


Then go to the browse and search sqlite, after that install it and wait until the process is completed.


Next go to the Updates and update the needed framework to make sqlite work properly.


Note: Update only the framework if there is an available new update.

Application Design


We will now create the design for the application, first locate the designer file called form1.Designer.cs, this is the default name when you create a new windows form. Rename the form as Main.cs and then write these codes inside your designer file.

  1. namespace Simple_CRUD
  2. {
  3. partial class Main
  4. {
  5. /// <summary>
  6. /// Required designer variable.
  7. /// </summary>
  8. private System.ComponentModel.IContainer components = null;
  9. /// <summary>
  10. /// Clean up any resources being used.
  11. /// </summary>
  12. /// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param>
  13. protected override void Dispose(bool disposing)
  14. {
  15. if (disposing && (components != null))
  16. {
  17. components.Dispose();
  18. }
  19. base.Dispose(disposing);
  20. }
  21. #region Windows Form Designer generated code
  22. /// <summary>
  23. /// Required method for Designer support - do not modify
  24. /// the contents of this method with the code editor.
  25. /// </summary>
  26. private void InitializeComponent()
  27. {
  28. this.btn_add = new System.Windows.Forms.Button();
  29. this.dataGridView1 = new System.Windows.Forms.DataGridView();
  30. this.label1 = new System.Windows.Forms.Label();
  31. this.txt_firstname = new System.Windows.Forms.TextBox();
  32. this.txt_lastname = new System.Windows.Forms.TextBox();
  33. this.label2 = new System.Windows.Forms.Label();
  34. this.txt_address = new System.Windows.Forms.TextBox();
  35. this.label3 = new System.Windows.Forms.Label();
  36. this.btn_update = new System.Windows.Forms.Button();
  37. this.btn_delete = new System.Windows.Forms.Button();
  38. this.btn_clear = new System.Windows.Forms.Button();
  39. ((System.ComponentModel.ISupportInitialize)(this.dataGridView1)).BeginInit();
  40. this.SuspendLayout();
  41. //
  42. // btn_add
  43. //
  44. this.btn_add.Location = new System.Drawing.Point(73, 577);
  45. this.btn_add.Name = "btn_add";
  46. this.btn_add.Size = new System.Drawing.Size(129, 55);
  47. this.btn_add.TabIndex = 0;
  48. this.btn_add.Text = "ADD";
  49. this.btn_add.UseVisualStyleBackColor = true;
  50. this.btn_add.Click += new System.EventHandler(this.Add);
  51. //
  52. // dataGridView1
  53. //
  54. this.dataGridView1.AllowUserToAddRows = false;
  55. this.dataGridView1.AllowUserToDeleteRows = false;
  56. this.dataGridView1.ColumnHeadersHeightSizeMode = System.Windows.Forms.DataGridViewColumnHeadersHeightSizeMode.AutoSize;
  57. this.dataGridView1.Location = new System.Drawing.Point(38, 181);
  58. this.dataGridView1.Name = "dataGridView1";
  59. this.dataGridView1.ReadOnly = true;
  60. this.dataGridView1.RowTemplate.Height = 28;
  61. this.dataGridView1.Size = new System.Drawing.Size(699, 369);
  62. this.dataGridView1.TabIndex = 7;
  63. this.dataGridView1.CellClick += new System.Windows.Forms.DataGridViewCellEventHandler(this.GetIdToDelete);
  64. this.dataGridView1.CellDoubleClick += new System.Windows.Forms.DataGridViewCellEventHandler(this.Edit);
  65. //
  66. // label1
  67. //
  68. this.label1.AutoSize = true;
  69. this.label1.Font = new System.Drawing.Font("Arial", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
  70. this.label1.Location = new System.Drawing.Point(34, 66);
  71. this.label1.Name = "label1";
  72. this.label1.Size = new System.Drawing.Size(119, 27);
  73. this.label1.TabIndex = 8;
  74. this.label1.Text = "Firstname";
  75. //
  76. // txt_firstname
  77. //
  78. this.txt_firstname.Font = new System.Drawing.Font("Arial", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
  79. this.txt_firstname.Location = new System.Drawing.Point(159, 63);
  80. this.txt_firstname.Name = "txt_firstname";
  81. this.txt_firstname.Size = new System.Drawing.Size(224, 35);
  82. this.txt_firstname.TabIndex = 9;
  83. //
  84. // txt_lastname
  85. //
  86. this.txt_lastname.Font = new System.Drawing.Font("Arial", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
  87. this.txt_lastname.Location = new System.Drawing.Point(530, 66);
  88. this.txt_lastname.Name = "txt_lastname";
  89. this.txt_lastname.Size = new System.Drawing.Size(224, 35);
  90. this.txt_lastname.TabIndex = 11;
  91. //
  92. // label2
  93. //
  94. this.label2.AutoSize = true;
  95. this.label2.Font = new System.Drawing.Font("Arial", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
  96. this.label2.Location = new System.Drawing.Point(405, 69);
  97. this.label2.Name = "label2";
  98. this.label2.Size = new System.Drawing.Size(117, 27);
  99. this.label2.TabIndex = 10;
  100. this.label2.Text = "Lastname";
  101. //
  102. // txt_address
  103. //
  104. this.txt_address.Font = new System.Drawing.Font("Arial", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
  105. this.txt_address.Location = new System.Drawing.Point(372, 117);
  106. this.txt_address.Name = "txt_address";
  107. this.txt_address.Size = new System.Drawing.Size(224, 35);
  108. this.txt_address.TabIndex = 13;
  109. //
  110. // label3
  111. //
  112. this.label3.AutoSize = true;
  113. this.label3.Font = new System.Drawing.Font("Arial", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
  114. this.label3.Location = new System.Drawing.Point(247, 120);
  115. this.label3.Name = "label3";
  116. this.label3.Size = new System.Drawing.Size(100, 27);
  117. this.label3.TabIndex = 12;
  118. this.label3.Text = "Address";
  119. //
  120. // btn_update
  121. //
  122. this.btn_update.Location = new System.Drawing.Point(252, 577);
  123. this.btn_update.Name = "btn_update";
  124. this.btn_update.Size = new System.Drawing.Size(129, 55);
  125. this.btn_update.TabIndex = 14;
  126. this.btn_update.Text = "UPDATE";
  127. this.btn_update.UseVisualStyleBackColor = true;
  128. this.btn_update.Click += new System.EventHandler(this.Update);
  129. //
  130. // btn_delete
  131. //
  132. this.btn_delete.Location = new System.Drawing.Point(410, 577);
  133. this.btn_delete.Name = "btn_delete";
  134. this.btn_delete.Size = new System.Drawing.Size(129, 55);
  135. this.btn_delete.TabIndex = 15;
  136. this.btn_delete.Text = "DELETE";
  137. this.btn_delete.UseVisualStyleBackColor = true;
  138. this.btn_delete.Click += new System.EventHandler(this.Delete);
  139. //
  140. // btn_clear
  141. //
  142. this.btn_clear.Location = new System.Drawing.Point(590, 577);
  143. this.btn_clear.Name = "btn_clear";
  144. this.btn_clear.Size = new System.Drawing.Size(129, 55);
  145. this.btn_clear.TabIndex = 16;
  146. this.btn_clear.Text = "CLEAR";
  147. this.btn_clear.UseVisualStyleBackColor = true;
  148. this.btn_clear.Click += new System.EventHandler(this.Clear);
  149. //
  150. // Main
  151. //
  152. this.AutoScaleDimensions = new System.Drawing.SizeF(9F, 20F);
  153. this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
  154. this.ClientSize = new System.Drawing.Size(819, 667);
  155. this.Controls.Add(this.btn_clear);
  156. this.Controls.Add(this.btn_delete);
  157. this.Controls.Add(this.btn_update);
  158. this.Controls.Add(this.txt_address);
  159. this.Controls.Add(this.label3);
  160. this.Controls.Add(this.txt_lastname);
  161. this.Controls.Add(this.label2);
  162. this.Controls.Add(this.txt_firstname);
  163. this.Controls.Add(this.label1);
  164. this.Controls.Add(this.dataGridView1);
  165. this.Controls.Add(this.btn_add);
  166. this.Name = "Main";
  167. this.StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen;
  168. this.Text = "Main";
  169. this.Load += new System.EventHandler(this.Main_Load);
  170. ((System.ComponentModel.ISupportInitialize)(this.dataGridView1)).EndInit();
  171. this.ResumeLayout(false);
  172. this.PerformLayout();
  173. }
  174. #endregion
  175. private System.Windows.Forms.Button btn_add;
  176. private System.Windows.Forms.DataGridView dataGridView1;
  177. private System.Windows.Forms.Label label1;
  178. private System.Windows.Forms.TextBox txt_firstname;
  179. private System.Windows.Forms.TextBox txt_lastname;
  180. private System.Windows.Forms.Label label2;
  181. private System.Windows.Forms.TextBox txt_address;
  182. private System.Windows.Forms.Label label3;
  183. private System.Windows.Forms.Button btn_update;
  184. private System.Windows.Forms.Button btn_delete;
  185. private System.Windows.Forms.Button btn_clear;
  186. }
  187. }

or also you create the layout by dragging the proper tools to the forms.

Creating the Script


We will now create the script to make things work. To do that go to the csharp script called Main.cs then right click and select view code, this will force you to go to the text editor. Then write these block of codes inside the Class of the form.

  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Data;
  5. using System.IO;
  6. using System.Drawing;
  7. using System.Linq;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. using System.Windows.Forms;
  11. using System.Data.SQLite;
  12. namespace Simple_CRUD
  13. {
  14. public partial class Main : Form
  15. {
  16. SQLiteConnection conn;
  17. SQLiteCommand cmd;
  18. SQLiteDataAdapter adapter;
  19. DataSet ds = new DataSet();
  20. DataTable dt = new DataTable();
  21. int id;
  22. bool isDoubleClick = false;
  23. String connectString;
  24. public Main()
  25. {
  26. InitializeComponent();
  27. connectString = @"Data Source=" + Application.StartupPath + @"\Database\crud.db;version=3";
  28. GenerateDatabase();
  29. }
  30. private void Add(object sender, EventArgs e) {
  31. if (txt_firstname.Text != "" || txt_lastname.Text != "" || txt_address.Text != "")
  32. {
  33. try
  34. {
  35. conn = new SQLiteConnection(connectString);
  36. cmd = new SQLiteCommand();
  37. cmd.CommandText = @"INSERT INTO member (firstname, lastname, address) VALUES(@firstname, @lastname, @address)";
  38. cmd.Connection = conn;
  39. cmd.Parameters.Add(new SQLiteParameter("@firstname", txt_firstname.Text));
  40. cmd.Parameters.Add(new SQLiteParameter("@lastname", txt_lastname.Text));
  41. cmd.Parameters.Add(new SQLiteParameter("@address", txt_address.Text));
  42. conn.Open();
  43. int i = cmd.ExecuteNonQuery();
  44. if (i == 1)
  45. {
  46. MessageBox.Show("Successfully Created!");
  47. txt_firstname.Text = "";
  48. txt_lastname.Text = "";
  49. txt_address.Text = "";
  50. ReadData();
  51. }
  52. }
  53. catch (Exception ex)
  54. {
  55. MessageBox.Show(ex.Message);
  56. }
  57. }
  58. else {
  59. MessageBox.Show("Required Field!");
  60. }
  61. }
  62. private void GenerateDatabase() {
  63. String path = Application.StartupPath + @"\Database\crud.db";
  64. if (!File.Exists(path))
  65. {
  66. conn = new SQLiteConnection(connectString);
  67. conn.Open();
  68. string sql = "CREATE TABLE member (ID INTEGER PRIMARY KEY AUTOINCREMENT, firstname TEXT, lastname TEXT, address TEXT)";
  69. cmd = new SQLiteCommand(sql, conn);
  70. cmd.ExecuteNonQuery();
  71. conn.Close();
  72. }
  73. }
  74. private void ReadData() {
  75. try
  76. {
  77. conn = new SQLiteConnection(connectString);
  78. conn.Open();
  79. cmd = new SQLiteCommand();
  80. String sql = "SELECT * FROM member";
  81. adapter = new SQLiteDataAdapter(sql, conn);
  82. ds.Reset();
  83. adapter.Fill(ds);
  84. dt = ds.Tables[0];
  85. dataGridView1.DataSource = dt;
  86. conn.Close();
  87. dataGridView1.Columns[1].HeaderText = "Firstname";
  88. dataGridView1.Columns[2].HeaderText = "Lastname";
  89. dataGridView1.Columns[3].HeaderText = "Address";
  90. dataGridView1.Columns[0].Visible = false;
  91. dataGridView1.Columns[1].AutoSizeMode = DataGridViewAutoSizeColumnMode.AllCells;
  92. dataGridView1.Columns[2].AutoSizeMode = DataGridViewAutoSizeColumnMode.AllCells;
  93. dataGridView1.Columns[3].AutoSizeMode = DataGridViewAutoSizeColumnMode.Fill;
  94. dataGridView1.SelectionMode = DataGridViewSelectionMode.FullRowSelect;
  95. }
  96. catch (Exception ex) {
  97. MessageBox.Show(ex.Message);
  98. }
  99. }
  100. private void Main_Load(object sender, EventArgs e)
  101. {
  102. ReadData();
  103. }
  104. private void Edit(object sender, DataGridViewCellEventArgs e) {
  105. id = Convert.ToInt32(dataGridView1.SelectedRows[0].Cells[0].Value);
  106. txt_firstname.Text = dataGridView1.SelectedRows[0].Cells[1].Value.ToString();
  107. txt_lastname.Text = dataGridView1.SelectedRows[0].Cells[2].Value.ToString();
  108. txt_address.Text = dataGridView1.SelectedRows[0].Cells[3].Value.ToString();
  109. isDoubleClick = true;
  110. }
  111. private void GetIdToDelete(object sender, DataGridViewCellEventArgs e) {
  112. id = Convert.ToInt32(dataGridView1.SelectedRows[0].Cells[0].Value);
  113. isDoubleClick = false;
  114. txt_firstname.Text = "";
  115. txt_lastname.Text = "";
  116. txt_address.Text = "";
  117. }
  118. private void Update(object sender, EventArgs e) {
  119. if(isDoubleClick) {
  120. try {
  121. conn.Open();
  122. cmd = new SQLiteCommand();
  123. cmd.CommandText = @"UPDATE member set firstname=@firstname, lastname=@lastname, address=@address WHERE ID='"+ id +"'";
  124. cmd.Connection = conn;
  125. cmd.Parameters.AddWithValue("@firstname", txt_firstname.Text);
  126. cmd.Parameters.AddWithValue("@lastname", txt_lastname.Text);
  127. cmd.Parameters.AddWithValue("@address", txt_address.Text);
  128. int i = cmd.ExecuteNonQuery();
  129. if (i == 1)
  130. {
  131. MessageBox.Show("Successfully Updated!");
  132. txt_firstname.Text = "";
  133. txt_lastname.Text = "";
  134. txt_address.Text = "";
  135. ReadData();
  136. id = 0;
  137. dataGridView1.ClearSelection();
  138. dataGridView1.CurrentCell = null;
  139. isDoubleClick = false;
  140. }
  141. conn.Close();
  142. }
  143. catch (Exception ex) {
  144. MessageBox.Show(ex.Message);
  145. }
  146. }
  147. }
  148. private void Delete(object sender, EventArgs e) {
  149. DialogResult dialogResult = MessageBox.Show("Do you to delete this record?", "Warning", MessageBoxButtons.YesNo, MessageBoxIcon.Warning);
  150. if (dialogResult == DialogResult.Yes)
  151. {
  152. try
  153. {
  154. conn = new SQLiteConnection(connectString);
  155. conn.Open();
  156. cmd = new SQLiteCommand();
  157. cmd.CommandText = @"DELETE FROM member WHERE ID='" + id + "'";
  158. cmd.Connection = conn;
  159. int i = cmd.ExecuteNonQuery();
  160. if (i == 1)
  161. {
  162. MessageBox.Show("Successfully Deleted!");
  163. id = 0;
  164. dataGridView1.ClearSelection();
  165. dataGridView1.CurrentCell = null;
  166. ReadData();
  167. dataGridView1.ClearSelection();
  168. dataGridView1.CurrentCell = null;
  169. }
  170. }
  171. catch (Exception ex)
  172. {
  173. MessageBox.Show(ex.Message);
  174. }
  175. }
  176. else if (dialogResult == DialogResult.No)
  177. {
  178. }
  179. }
  180. private void Clear(object sender, EventArgs e)
  181. {
  182. id = 0;
  183. txt_firstname.Text = "";
  184. txt_lastname.Text = "";
  185. txt_address.Text = "";
  186. dataGridView1.ClearSelection();
  187. dataGridView1.CurrentCell = null;
  188. isDoubleClick = false;
  189. }
  190. }
  191. }

Try to run the application and see if it works.
There you go we successfully created a Simple CRUD Application With SQLite using C#. I hope that this tutorial help you understand on how to develop an application using C#. For more updates and tutorials just kindly visit this site. Happy Coding!!!

Comments