今天是第三天,昨天去过光棍节了,==。所以学的东西比较少,今天要上学,不过还好下午和晚上没有课,昨天说到C#操作sqlite了。let's go on;
果然道路相当曲折,在使用system.data.sqlite时提示如下错误,原因是这个dll是用Framework2.0写的在4.0 上无法运行。
System.IO.FileLoadException: 混合模式程序集是针对“v2.0.50727”版的运行时生成的,在没有配置其他信息的情况下,无法在 4.0 运行时中加载该程序集。
解决方案:
右击项目-添加-新建项-应用程序配置文件。这样在项目文件下会生成一个appconfig.xml的文件。在这个里面添加如下 代码:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<startup useLegacyV2RuntimeActivationPolicy="true">
<supportedRuntime version="v4.0"/>
</startup>
</configuration>
这样成功运行:
现在可以正常的继续sqlite了:
step1:创建一个数据库文件
string dbPath = "E:\\DB\\Demo.db3";
//如果不存在改数据库文件,则创建该数据库文件
if (!System.IO.File.Exists(dbPath))
{
SQLiteConnection.CreateFile("E:\\DB\\Demo.db3");
}
step2:连接数据库
System.Data.SQLite.SQLiteConnection conn = new System.Data.SQLite.SQLiteConnection();
System.Data.SQLite.SQLiteConnectionStringBuilder connstr = new System.Data.SQLite.SQLiteConnectionStringBuilder();
connstr.DataSource = dbPath;
connstr.Password = "admin";//设置密码,SQLite ADO.NET实现了数据库密码保护
conn.ConnectionString = connstr.ToString();
conn.Open();
step3:创建表
以前用过安卓上的sqlite,所以这个部分遇到了点小问题很快解决,在重复使用如下语句时,程序会提示该表已经被创建,立马找到了eclipse里的工程把那条语句翻了出来 。==,我就记着是好像有一个create table if not exist。
System.Data.SQLite.SQLiteCommand cmd = new System.Data.SQLite.SQLiteCommand();
string sql = "CREATE TABLE test(username varchar(20),password varchar(20))";
cmd.CommandText = sql;
cmd.Connection = conn;
cmd.ExecuteNonQuery();
找到了那条语句之后,原来是少了一个s。如下正确:
System.Data.SQLite.SQLiteCommand cmd = new System.Data.SQLite.SQLiteCommand();
string sql = "CREATE TABLE if not exists test(username varchar(20),password varchar(20))";
cmd.CommandText = sql;
cmd.Connection = conn;
cmd.ExecuteNonQuery();
step4:插入值
sql = "INSERT INTO test VALUES('dotnetthink','mypasswd')";
cmd.CommandText = sql;
cmd.ExecuteNonQuery();
step5:取得值
string sql = "SELECT * FROM test";
System.Data.SQLite.SQLiteCommand cmd = new System.Data.SQLite.SQLiteCommand();
cmd.CommandText = sql;
cmd.Connection = conn;
System.Data.SQLite.SQLiteDataReader reader = cmd.ExecuteReader();
StringBuilder sb = new StringBuilder();
while (reader.Read())
{
sb.Append("username:").Append(reader.GetString(0)).Append("\n")
.Append("password:").Append(reader.GetString(1));
}
MessageBox.Show(sb.ToString());
其它操作就不赘述了,之前安卓的博客里面单有一篇讲到数据存储的。