C#中SQLite数据库引擎的使用
acmilan2016/07/10软件综合 IP:四川

首先,从这个网站下载SQLite的XXXXXXT驱动。

XXXXXXXXXXXXXXXXXXXXXXXXXXXXX/XXXXXXXXml/doc/trunk/www/downloads.wiki

推荐下载这个版本:

Precompiled Statically-Linked Binaries for 32-bit Windows (.NET Framework 2.0 SP2)

sqlite-netFx20-static-binary-bundle-Win32-2005-1.0.102.0.zip

使用SQLite需要将C#的架构改成x86,不能用Any CPU。

XXXXXXnfig改成这样,不然在新版.NET中会加载失败。

<code class="language-xml"><?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <startup uselegacyv2runtimeactivationpolicy="true"> 
        <supportedruntime version="v4.0.30319">
        <supportedruntime version="v2.0.50727">
    </supportedruntime></supportedruntime></startup>
</configuration>
</code>

如果不想改XXXXXXnfig可以下载这个,不过.net3.5及以下版本就不能用了:

Precompiled Statically-Linked Binaries for 32-bit Windows (.NET Framework 4.0)

sqlite-netFx40-static-binary-bundle-Win32-2010-1.0.102.0.zip

使用时添加System.Data.SQLite.dll的引用就行了,不需要做其它事情。

使用示例代码如下,连接时如果文件不存在则会自动创建文件。

<code class="language-cs">using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Data.Common;
using System.Data.SQLite;

namespace sqlitetest
{
    class Program
    {
        static void Main(string[] args)
        {
            using (DbConnection conn = new SQLiteConnection("Data Source = test.db"))
            {
                conn.Open();
                using (DbCommand cmd = conn.CreateCommand())
                {
                    cmd.CommandText = "CREATE TABLE IF NOT EXISTS student(id integer, name varchar(20), sex varchar(2));";
                    cmd.ExecuteNonQuery();

                    cmd.CommandText = "INSERT INTO student VALUES(1, '小红', '男')";
                    cmd.ExecuteNonQuery();
                    cmd.CommandText = "INSERT INTO student VALUES(2, '小李', '女')";
                    cmd.ExecuteNonQuery();
                    cmd.CommandText = "INSERT INTO student VALUES(3, '小明', '男')";
                    cmd.ExecuteNonQuery();

                    cmd.CommandText = "SELECT * FROM student";
                    using (DbDataReader dr = cmd.ExecuteReader())
                    {
                        while (dr.Read())
                        {
                            Console.WriteLine(dr.GetInt32(0));
                            Console.WriteLine(dr.GetString(1));
                            Console.WriteLine(dr.GetString(2));
                        }
                    }
                }
            }
        }
    }
}
</code>

[修改于 8年5个月前 - 2016/07/10 03:10:34]

来自:计算机科学 / 软件综合
1
已屏蔽 原因:{{ notice.reason }}已屏蔽
{{notice.noticeContent}}
~~空空如也
acmilan 作者
8年5个月前 修改于 8年5个月前 IP:四川
822547
SQLite常用版本

适用于.NET 2.0 SP2/3.5:
attachment icon sqlite-netFx20-static-binary-bundle-Win32-2005-1.0.102.0.zip 1.92MB ZIP 27次下载

适用于.NET 3.5 SP1:
attachment icon sqlite-netFx35-static-binary-bundle-Win32-2008-1.0.102.0.zip 2.37MB ZIP 24次下载

适用于.NET 4.x:
attachment icon sqlite-netFx40-static-binary-bundle-Win32-2010-1.0.102.0.zip 2.61MB ZIP 26次下载

引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论

想参与大家的讨论?现在就 登录 或者 注册

所属专业
所属分类
上级专业
同级专业
acmilan
进士 学者 笔友
文章
461
回复
2934
学术分
4
2009/05/30注册,5年10个月前活动
暂无简介
主体类型:个人
所属领域:无
认证方式:邮箱
IP归属地:未同步
文件下载
加载中...
{{errorInfo}}
{{downloadWarning}}
你在 {{downloadTime}} 下载过当前文件。
文件名称:{{resource.defaultFile.name}}
下载次数:{{resource.hits}}
上传用户:{{uploader.username}}
所需积分:{{costScores}},{{holdScores}}下载当前附件免费{{description}}
积分不足,去充值
文件已丢失

当前账号的附件下载数量限制如下:
时段 个数
{{f.startingTime}}点 - {{f.endTime}}点 {{f.fileCount}}
视频暂不能访问,请登录试试
仅供内部学术交流或培训使用,请先保存到本地。本内容不代表科创观点,未经原作者同意,请勿转载。
音频暂不能访问,请登录试试
支持的图片格式:jpg, jpeg, png
插入公式
评论控制
加载中...
文号:{{pid}}
投诉或举报
加载中...
{{tip}}
请选择违规类型:
{{reason.type}}

空空如也

加载中...
详情
详情
推送到专栏从专栏移除
设为匿名取消匿名
查看作者
回复
只看作者
加入收藏取消收藏
收藏
取消收藏
折叠回复
置顶取消置顶
评学术分
鼓励
设为精选取消精选
管理提醒
编辑
通过审核
评论控制
退修或删除
历史版本
违规记录
投诉或举报
加入黑名单移除黑名单
查看IP
{{format('YYYY/MM/DD HH:mm:ss', toc)}}