【AICon】AI 大模型超全落地场景&最佳实践 了解详情
写点什么

SQLite——只要 3 分钟,你就可以在.NET 上创建和运行它

  • 2008-01-20
  • 本文字数:1628 字

    阅读完需:约 5 分钟

AI 大模型超全落地场景&金融应用实践,8 月 16 - 19 日 FCon x AICon 大会联诀来袭、干货翻倍!

SQLite 是一个开源数据库,现在已变得越来越流行,它的体积很小,被广泛应用于各种不同类型的应用中。

什么是 SQLite?

SQLite 的官方网站上是这样定义 SQLite 的:

SQLite 是一个软件库,用于实现自包含非服务式零配置事务化的 SQL 数据库引擎。
SQLite 是一个嵌入式 SQL 数据库引擎,与其它大多数 SQL 数据库不同的是,SQLite 没有独立的服务进程。SQLite 直接读写原始的磁盘文件,一个拥有多个表、索引、触发器和视图的完整 SQL 数据库就包含在一个独立的磁盘文件中。数据库文件的格式是跨平台的,你可以在 32 位和 64 位系统之间、甚至在 Big-Endian Little-Endian (译者注:这是两种不同的字节排序方式,Big-Endian 是指一个 word 中的高位 Byte 是放在内存 word 区域的低地址处,而 Little-Endian 则与之相反) 两种不同的架构间自由地拷贝数据库,这一特性让 SQLite 成为应用文件格式的一种流行选择。SQLite 不能替代 Oracle ,但可以考虑作为 fopen() 的替代方法。
SQLite 已经是世界上布署得最广泛的 SQL 数据库引擎,被用在无以计数的桌面电脑应用中,还有消费电子设备中,如移动电话、掌上电脑和 MP3 播放器等。SQLite 的源码就放在公有领域(即 WikiPedia 的 public domain ) 中。

SQLite 最早是应用在 Linux 和 OSX 平台上的,但对数据库需求较少的 Windows 应用而言,它是替代 SQL Express 和 Access 数据库运行于.NET 之上的一个可行且实用的选择。

有一篇来自开发者 Mike Duncan 的文章,给出了一个在 3 分钟内就可将 SQLite 安装到.NET 上的指南。这个指南非常有用,读完它你就可以使用一个轻量级的数据库来处理你丢给它的许多任务。

3 分钟的指南

指南是从第一次下载 SQLite 开始的:

尽管你可以通过 SQLite 下载页获得 Windows 的通用库,但我还是打算建议你从 sourceforge 获取 SQLite 的 ADO.NET 2.0 数据提供者,我并不是说它是最高效的版本(它有一个 ADO 包装层以及附带的无用功能),但它确实是一个非常容易上手的版本,可能值得长期使用。

找出 DLL:

将找到的 DLL(System.Data.SQLite.DLL)拷贝到你的项目中,并添加引用。

下载和安装一个 SQLite GUI 工具, SQLiteMan 有一个非常出色的 windows 版本,指南上是这样说的:

我一直在使用的工具名为“SQLite Administrator”(很合适的名字,它是免费的!)有一个“甜点”——有着一个和Query Analyzer 很像的界面。如果你有兴趣的话,可以从这里 http://www.sqlite.org/cvstrac/wiki?p=ManagementTools 找到一个很大的 SQLite GUI 客户端列表。

指南的最后一步就是创建一个 SQLite 数据库:

通过 GUI,创建一个数据库并随意创建一个测试表,就会出现一个以.s3db 为尾缀的单独文件。

一旦 System.Data.SQLite.dll 被引用为.NET 项目的一部分,那就可以像在你的应用顶部写 using System.Data.SQLite 那样容易地使用它。通过使用 ADO.NET 包装层,一个参数化的查询看上去会像是这样:

string lookupValue;<br></br>using (SQLiteCommand cmd = cnn.CreateCommand())<br></br>{<br></br> for (int i = 0; i < 100; i++)<br></br> {<br></br> lookupValue = getSomeLookupValue(i);<br></br> cmd.CommandText = @"UPDATE [Foo] SET [Value] = [Value] + 1<br></br> WHERE [Customer] LIKE '" + lookupValue + "'";<br></br> cmd.ExecuteNonQuery();<p> }</p><br></br>}

