SQLite安装及在Visual studio 2010(VS2010)中的使用

时间:2022-11-24 22:59:24

本人菜鸟,本文仅自己学习过程中总结,望高手指点

1.SQLite安装

SQlite官网:http://www.sqlite.org/download.html

找到以下截图中内容

SQLite安装及在Visual studio 2010(VS2010)中的使用

第一个解压之后是sqlite3.exe,第二个解压之后是sqlite3.dll和sqlite3.def文件,第三个是sqlite3_analyzer(暂时没用到)

可将sqlite3.exe复制到C:\Windows\System32\下,这样一来可以从任何目录下运行CLP(SQLite CLP是使用和管理SQLite数据库最常用的工具),

打开命令行输入sqlite3回车,出现如下截图

SQLite安装及在Visual studio 2010(VS2010)中的使用

2.使用SQLite创建数据库及数据表

重新进入命令行输入sqlite3 newsql_learn.db创建newsql_learn数据库

SQLite安装及在Visual studio 2010(VS2010)中的使用

然后就是SQL语句了

SQLite安装及在Visual studio 2010(VS2010)中的使用

其中.tables是查看数据库newsql_learn.db中所有的数据表,mytable是另一个已建好的数据表

http://blog.csdn.net/byxdaz/article/details/5846023还有相关SQL介绍

3.要在VS2010中使用,那么需要添加SQLite的引用

网上有关于System.Data.Sqlite 下载及安装的注意事项http://blog.csdn.net/norsd/article/details/6795695

本人也还不能确定哪个版本,自己的电脑是win8 64位,可是装的SQLite只有32位,VS2010目标生成CPU为32位,(之前整的Oracle是64位,默认目标生成为Any CPU,改成32位的Oracle出错,只好两者分开测试学习了),.NET 4.0版本

官网上下载System.Data.Sqlite:http://system.data.sqlite.org/index.html/doc/trunk/www/downloads.wiki

SQLite安装及在Visual studio 2010(VS2010)中的使用

其实我是一个一个试的····最后是从上往下算第二个,sqlite-netFx40-setup-x86-2010-1.0.97.0.exe,哎,擦TM

下载完,双击安装,默认路径是C:\Program Files (x86)\System.Data.SQLite

安装完到程序中点击添加引用(Project(项目)-->Add reference..(添加引用..)-->.Net(框架))

SQLite安装及在Visual studio 2010(VS2010)中的使用

若你的左侧列中有System.Data.SQLite恭喜你,你不用纠结了,就是那个了,选中点击确定,要是没有,可以点击右下角的浏览(不同VS版本,可能浏览的位置不同),进入C:\Program Files (x86)\System.Data.SQLite\2010\bin\找到System.Data.SQLite.dll点击确定

4.开始调用SQLite

命名空间添加

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

主函数中添加

            string connectString = @"Data Source=F:\newsql_learn.db;Pooling=true;FailIfMissing=false";
            SQLiteConnection conn = new SQLiteConnection(connectString); //新建一个连接
            conn.Open();  //打开连接,如果sqlite.db存在就正常打开,如果不存在则创建一个SQLite.db文件
            SQLiteCommand cmd = conn.CreateCommand();
            cmd.CommandText = "select * from table1";   //数据库中要事先有个orders表
            cmd.CommandType = CommandType.Text;
            using (SQLiteDataReader reader = cmd.ExecuteReader())
            {
                while (reader.Read())
                    Console.WriteLine(reader[0].ToString());
            }
注:这里出现了错误,莫名其妙的错误,系统显示没有找到table1数据表,可是利用SQLite命名行进行查找却可以找到table1及该数据表下的所有数据,无奈之下下载了SQLiteBrowser,可是安装之后发现数据库newsql_learn中没有table1,只是有之前创建的mytable,这下更郁闷了,什么情况, 也就是说在SQLite3.exe中可以发现table1表,在调用该表以及SQLiteBrowser中都没有发现该表························

