学习C#记录之第三天

今天是第三天,昨天去过光棍节了,==。所以学的东西比较少,今天要上学,不过还好下午和晚上没有课,昨天说到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());

其它操作就不赘述了,之前安卓的博客里面单有一篇讲到数据存储的。











  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值