数据提供者

SQLite 已经实实在在地影响到.NET 的开发,已经有很多数据提供器被用于流行的对像关系映射(O/RM, 即 Object-Relational Mapper)框架中。

LINQ 提供器允许.NET 3.5 的开发者们利用新 LINQ 框架的优势,并以 SQLite 作为后端数据存储。

SQLite 可以作为替代 Access 或 SQL Express 让数据库应用快速创建和运行起来的一个不错选择,而且因为数据库还可以同时在 Linux 和 Mac OSX 平台上使用,所以创建一个可以跨平台使用的数据库应用很容易。

查看英文原文 Up and Running with SQLite on .NET in 3 Minutes

2008-01-20 05:1819642
用户头像

发布了 90 篇内容, 共 13.0 次阅读, 收获喜欢 10 次。

关注

评论

发布
暂无评论
发现更多内容

通证经济最核心的价值,就是带来了流动性的质变

CECBC

智汇华云 | kata container virtiofs测试和技术分析

华云数据

呱呱乐园软件开发|呱呱乐园系统APP开发

思购臻选系统开发|思购臻选APP软件开发

Redisson 分布式锁源码 11:Semaphore 和 CountDownLatch

程序员小航

Java redis 源码 redssion redisson 分布式锁

存储大师班 | Linux IO 模式之 io_uring

QingStor分布式存储

Linux 文件存储 分布式存储 Linux Kenel

赞 1 收藏 分享 B站崩溃3小时引网友狂欢:A站成为最大赢家?

白亦杨

万万没想到,低功耗也会烧毁元器件?

不脱发的程序猿

嵌入式 电路设计 低功耗 ADI 稳压器

(ROYOLE)全球首款柔性屏开发套件,柔宇RoKit终于来了!

Vsir·横磨剑

揭秘百度微服务监控:百度游戏服务监控的演进

百度Geek说

微服务 大前端 游戏

mysql常用命令

阿呆

mysql命令

桌面多空间使用技巧

DisonTangor

chrome Windows 10 fedora

门道APP开发|门道软件系统开发

JVM面试高频考点:由浅入深带你了解G1垃圾回收器!

华为云开发者联盟

Java JVM 服务端 G1垃圾回收器 Java堆

项目绩效考核管理有哪些方法?这7种考核方式值得一试!

优秀

低代码

Serverless 时代下大规模微服务应用运维的最佳实践

阿里巴巴中间件

云计算 Serverless 微服务 云原生 中间件

中国移动5G消息开发者社区强势助力,创客马拉松大赛5G消息专题赛重磅来袭!

5G消息

开发者 开发者社区 应用开发 开发者大赛 5G消息

初学汇编

若尘

汇编 汇编语言 7月日更

自学者福利!BAT常见的20道Android面试题详解

欢喜学安卓

android 程序员 面试 移动开发

自学编程找工作!46道面试题带你了解中高级Android面试

欢喜学安卓

android 程序员 面试 移动开发

数据驱动决策,可视化推动传统电力发展革命史?

一只数据鲸鱼

数据可视化 智慧能源 水力发电 智慧水利

工卡融合柔性屏,办公效率和信息安全性可能会有质的飞跃?

船医特拉法尔加

数字人民币热度不断攀升 多地再迎大规模试点

CECBC

架构之路,道阻且长

長庚

知识大陆软件系统开发介绍

AQS介绍和原理分析(下)-条件中断

追风少年

Java 并发编程 AQS

乐活星际系统软件开发资料

极狐 GitLab 初探(上)

极狐GitLab

ci DevOps gitlab CD 敏捷开发管理

区块链的风险与防范

CECBC

对标阿里水准!2021年最全Java架构面试点+技术点标准手册

Java架构追梦

Java 学习 阿里巴巴 架构 面试

什么是 shell?

学神来啦

云计算 运维 Shell shell脚本编写

SQLite——只要3分钟,你就可以在.NET上创建和运行它_.NET_Robert Bazinet_InfoQ精选文章