服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C# - C#创建SQLite控制台应用程序详解

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

2022-01-17 12:36cnc C#

这篇文章主要为大家详细介绍了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来进行引用,下载网址如下:

 

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,下载网址如下:

 

有人会问,怎么不使用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,点击“添加数据库”按钮,如下图所示:

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

10、在行数据编辑栏里输入两条数据,第一条数据id为2017、name为lsb,第二条数据id为2011、name为cnc,如下图所示:

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

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

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

12、关闭sqlite studio数据库管理软件。

五、使用system.data.sqlite.dll访问sqlite数据库

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

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

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

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

3、将路径为“c:\program files (x86)\system.data.sqlite\2010\gac\system.data.sqlite.dll”的引用添加进来,如下图所示:

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

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

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

5、在main主函数里输入以下代码,如下:

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
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控制台应用程序

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

原文链接:http://www.cnblogs.com/cncc/p/7158126.html

延伸 · 阅读

精彩推荐
  • C#深入理解C#的数组

    深入理解C#的数组

    本篇文章主要介绍了C#的数组,数组是一种数据结构,详细的介绍了数组的声明和访问等,有兴趣的可以了解一下。...

    佳园9492021-12-10
  • C#利用C#实现网络爬虫

    利用C#实现网络爬虫

    这篇文章主要介绍了利用C#实现网络爬虫,完整的介绍了C#实现网络爬虫详细过程,感兴趣的小伙伴们可以参考一下...

    C#教程网11852021-11-16
  • C#SQLite在C#中的安装与操作技巧

    SQLite在C#中的安装与操作技巧

    SQLite,是一款轻型的数据库,用于本地的数据储存。其优点有很多,下面通过本文给大家介绍SQLite在C#中的安装与操作技巧,感兴趣的的朋友参考下吧...

    蓝曈魅11162022-01-20
  • C#C#设计模式之Strategy策略模式解决007大破密码危机问题示例

    C#设计模式之Strategy策略模式解决007大破密码危机问题示例

    这篇文章主要介绍了C#设计模式之Strategy策略模式解决007大破密码危机问题,简单描述了策略模式的定义并结合加密解密算法实例分析了C#策略模式的具体使用...

    GhostRider10972022-01-21
  • C#如何使用C#将Tensorflow训练的.pb文件用在生产环境详解

    如何使用C#将Tensorflow训练的.pb文件用在生产环境详解

    这篇文章主要给大家介绍了关于如何使用C#将Tensorflow训练的.pb文件用在生产环境的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴...

    bbird201811792022-03-05
  • C#三十分钟快速掌握C# 6.0知识点

    三十分钟快速掌握C# 6.0知识点

    这篇文章主要介绍了C# 6.0的相关知识点,文中介绍的非常详细,通过这篇文字可以让大家在三十分钟内快速的掌握C# 6.0,需要的朋友可以参考借鉴,下面来...

    雨夜潇湘8272021-12-28
  • C#VS2012 程序打包部署图文详解

    VS2012 程序打包部署图文详解

    VS2012虽然没有集成打包工具,但它为我们提供了下载的端口,需要我们手动安装一个插件InstallShield。网上有很多第三方的打包工具,但为什么偏要使用微软...

    张信秀7712021-12-15
  • C#C#微信公众号与订阅号接口开发示例代码

    C#微信公众号与订阅号接口开发示例代码

    这篇文章主要介绍了C#微信公众号与订阅号接口开发示例代码,结合实例形式简单分析了C#针对微信接口的调用与处理技巧,需要的朋友可以参考下...

    smartsmile20127762021-11-25