用 C# 访问 SQLite 入门(2)

用 C# 访问 SQLite (2)

 

6. Form 与 DataGridView

 

在 Solutuon Explorer 点击 Form1.cs , 在打开的 Form1[Design] 添加控件

 

在 Toolbox 拉入4个 Label, 分别命名,例如:lblID, lblBookname, lblPrice, lblGuid

在 Toolbox 拉入4个 TextBox, 分别命名,例如: txtID, txtBookname, txtPrice, txtGuid

在 Toolbox 拉入2个 Button, 分别命名,例如: btnExit, btnSave

在 Toolbox 拉入1个 DataGridView, 命名,例如: dgv1

 

适当排列和布局,就可以达到这样的一个输入和现实界面:

 


用 C# 访问 SQLite 入门(2)_第1张图片

 

当然,可以把 Form1 的尺寸调大,把各个控件的尺寸也放大一些。

 

双击 Form1 就会打开 Form1.cs 来输入语句。


用 C# 访问 SQLite 入门(2)_第2张图片

 

在 Form1.cs[Design] 分别双击 btnExit , btnSave 和 dgv1 然后在 Form1.cs 输入相关的语句:

 

        private void Form1_Load(object sender, EventArgs e)
        {
            initView1();
        }

        private void btnExit_Click(object sender, EventArgs e)
        {
            Application.Exit();
        }

        private void btnSave_Click(object sender, EventArgs e)
        {
            //find a GUID for new row to insert into DB
            StringBuilder guidSB = new StringBuilder(System.Guid.NewGuid().ToString());
            guidSB.Replace("-", "");  //replace -
            string guidStr = guidSB.ToString();

            //new book object            
            Book book1 = new Book();
            book1.ID = Convert.ToInt32(txtID.Text);
            book1.BookName = txtBookname.Text;
            book1.Price = Convert.ToDecimal(txtPrice.Text);
            book1.Rowguid = guidStr;

            //save to DB
            BookDAL.CreateBook(book1);

            //Read the rows from DB and display in dgv
            initView1();
        }

        private void dgv1_CellContentClick(object sender, DataGridViewCellEventArgs e)
        {

        }

        //===================================================
        // Click a row to dusplay its field in textbox
        //===================================================
        private void dgv1_CellClick(object sender, DataGridViewCellEventArgs e)
        {
            if (e.RowIndex < 0) return;
            if (e.ColumnIndex < 0) return;

            int rowIndx = dgv1.CurrentCell.RowIndex;

            txtID.Text = this.dgv1[0, e.RowIndex].Value.ToString();  //column 0
            txtBookname.Text = this.dgv1[1, e.RowIndex].Value.ToString();  //column 1
            txtPrice.Text = this.dgv1[2, e.RowIndex].Value.ToString();  //column 2
            txtGuid.Text = this.dgv1[3, e.RowIndex].Value.ToString();  //column 3
        }


        //===================================================
        // init the data view: datagridview and text boxes
        //===================================================
        private void initView1()
        {
            dgv1.DataSource = null;

            DataTable dt1 = new DataTable();

            dt1 = BookDAL.GetAllBook();
            if (dt1.Rows.Count > 0)
            {
                dgv1.DataSource = dt1;
            }

        }
 

这里需要特别说明的是 DataGirdView 的点击事件。我们希望 点一下 DataGridView 的任一单元格, 就把这行的数据显示到 TextBox 对应项。

 

在 dgv1 双击 会产生这个事件控制段:

 

        private void dgv1_CellContentClick(object sender, DataGridViewCellEventArgs e)
        {

        }
 

但是,这个 CellContentClick 控制不是对Cell 点击的控制,在其中加入代码,在 鼠标点击 Cell (单元格) 时不会触发这个事件。所以,我们要手工加入 CellClick 的事件控制:

 

        private void dgv1_CellClick(object sender, DataGridViewCellEventArgs e)
        {
            if (e.RowIndex < 0) return;
            if (e.ColumnIndex < 0) return;

            int rowIndx = dgv1.CurrentCell.RowIndex;

            txtID.Text = this.dgv1[0, e.RowIndex].Value.ToString();  //column 0
            txtBookname.Text = this.dgv1[1, e.RowIndex].Value.ToString();  //column 1
            txtPrice.Text = this.dgv1[2, e.RowIndex].Value.ToString();  //column 2
            txtGuid.Text = this.dgv1[3, e.RowIndex].Value.ToString();  //column 3
        }

 

这样就可以了吗?还不行。

 

因为 这个 CellClick 是你自己加入的,还不能被识别,需要在 Form1.Designer.cs 加入这个 CellClick 的识别:

 

在 Solution Explorer 在 Form1.cs 下面, 点 Form1.Designer.cs, 点  Open

 


用 C# 访问 SQLite 入门(2)_第3张图片

 

点一下 “Windows Form Designer generated code” 前面的 + 号 ,就展开各控件的定义设置语句。

 

在 dgv1 下加入 CellClick 的定义:

 


用 C# 访问 SQLite 入门(2)_第4张图片

 

保存,关闭 Form1.Designer.cs 即可。

 

这是很重要的一步,在网上多数的例子都是列出数据库操作语句,而这个设置就没有特别说明。我就是在网上搜索了很多例子,最后是在 msdn 论坛发问,才得到指点,而添加这一行来控制 单元格的点击操作。

 

其他的数据库操作,例如 插入,更新,删除,等等,可以看网上的例子。

 

 

7. SQLite ADO.NET 版本问题

 

现在可以调试一下,看看运行的效果:

 

在 VS 菜单,Debug -> Start Debugging

 


用 C# 访问 SQLite 入门(2)_第5张图片

就会看到一个 Mixed mode 错误。原因么,就是因为这个 SQLite ADO.NET 是支持 2.0 runtime 的, 而我们现在是在 .NET 4.0 环境下来使用,所以需要特别的设置。


用 C# 访问 SQLite 入门(2)_第6张图片

 

那特别的设置在哪里呢? 在 App.config 文件, 而这个文件缺省并不存在,需要手工添加:

 

先关闭 调试状态, Debug -> Stop Debugging

 

在 Solution Explorer 点 项目名, 按鼠标右键,选 Add -> New Item

 


用 C# 访问 SQLite 入门(2)_第7张图片

 

在弹出的对话框,点选Application Configuration File, 然后点 Add 添加。

 


用 C# 访问 SQLite 入门(2)_第8张图片

 

在打开的 App.config 编辑窗口,加入一行:

 

<startup useLegacyV2RuntimeActivationPolicy="true"><supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.0"/></startup>

 


用 C# 访问 SQLite 入门(2)_第9张图片

 

保存,关闭 App.config 即可。

 

再试运行一下吧:

 


用 C# 访问 SQLite 入门(2)_第10张图片

 

现在可以了。在 各个 textbox 输入数据,然后点 Save 数据就插入 数据库,并在 Datagridview 显示出来。点击 Datagridview 的任一单元格,这行的数据就显示到 textbox 可供编辑。

 

这样一个很简单的 SQLite 数据库操作就完成了。但是,以上的操作还是太简单,需要添加的功能太多了,可以参考网上的很多例子来逐步完善。

 

 

:-

你可能感兴趣的:(sqlite)