SQLite的总结与在C#的使用
这几天接触了一下SQLite,算是有点收获吧,因此总结一下。
SQLite简介:
SQLite是用C语言编写的数据库引擎,可以运行在Linux、Windows、Mac平台上。
SQLite安装简单,下载,解压配置环境变量就好了,之后就可以用命令行进行操作。
SQLite中每个数据库都是以单个文件的形式存在的,传说一个数据库最大容量是2T。
在事物方面,允许多个进程在同一时间从同一数据库读取数据,但是呢,只有一个能进行写操作。
SQLite在使用时,是直接从磁盘上进行数据库读写的,他不支持远程链接。
SQLite的使用场景:
最常见的就是安卓和IOS开发了,因为SQLite占用空间和内存很小,顶多也就几百k,把一些数据存到本地,不用通过网络与远程数据库交互。
我还想到一个例子,与IOS开发的同志交流了一会儿,在IOS开发中, 我就问像用户名,密码这些东西是不是也是存到SQLite中了。这个他回答,不用,因为IOS中有一个专门的list集合NSUserDefaults,这个集合就是键值对,存一些基本信息,也可以存很多数据类型。这个我就i想到和H5里面的本地存储一个样,想当初用appcan这种开发混合应用的app时,里面也有个localstorage这样的东西,专门存储一些例如账户密码这些信息。当然IOS里现在有个更牛掰的东西coredata,是面向对象的,更好用。
SQLite命令操作
1.执行sqlite3命令。
当执行该命令的时候没有传递任何参数表示默认连接到了一个内存数据库,当退出该程序的时候,数据库自动销毁。
2.退出命令:.quit 或.exit 。
3.创建一个数据库:sqlite3 test.db
注意:创建完毕该数据库后,不会立刻在磁盘上生成对应的文件,需要等待在该数据库中创建对象后,数据库文件才会写入到磁盘上。或者也可以用.databases 命令,也行。
4.设置查询语句显示样式:
.mode column --设置以列的方式显示数据
.headers on --设置查询的时候显示列名
.echo on --设置执行Sql语句的时候回显,刚执行的命令
.nullvalue NULL --设置显示的时候把所有的空值显示为null
.databases --显示当前附加到管理器中的所有的数据库
.tables 显示当前管理器中可以看到的所有的表
.schema 显示数据库中的内容的脚本
.schema 对象名 显示某个对象的脚本
5.创建索引
create index IX_mytable_name on mytable(name);
--查看所有的索引
.indices
limit n ;等价于t-sql中的top
offset n;跳过前几条。
6.日期函数:
select date()
select time();
select time('now','localtime'); --17:51:16
select datetime('now','localtime');--2017-07-06 17:51:35
介绍一款SQLite的管理工具:SQLiteStudio

SQLite在C#中使用
SQLite提供了多种语言操作的API,当然也有C#的。其书写方法几乎和ADO.NET的一摸一样。但是要引用System.Data.SQLite.dll,我们新建项目,用Nuget去直接安装System.Data.SQLite,这样可以。也可以去官网去下载安装包,安装完成之后,去引用这个dll。
表结构:
CREATE TABLE [mytable] ( [id] INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT, [value] text NULL , email text null);
C#代码:
//创建连接字符串
string constr = "Data Source=C:/SQLite/test.db;";
//创建连接对象
using (SQLiteConnection con = new SQLiteConnection(constr))
{ //创建SQL语句
string sql = "select * from mytable";
//创建命令对象
using (SQLiteCommand cmd = new SQLiteCommand(sql, con))
{ con.Open();
using (SQLiteDataReader reader = cmd.ExecuteReader())
{ if (reader.HasRows)
{
while (reader.Read())
{
Console.WriteLine(reader.GetInt32()+" , "+reader.GetString()); }
}
}
}
}

注意:可能会遇到 无法加载 DLL“SQLite.Interop.dll”: 找不到指定的模块,这种报错。解决办法,项目引用SQLite.Interop.dll,假如不起作用,替换一下System.Data.SQLite.dll的版本。
最后,还封装了一个自己的类库,关于SQLite的,以后,该慢慢积累自己的类库了。
http://git.oschina.net/sdadx/leiku/blob/master/SqlLibrary/SqliteHelper.cs
---------------------------------------------------------------------------------------华丽的分割线------------------------------------------------------------------------------------------
刚突然看到一篇用EF操作SQLite的文章,觉得不错,我也摘了一点,到我这个博客里,这样也更完整些。
如下图,直接在项目中新建实体模型,这样是不行的,数据源里根本没有SQLite的数据源。这时候应该去SQLite官网下载一个安装包,sqlite-netFx46-setup-bundle-x86-2015-1.0.105.2.exe,我下的是这个,好像必须的下载这个,下别的版本不能用。记得装完后,要重启VS.


安装的过程就不必说了,最终VS出现右图这个界面,证明装好了,下一步就是建立链接了。


哎,好多坑,安装完成之后,我想直接去VS2015中新建模型,数据源竟然还没有System.Data.SQLite Database File这个选项。原因是我必须先用NuGet,再项目中引入SQLite,之后行。


