博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C#使用System.Data.SQLite操作SQLite
阅读量:6242 次
发布时间:2019-06-22

本文共 2183 字,大约阅读时间需要 7 分钟。

使用System.Data.SQLite

下载地址:

得到System.Data.SQLite.dll添加到工程引用;

 建表,插入操作

C#代码  
  1. static void Main(string[] args)  
  2.         {  
  3.             SQLiteConnection conn = null;  
  4.   
  5.             string dbPath = "Data Source =" + Environment.CurrentDirectory + "/test.db";  
  6.             conn = new SQLiteConnection(dbPath);//创建数据库实例,指定文件位置  
  7.             conn.Open();//打开数据库,若文件不存在会自动创建  
  8.   
  9.             string sql = "CREATE TABLE IF NOT EXISTS student(id integer, name varchar(20), sex varchar(2));";//建表语句  
  10.             SQLiteCommand cmdCreateTable = new SQLiteCommand(sql, conn);  
  11.             cmdCreateTable.ExecuteNonQuery();//如果表不存在,创建数据表  
  12.   
  13.             SQLiteCommand cmdInsert = new SQLiteCommand(conn);  
  14.             cmdInsert.CommandText = "INSERT INTO student VALUES(1, '小红', '男')";//插入几条数据  
  15.             cmdInsert.ExecuteNonQuery();  
  16.             cmdInsert.CommandText = "INSERT INTO student VALUES(2, '小李', '女')";  
  17.             cmdInsert.ExecuteNonQuery();  
  18.             cmdInsert.CommandText = "INSERT INTO student VALUES(3, '小明', '男')";  
  19.             cmdInsert.ExecuteNonQuery();  
  20.   
  21.             conn.Close();  
  22.         }  

 

 可以使用SQLite Database Browser来查看数据:

下载地址:

 

 
 建表成功。

当然这种方法插入数据效率不高,数据量大的话要使用下面这种方法:

C#代码  
  1. static void Main(string[] args)  
  2.        {  
  3.            string dbPath = Environment.CurrentDirectory + "/test.db";//指定数据库路径  
  4.              
  5.            using(SQLiteConnection conn = new SQLiteConnection("Data Source =" + dbPath))//创建连接  
  6.            {  
  7.                conn.Open();//打开连接  
  8.                using(SQLiteTransaction tran = conn.BeginTransaction())//实例化一个事务  
  9.                {  
  10.                    for (int i = 0; i < 100000; i++ )  
  11.                    {  
  12.                        SQLiteCommand cmd = new SQLiteCommand(conn);//实例化SQL命令  
  13.                        cmd.Transaction = tran;  
  14.                        cmd.CommandText = "insert into student values(@id, @name, @sex)";//设置带参SQL语句  
  15.                        cmd.Parameters.AddRange(new[] {
    //添加参数  
  16.                            new SQLiteParameter("@id", i),  
  17.                            new SQLiteParameter("@name""中国人"),  
  18.                            new SQLiteParameter("@sex""男")  
  19.                        });  
  20.                        cmd.ExecuteNonQuery();//执行查询  
  21.                    }  
  22.                    tran.Commit();//提交  
  23.                }  
  24.            }  
  25.        }  

 

插入这样的十万条数据只需要5秒左右。

 

读取数据:

 

C#代码  
  1. static void Main(string[] args)  
  2.         {  
  3.             SQLiteConnection conn = null;  
  4.   
  5.             string dbPath = "Data Source =" + Environment.CurrentDirectory + "/test.db";  
  6.             conn = new SQLiteConnection(dbPath);//创建数据库实例,指定文件位置  
  7.             conn.Open();//打开数据库,若文件不存在会自动创建  
  8.   
  9.             string sql = "select * from student";  
  10.             SQLiteCommand cmdQ = new SQLiteCommand(sql, conn);  
  11.   
  12.             SQLiteDataReader reader = cmdQ.ExecuteReader();  
  13.   
  14.             while (reader.Read())  
  15.             {  
  16.                 Console.WriteLine(reader.GetInt32(0) + " " + reader.GetString(1) + " " + reader.GetString(2));  
  17.             }  
  18.             conn.Close();  
  19.   
  20.             Console.ReadKey();  
  21.         }  

 

 

 数据读取成功。

 

转载地址:http://bvsia.baihongyu.com/

你可能感兴趣的文章
vue-cli的坑,loader重复的锅 Invalid CSS after "...load the styles"
查看>>
手写Spring之IOC基于xml动态创建对象
查看>>
聊聊reactive streams的tranform操作
查看>>
箭头函数与this
查看>>
Angular4学习笔记之DOM属性绑定
查看>>
java构造list,合并重复的数组
查看>>
紫书第四章例4-4信息解码Message Decoding (处理二进制字符的一种典型例题)
查看>>
一些杂感杂想(三)打理业余时间的一点个人心得
查看>>
Apache Kylin安装部署
查看>>
JavaScript的async 的学习
查看>>
SpringCloud(第 021 篇)Zuul 的过滤器 ZuulFilter 的使用
查看>>
JavaScript笔记——闭包
查看>>
gRPC 初探
查看>>
SpringBoot非官方教程 | 第六篇:SpringBoot整合mybatis
查看>>
dataguard备库出现GAP修复
查看>>
OOD、DIP、IOC、DI、依赖注入容器(即 控制反转容器,IOC Container)
查看>>
Linux常用命令
查看>>
Grub4Dos 手动引导指令
查看>>
C# 有道API翻译 查询单词详细信息
查看>>
android 录像提示音问题
查看>>