全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

C#创建SQLite控制台应用程序详解

一、开发环境

操作系统:Windows 10 X64

开发环境:VS2015

编程语言:C#

.NET版本:.NET Framework 4.0

目标平台:X86

二、前言

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

三、SQLite的下载

1、由于是基于.NET的C#编程,需下载System.Data.SQLite.dll来进行引用,下载网址如下:

http://system.data.sqlite.org/index.html/doc/trunk/www/downloads.wiki

2、由于使用的是.NET Framework 4.0,且软件开发的目标平台是X86,因此需下载 sqlite-netFx40-setup-x86-2010-1.0.105.2.exe 软件,下载网址如下:

http://system.data.sqlite.org/downloads/1.0.105.2/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,则可以进行下载安装,下载网址如下:

http://system.data.sqlite.org/downloads/1.0.105.2/sqlite-netFx40-setup-bundle-x86-2010-1.0.105.2.exe

3、下载的是Setup安装包,因此只需按照点击下一步(Next)或安装(Install),直至安装完毕即可。

四、创建加密版本的SQLite数据库

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

https://sqlitestudio.pl/files/sqlitestudio3/complete/win32/sqlitestudio-3.1.1.zip

有人会问,怎么不使用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的不一样。

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

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

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

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

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

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

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

8、在弹出的对话框点击“OK”按钮,即可完成表单的创建工作,如下图所示:

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

10、在行数据编辑栏里输入两条数据,第一条数据ID为2017、Name为LSB,第二条数据ID为2011、Name为CNC,如下图所示:

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

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

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

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

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

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

4、在项目属性设置中,将“生成”选项卡中的目标平台改为“X86”,否则,软件无法运行,原因是使用的是X86版本的System.Data.SQLite.dll,如下图所示:

5、在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();
  }
 }
}

6、运行结果如下:

附源代码:C#创建SQLite控制台应用程序

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# C#  # SQLite  # 控制台  # C# 如何在WINForm程序中创建XML文件  # 使用Visual Studio2019创建C#项目(窗体应用程序、控制台应用程序、Web应用程序)  # C#创建WCF服务控制台应用程序详解  # C#创建Web应用程序代码实例  # C#通过创建Windows服务启动程序的方法详解  # C#程序中创建、复制、移动、删除文件或文件夹的示例  # C#操作IIS程序池及站点的创建配置实现代码  # C# 创建控制台应用程序  # 所示  # 如下图  # 的是  # 并在  # 两条  # 另外一个  # 选项卡  # 应用程序  # 复选框  # 数据库管理  # 数据库文件  # 如果你  # 第一个  # 将会  # 在此  # 在弹出  # 只需  # 但在  # 推荐使用  # 没有什么 


相关文章: 如何通过虚拟主机空间快速建站?  GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?  JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)  如何通过可视化优化提升建站效果?  建站主机空间推荐 高性价比配置与快速部署方案解析  如何确认建站备案号应放置的具体位置?  免费ppt制作网站,有没有值得推荐的免费PPT网站?  如何在景安云服务器上绑定域名并配置虚拟主机?  如何在阿里云虚拟主机上快速搭建个人网站?  做企业网站制作流程,企业网站制作基本流程有哪些?  建站之星安装提示数据库无法连接如何解决?  免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  C++如何使用std::optional?(处理可选值)  如何在云主机上快速搭建多站点网站?  北京的网站制作公司有哪些,哪个视频网站最好?  建站VPS配置与SEO优化指南:关键词排名提升策略  如何选择高效便捷的WAP商城建站系统?  c# 在高并发场景下,委托和接口调用的性能对比  微信小程序 input输入框控件详解及实例(多种示例)  网站网页制作专业公司,怎样制作自己的网页?  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  如何在阿里云虚拟服务器快速搭建网站?  如何配置IIS站点权限与局域网访问?  如何在阿里云高效完成企业建站全流程?  网站按钮制作软件,如何实现网页中按钮的自动点击?  如何在阿里云域名上完成建站全流程?  正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?  如何快速生成专业多端适配建站电话?  网站制作壁纸教程视频,电脑壁纸网站?  如何快速搭建高效WAP手机网站?  江苏网站制作公司有哪些,江苏书法考级官方网站?  如何选择PHP开源工具快速搭建网站?  如何快速上传自定义模板至建站之星?  宁波自助建站系统如何快速打造专业企业网站?  如何在Windows环境下新建FTP站点并设置权限?  制作网站的公司有哪些,做一个公司网站要多少钱?  测试制作网站有哪些,测试性取向的权威测试或者网站?  沈阳制作网站公司排名,沈阳装饰协会官方网站?  高防服务器如何保障网站安全无虞?  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  建站主机SSH密钥生成步骤及常见问题解答?  建站之星在线客服如何快速接入解答?  招贴海报怎么做,什么是海报招贴?  香港服务器WordPress建站指南:SEO优化与高效部署策略  企业网站制作公司网页,推荐几家专业的天津网站制作公司?  山东网站制作公司有哪些,山东大源集团官网?  网站企业制作流程,用什么语言做企业网站比较好?  制作网站的软件免费下载,免费制作app哪个平台好? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。