SQLite的总结与在C#的使用的更多相关文章
- 【开源】分享2011-2015年全国城市历史天气数据库【Sqlite+C#访问程序】
由于个人研究需要,需要采集天气历史数据,前一篇文章:C#+HtmlAgilityPack+XPath带你采集数据(以采集天气数据为例子),介绍了基本的采集思路和核心代码,经过1个星期的采集,历史数据库 ...
- UWP开发之ORM实践:如何使用Entity Framework Core做SQLite数据持久层?
选择SQLite的理由 在做UWP开发的时候我们首选的本地数据库一般都是Sqlite,我以前也不知道为啥?后来仔细研究了一下也是有原因的: 1,微软做的UWP应用大部分也是用Sqlite.或者说是微软 ...
- 深入解析Sqlite的完美替代者,android数据库新王者——Realm
写在前面: 又到一年一度七夕虐狗节,看着大家忍受着各种朋友圈和QQ空间还有现实生活中的轮番轰炸,我实在不忍心再在这里给大家补刀,所以我觉得今天不虐狗,继续给大家分享有用的. 如果你比较关心androi ...
- VS15 preview 5打开文件夹自动生成slnx.VC.db SQLite库疑惑?求解答
用VS15 preview 5打开文件夹(详情查看博客http://www.cnblogs.com/zsy/p/5962242.html中配置),文件夹下多一个slnx.VC.db文件,如下图: 本文 ...
- Android之SQLite数据存储
一.SQLite保存数据介绍 将数据库保存在数据库对于重复或者结构化数据(比如契约信息)而言是理想之选.SQL数据库的主要原则之一是架构:数据库如何组织正式声明.架构体现于用于创建数据库的SQL语句. ...
- 【教程】SQLite数据库修复
SQLite 大家都知道,就不多说了. 有时候数据量大了,或者存储过程中出现异常,数据库就可能会出问题. 这是以前公司产品出现过的问题,导致软件都打不开了,我花了不少时间才解决的,趁现在有空贡献出来. ...
- SQLite学习笔记(十)&&加密
随着移动互联网的发展,手机使用越来越广泛,sqlite作为手机端存储的一种解决方案,使用也非常普遍.但是sqlite本身安全特性却比较弱,比如不支持用户权限,只要能获取到数据库文件就能进行访问:另外也 ...
- mono for android中使用dapper或petapoco对sqlite进行数据操作
在mono for android中使用dapper或petapoco,很简单,新建android 类库项目,直接把原来的文件复制过来,对Connection连接报错部分进行注释和修改就可以运行了.( ...
- 【腾讯Bugly干货分享】微信iOS SQLite源码优化实践
本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57b58022433221be01499480 作者:张三华 前言 随着微信iO ...
- 【腾讯Bugly干货分享】移动客户端中高效使用SQLite
本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57b57f2a0703f7d31b9a3932 作者:赵丰 导语 iOS 程序能 ...
随机推荐
- 如何用C#寻找100到999的所有水仙花数?
首先解释一下何为水仙花数:水仙花数只是自幂数的一种,严格来说是三位数的个位.十位.百位的3次幂数相加等于原来的数字,称为水仙花数.(例如:1^3 + 5^3+ 3^3 = 153) 那么如何通过C#语 ...
- 分辨率、像素和PPI
屏幕尺寸是指屏幕对角线的长度,一般以英寸为单位,1英寸(inch)=2.54厘米(cm).传统意义上的照片尺寸也是这个概念.所以同样尺寸(指对角线)的屏幕,也可能长宽比率不同.像素(Pixel):是位 ...
- 主机设置ss代理,虚拟机共享代理
代理的原理: 关于代理的具体的书面定义你百度谷歌可以知道.这里,我想简单通过一个例子,说明代理的原理: 假如,你在北京,但你女朋友在广州,你有东西要给你的女朋友,但是正好你这几天公司有事,所以你不能去 ...
- DOM4J介绍与代码示例(2)-XPath 详解
XPath 详解,总结 XPath简介 XPath是W3C的一个标准.它最主要的目的是为了在XML1.0或XML1.1文档节点树中定位节点所设计.目前有XPath1.0和 XPath2.0两个版本.其 ...
- 写给Android App开发人员看的Android底层知识(6)
(十一)BroadcastReceiver BroadcastReceiver,也就是广播,简称Receiver. 很多App开发人员表示,从来没用过Receiver.其实吧,对于音乐播放类App,用 ...
- Python教程(0)——介绍
What's Python? Python是一种编程语言,由荷兰人Guido van Rossum于1989年,为打发无聊的圣诞节而开发的. Python的优点是语法简洁,代码量比C/C++.Java ...
- 原生js实现图片网格式渐显、渐隐效果
写正文前先吐槽一下:端午放假完第一天去某千人以上公司面试前端工程师,第一轮是我应聘职位的部门小领导,谈的不错,面试主要围绕要用到的技术来:第二轮来了我要说的正主,我了个去,问的问题一个和前端无关,问我 ...
- [python标准库]Pickle模块
Pickle-------python对象序列化 本文主要阐述以下几点: 1.pickle模块简介 2.pickle模块提供的方法 3.注意事项 4.实例解析 1.pickle模块简介 The pic ...
- 软件raid 5
软件raid 5的实现 RAID 5 是一种存储性能.数据安全和存储成本兼顾的存储解决方案. RAID 5可以理解为是RAID 0和RAID 1的折中方案.RAID 5可以为系统提供数据安全保障,但保 ...
- APUE-文件和目录(六)函数ftw和nftw
名字 ftw,nftw - 文件树遍历 概要 #include <ftw.h> int nftw(const char *dirpath, int (*fn) (const char *f ...