使用C#建立SQLite控制台应用程序

本文属于原创,转载请注明出处,谢谢!html

1、开发环境算法

操做系统:Windows 10 X64sql

开发环境:VS2015数据库

编程语言:C#编程

.NET版本:.NET Framework 4.0编程语言

目标平台:X86函数

2、前言工具

以前使用的是软件的Access来建立基于本地的数据库软件,发如今使用过程当中,发现Access比较耗内存,运行速度比SQLite稍微慢,另一个最重要的是Access加密的文件容易被破解,所以,如今转向使用SQLite来代替Access。加密

3、SQLite的下载spa

一、因为是基于.NET的C#编程,需下载System.Data.SQLite.dll来进行引用,下载网址以下:

二、因为使用的是.NET Framework 4.0,且软件开发的目标平台是X86,所以需下载 sqlite-netFx40-setup-x86-2010-1.0.105.2.exe 软件,下载网址以下:

另外,还有一个 sqlite-netFx40-setup-bundle-x86-2010-1.0.105.2.exe,它与 sqlite-netFx40-setup-x86-2010-1.0.105.2.exe 的区别是,它含有VS2010的运行时组件,因使用的VS2015,全部安装该带有bundle的软件实际没有什么用处,若是你使用的是VS2010,则能够进行下载安装,下载网址以下:

三、下载的是Setup安装包,所以只需按照点击下一步(Next)或安装(Install),直至安装完毕便可。

4、建立加密版本的SQLite数据库

在此使用的SQLite数据库管理软件为SQLite Studio,版本为3.1.1,下载网址以下:

有人会问,怎么不使用Navicat For SQLite,这个软件不只有彻底的中文版本,并且还有详细使用说明,不是更好吗?

其实,当初也想用这个软件来对SQLite数据库进行管理,但在建立加密版本的SQLite数据库时,发现使用System.Data.SQLite.dll来对该数据库操做时,会弹出相似数据库文件被加密或者不是数据库文件的提示,而非加密版本的就没有此问题,所以,可使用Navicat For SQLite来对非加密的SQLite数据操做,但若是须要使用加密的SQLite数据库,推荐使用SQLite Studio,由于它生成的加密版本SQLite数据库能够被System.Data.SQLite.dll识别。

关于为什么不能使用Navicat For SQLite来对加密数据库记性操做的缘由是:Navicat使用的加密算法与SQLite Studio的不同。

一、打开SQLite Studio,点击“添加数据库”按钮,以下图所示:

二、数据类型选择“System.Data.SQLite”,点击绿色添加按钮,将文件保存至D:\Test.db,并在Password一栏内输入密码:2017(如不使用密码,此处留空便可),而后点击“OK”按钮便可建立一个加密版本的SQLite DB文件,以下图所示:

三、双击“Test”数据库,将会显示其下的子节点,选择“Tables”,并在工具栏点击“新建表”按钮,以下图所示:

四、在Table name文本框内输入表名Info,并点击“Add columns(Ins)”图标以便添加列,以下图所示:

五、添加第一个字段,字段名为ID,数据类型为Text,将主键前的复选框打钩,并点击“OK”按钮,以下图所示:

六、重复第4个步骤,点击“Add columns(Ins)”图标以便添加另一个列,字段名为Name,数据类型为Text,将非空前的复选框打钩,并点击“OK”按钮,以下图所示:

七、点击“Commit structure changes”图标以便保存该表及字段,以下图所示:

八、在弹出的对话框点击“OK”按钮,便可完成表单的建立工做,以下图所示:

九、选择“数据”选项卡,点击“插入行(Ins)”图标按钮,以下所示:

十、在行数据编辑栏里输入两条数据,第一条数据ID为201七、Name为LSB,第二条数据ID为20十一、Name为CNC,以下图所示:

十一、添加数据完毕以后,点击“提交(Ctrl+Return)”图标按钮提交刚才输入的两条数据,以下图所示:

十二、关闭SQLite Studio数据库管理软件。

5、使用System.Data.SQLite.dll访问SQLite数据库

一、新建一个项目名为“SQLiteTest”的控制台应用程序,以下图所示:

二、在“SQLiteTest”项目中右键点击“引用”,在弹出的上下文菜单中选择“添加引用(R)”,以下图所示:

三、将路径为“C:\Program Files (x86)\System.Data.SQLite\2010\GAC\System.Data.SQLite.dll”的引用添加进来,以下图所示:

四、在项目属性设置中,将“生成”选项卡中的目标平台改成“X86”,不然,软件没法运行,缘由是使用的是X86版本的System.Data.SQLite.dll,以下图所示:

 

五、在Main主函数里输入如下代码,以下:

using System;
using System.Data.SQLite;
using System.Data;

namespace SQLiteTest
{
    class Program
    {
        static void Main(string[] args)
        {
            using (SQLiteConnection connection = new SQLiteConnection(@"Data Source = D:\test.db;Password = 2017"))
            {
                using (SQLiteCommand command = new SQLiteCommand(connection)
                { CommandText = "SELECT * FROM [main].[Info]" })
                {
                    DataTable table = new DataTable("Info");
                    SQLiteDataAdapter adapter = new SQLiteDataAdapter(command);
                    adapter.Fill(table);
                    foreach(DataRow row in table.Rows)
                    {
                        foreach(DataColumn col in table.Columns)
                        {
                            Console.Write($"{row[col]}\t");
                        }
                        Console.WriteLine();
                    }
                }
            }
            Console.ReadKey();
        }
    }
}

六、运行结果以下:

 

附源代码:

相关文章
相关标签/搜索