难道是创建的路径不正确,他们访问的数据库名字虽然全都是newsql_learn.db可是更本不是一个数据库?于是整个电脑搜索newsql_learn.db,果然,

SQLite安装及在Visual studio 2010(VS2010)中的使用


5.利用代码创建数据表及访问显示表中数据,以下代码主要参照C#使用System.Data.SQLite操作SQLite原文地址http://hzy3774.iteye.com/blog/1691932

<span style="font-size:18px;">            //第一步先创建数据表</span>
<span style="font-size:18px;">            string dbPath = Environment.CurrentDirectory + "/test.db";//指定数据库路径  位于程序根目录下
            using (SQLiteConnection conn = new SQLiteConnection("Data Source =" + dbPath))//创建连接  
            {
                conn.Open();//打开连接  
                string sql = "CREATE TABLE IF NOT EXISTS student(id integer, name varchar(20), sex varchar(2));";//创建数据表语句  
                SQLiteCommand cmdCreateTable = new SQLiteCommand(sql, conn);
                cmdCreateTable.ExecuteNonQuery();//如果表不存在,创建数据表  

                using (SQLiteTransaction tran = conn.BeginTransaction())//实例化一个事务  使用事务操作提高效率
                {
                    for (int i = 0; i < 100; i++)
                    {
                        SQLiteCommand cmd = new SQLiteCommand(conn);//实例化SQL命令  
                        cmd.Transaction = tran;
                        cmd.CommandText = "insert into student values(@id, @name, @sex)";//设置带参SQL语句  
                        cmd.Parameters.AddRange(new[] {//添加参数  
                           new SQLiteParameter("@id", i),  
                           new SQLiteParameter("@name", "中国人"),  
                           new SQLiteParameter("@sex", "男")  
                       });
                        cmd.ExecuteNonQuery();//执行查询
                    }
                    tran.Commit();//提交  
                }
            }
           </span>
<span style="font-size:18px;">            //第二步,创建第二个数据表</span>
<span style="font-size:18px;">            SQLiteConnection conn1 = null;
            string dbPath2 = "Data Source =" + Environment.CurrentDirectory + "/test.db";
            conn1 = new SQLiteConnection(dbPath2);//创建数据库实例,指定文件位置  
            conn1.Open();//打开数据库,若文件不存在会自动创建  

            //创建第二张表
            string sql1 = "CREATE TABLE IF NOT EXISTS student2(id integer, name varchar(20));";//建表语句  
            SQLiteCommand cmdCreateTable2 = new SQLiteCommand(sql1, conn1);
            cmdCreateTable2.ExecuteNonQuery();//如果表不存在,创建数据表  
            SQLiteCommand cmdInsert = new SQLiteCommand(conn1);
            cmdInsert.CommandText = "INSERT INTO student2 VALUES(1, '小红')";//插入几条数据  
            cmdInsert.ExecuteNonQuery();
            cmdInsert.CommandText = "INSERT INTO student2 VALUES(2, '小李')";
            cmdInsert.ExecuteNonQuery();
            cmdInsert.CommandText = "INSERT INTO student2 VALUES(3, '小明')";
            cmdInsert.ExecuteNonQuery();

</span>
<span style="font-size:18px;">            //第三步查询数据</span>
<span style="font-size:18px;">            string sql2 = "select * from student";
            SQLiteCommand cmdQ = new SQLiteCommand(sql2, conn1);
            SQLiteDataReader reader = cmdQ.ExecuteReader();
            while (reader.Read())
            {
                Console.WriteLine(reader.GetInt32(0) + " " + reader.GetString(1) + " " + reader.GetString(2));
            }

            string sql3 = "select id,name from student2";
            SQLiteCommand cmdQ2 = new SQLiteCommand(sql3, conn1);
            SQLiteDataReader reader2 = cmdQ2.ExecuteReader();
            while (reader2.Read())
            {
                Console.WriteLine(reader2.GetInt32(0) + " " + reader2.GetString(1) );
            }
            conn1.Close();</span>
O了,接下来可以在此基础上开发使用数据库的其他功能了···········