社区
邵发的课程社区_NO_1
《C语言/C++学习指南》数据库篇(MySQL& sqlite)
帖子详情
SQLite处理字节数BLOB (1)
阿发你好
2023-01-12 15:11:02
课时名称
课时知识点
SQLite处理字节数BLOB (1)
...全文
51
回复
打赏
收藏
SQLite处理字节数BLOB (1)
课时名称课时知识点SQLite处理字节数BLOB (1)
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
Sqlite
大对象字段读写及数据流的解压缩
1. 利用
Sqlite
创建
BLOB
类型字段,可用于图片或数据流的存储; 2. 实现
BLOB
类型字段的读写; 3. 利用ZlibNet对二进制字节流进行数据解压缩;
sqlite
3.08源码包及使用指南
sqlite
3.08源码及使用指南
sqlite
是嵌入式SQL数据库引擎
SQLite
(
SQLite
Embeddable SQL Database Engine)的一个扩展。
SQLite
是一个实现嵌入式SQL数据库引擎小型C语言库(C library),实现了独立的,可嵌入的,零配置的SQL数据库引擎。 特性包括:事务操作是原子,一致,孤立,并且持久的,即使在系统崩溃和电源故障之后。零配置——不需要安装和管理。 实现了绝大多数SQL92标准。整个数据库存储在一个单一的文件中。数据库文件可以在不同字节序的机器之间自由地共享。 支持最大可达2T的数据库。字符串和
BLOB
类型的大小只受限于可用内存。完整配置的少于250KB,忽略一些可选特性的少于150KB。 在大多数常见操作上比流行的客户/服务器数据库引擎更快。 简单易于使用的API。 内建TCL绑定。 另外提供可用于许多其他语言的绑定。具有良好注释的源代码,代码95%有较好的注释。 独立:没有外部依赖。源代码位于公共域,可用于任何用途。 用
SQLite
连接的程序可以使用SQL数据库,但不需要运行一个单独的关系型数据库管理系统进程(separate RDBMS process)。
SQLite
不是一个用于连接到大型数据库服务器(big database server)的客户端库(client library), 而是非常适合桌面程序和小型网站的数据库服务器。
SQLite
直接读写(reads and writes directly)在硬盘上的数据库文件。
SQLite
数据库
SQLite
是一个小型的C程序库,实现了独立的,可嵌入的,零配置的SQL数据库引擎。特性包括: 事务操作是原子,一致,孤立,并且持久的(ACID),即使在系统崩溃和电源故障之后。 零配置——不需要安装和管理。 实现了绝大多数SQL92标准。 (不支持的特性) 整个数据库存储在一个单一的文件中。 数据库文件可以在不同字节序的机器之间自由地共享。 支持最大可达2T的数据库。 (241 字节) 字符串和
BLOB
类型的大小最大可达 2G 字节(231字节)。 小的代码: 完整配置的少于250KB,忽略一些可选特性的少于150KB。 在大多数常见操作上比流行的客户/服务器数据库引擎更快。 简单,易于使用的API。 内建TCL绑定。 另外提供可用于许多其他语言的绑定。 具有良好注释的源代码,95%经过测试。 独立:没有外部依赖。 源代码位于公共域。 可用于任何用途。
SQLite
最全资料-完美书签
部分PDF文件书签 目录 2 使用
SQLite
编程的快速介绍 6 下载代码 6 创建一个新数据库 6 使用
SQLite
编写程序 6
SQLite
第三版总览(简介) 8 命名上的变化 11 新的文件格式 11 弱类型和
BLOB
技术支持 12 支持UTF-8和UTF-16 12 用户定义的分类排序 13 64字节的行编号 13 改良的并发性 14 致谢 14
SQLite
第三版中的数据类型 15 1.存储类别 15 2.列之间的亲和性 15 3.比较表达式 17 4.运算符 18 5.分类,排序,混合挑选 18 6.其它亲和性模式 18 7.用户定义的校对顺序 19
SQLite
不支持的 SQL 特性 21
SQLite
的体系结构简介 22 简介 22 接口程序 22 Tokenizer 22 Parser 23 代码发生器 23 虚拟机器 23 B-树 23 页面高速缓存 24 OS 接口程序 24 Utilities 24 测试代码 24
SQLite
(
Sqlite
Dev)
SQLite
,是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如 Tcl、C#、PHP、Java等,还有ODBC接口,同样比起Mysql、PostgreSQL这两款开源世界著名的数据库管理系统来讲,它的
处理
速度比他们都快。
SQLite
第一个Alpha版本诞生于2000年5月. 至今已经有10个年头,
SQLite
也迎来了一个版本
SQLite
3已经发布。
SQLite
功能
SQLite
虽然很小巧,但是支持的SQL语句不会逊色于其他开源数据库,它支持的SQL包括: ATTACH DATABASE BEGIN TRANSACTION comment COMMIT TRANSACTION COPY CREATE INDEX CREATE TABLE CREATE TRIGGER CREATE VIEW DELETE DETACH DATABASE DROP INDEX DROP TABLE DROP TRIGGER DROP VIEW END TRANSACTION EXPLAIN expression INSERT ON CONFLICT clause PRAGMA REPLACE ROLLBACK TRANSACTION SELECT UPDATE 同时它还支持事务
处理
功能等等。也有人说它象Microsoft的Access,有时候真的觉得有点象,但是事实上它们区别很大。比如
SQLite
支持跨平台,操作简单,能够使用很多语言直接创建数据库,而不象Access一样需要Office的支持。如果你是个很小型的应用,或者你想做嵌入式开发,没有合适的数据库系统,那么现在你可以考虑使用
SQLite
。目前它的最新版本是 3.7.8 。它的官方网站是:http://www.
sqlite
. org或者http://www.
sqlite
.com .cn,能在上面获得源代码和文档。同时因为数据库结构简单,系统源代码也不是很多,也适合想研究数据库系统开发的专业人士
SQLite
特性 下面是访问
SQLite
官方网站: http://www.
sqlite
. org/ 时第一眼看到关于
SQLite
的特性. 1. ACID事务 2. 零配置 – 无需安装和管理配置 3. 储存在单一磁盘文件中的一个完整的数据库 4. 数据库文件可以在不同字节顺序的机器间自由的共享 5. 支持数据库大小至2TB 6. 足够小, 大致3万行C代码, 250K 7. 比一些流行的数据库在大部分普通数据库操作要快 8. 简单, 轻松的API 9. 包含TCL绑定, 同时通过Wrapper支持其他语言的绑定 10. 良好注释的源代码, 并且有着90%以上的测试覆盖率 11. 独立: 没有额外依赖 12. Source完全的Open, 你可以用于任何用途, 包括出售它 13. 支持多种开发语言,C, PHP, Perl, Java, C#,Python
SQLite
类型
SQLite
的数据类型 首先你会接触到一个让你惊讶的名词: Typelessness(无类型). 对!
SQLite
是无类型的. 这意味着你可以保存任何类型的数据到你所想要保存的任何表的任何列中, 无论这列声明的数据类型是什么(只有在一种情况下不是, 稍后解释). 对于
SQLite
来说对字段不指定类型是完全有效的. 如: Create Table ex1(a, b, c); 诚然
SQLite
允许忽略数据类型, 但是仍然建议在你的Create Table语句中指定数据类型. 因为数据类型对于你和其他的程序员交流, 或者你准备换掉你的数据库引擎.
SQLite
支持常见的数据类型, 如: CREATE TABLE ex2( a VARCHAR(10), b NVARCHAR(15), c TEXT, d INTEGER, e FLOAT, f BOOLEAN, g CLOB, h
BLOB
, i TIMESTAMP, j NUMERIC(10,5) k VARYING CHARACTER (24), l NATIONAL VARYING CHARACTER(16) ); 前面提到在某种情况下,
SQLite
的字段并不是无类型的. 即在字段类型为”Integer Primary Key”时. 使用.NET操作SQLLITE 先下载ADO.NET2.0 Provider for
SQLite
。下载binaries zip版就可以了。下载完后解压缩,可以在bin目录下找到System.Data.
SQLite
.DLL。在vs2008中用Add Refrence功能把System.Data.
SQLite
.DLL加到工程里就可以了。运行下面代码试试: string datasource = "e:/tmp/test.db"; System.Data.
SQLite
.
SQLite
Connection.CreateFile(datasource); //连接数据库 System.Data.
SQLite
.
SQLite
Connection conn = new System.Data.
SQLite
.
SQLite
Connection(); System.Data.
SQLite
.
SQLite
ConnectionStringBuilder connstr = new System.Data.
SQLite
.
SQLite
ConnectionStringBuilder(); connstr.DataSource = datasource; connstr.Password = "admin";//设置密码,
SQLite
ADO.NET实现了数据库密码保护 conn.ConnectionString = connstr.ToString(); conn.Open(); //创建表 System.Data.
SQLite
.
SQLite
Command cmd = new System.Data.
SQLite
.
SQLite
Command(); string sql = "CREATE TABLE test(username varchar(20),password varchar(20))"; cmd.CommandText = sql; cmd.Connection = conn; cmd.ExecuteNonQuery(); //插入数据 sql = "INSERT INTO test VALUES('a','b')"; cmd.CommandText = sql; cmd.ExecuteNonQuery(); //取出数据 sql = "SELECT * FROM test"; cmd.CommandText = sql; System.Data.
SQLite
.
SQLite
DataReader 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());
邵发的课程社区_NO_1
1
社区成员
431
社区内容
发帖
与我相关
我的任务
邵发的课程社区_NO_1
全套Java/C语言系列教程
复制链接
扫一扫
分享
社区描述
全套Java/C语言系列教程
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章