zoukankan      html  css  js  c++  java
  • C#使用System.Data.SQLite操作SQLite

    使用System.Data.SQLite 下载地址:http://system.data.sqlite.org/index.html/doc/trunk/www/downloads.wiki

    得到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来查看数据:

    下载地址:http://sourceforge.net/projects/sqlitebrowser/

       建表成功。

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

    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.         }  

       数据读取成功。

  • 相关阅读:
    iptables学习笔记
    启动级别和单用户模式
    Apache虚拟主机配置模板
    LAMP环境搭建问题
    LAMP环境搭建
    C++面向对象高级编程(九)Reference与重载operator new和operator delete
    C++面向对象高级编程(八)模板
    C++面向对象高级编程(七)point-like classes和function-like classes
    C++面向对象高级编程(六)转换函数与non-explicit one argument ctor
    C++面向对象高级编程(五)类与类之间的关系
  • 原文地址:https://www.cnblogs.com/gc2013/p/3806257.html
Copyright © 2011-2022 走看看