使用Linux C编程读写SQLite中的Blob数据 (linux c sqlite blob)

SQLite是一种嵌入式关系型数据库,常常用于嵌入式应用程序的存储。它是开源的,并且被广泛应用于各种平台和编程语言中。在Linux系统上,我们可以使用C编程语言来读写SQLite中的Blob数据,本文将介绍的方法。

1. 安装SQLite

在Linux系统上,我们需要先安装SQLite。SQLite可以通过Advanaced Packaging Tool(APT)来安装。使用以下命令来安装SQLite:

“`

apt-get install sqlite3 libsqlite3-dev

“`

安装完SQLite之后,我们需要创建并打开一个SQLite数据库。

2. 创建SQLite数据库

使用以下命令来创建一个SQLite数据库:

“`

sqlite3 test.db

“`

这将创建一个名为test.db的SQLite数据库。我们可以在SQLite数据库中创建数据表并将数据存储在其中。

3. 在SQLite中创建数据表

在SQLite中,我们可以使用以下命令来创建数据表:

“`

CREATE TABLE test (

id INTEGER PRIMARY KEY,

data BLOB

);

“`

这将创建一个名为test的数据表,其中包含两个列。之一列是id,是INTEGER类型。第二列是data,是BLOB类型。我们可以在这个数据表中存储任意类型的数据。

4. 在C程序中打开SQLite数据库

在C程序中,我们可以使用sqlite3_open函数来打开SQLite数据库。我们需要在程序中包含sqlite3.h头文件,使用以下命令来打开SQLite数据库:

“`

sqlite3* db;

if(sqlite3_open(“test.db”, &db) != SQLITE_OK) {

fprintf(stderr, “Can’t open database: %s\n”, sqlite3_errmsg(db));

sqlite3_close(db);

return 0;

}

“`

上面的代码将打开名为test.db的SQLite数据库,并将其存储在指针变量db中。如果打开失败,程序将输出错误信息并返回。

5. 在C程序中写入Blob数据到SQLite数据库中

在C程序中,我们可以使用sqlite3_prepare函数来准备一个SQL语句。我们可以将Blob数据写入SQLite数据库中,使用以下语句:

“`

sqlite3_stmt* stmt;

const char* insert_sql = “INSERT INTO test (id, data) VALUES (?, ?)”;

sqlite3_prepare(db, insert_sql, strlen(insert_sql)+1, &stmt, NULL);

sqlite3_bind_int(stmt, 1, 1);

sqlite3_bind_blob(stmt, 2, blob_data, blob_size, NULL);

sqlite3_step(stmt);

sqlite3_finalize(stmt);

“`

上面的代码将Blob数据写入名为test的数据表中。这个SQL语句将会将id和data两列的值分别设为1和blob_data变量中的Blob数据。

6. 在C程序中读取SQLite数据库中的Blob数据

在C程序中,我们可以使用sqlite3_prepare函数来准备一个SQL语句。我们可以从SQLite数据库中读取Blob数据,使用以下语句:

“`

sqlite3_stmt* stmt;

const char* select_sql = “SELECT data FROM test WHERE id = ?”;

sqlite3_prepare(db, select_sql, strlen(select_sql)+1, &stmt, NULL);

sqlite3_bind_int(stmt, 1, 1);

while(sqlite3_step(stmt) == SQLITE_ROW) {

const void* blob_value = sqlite3_column_blob(stmt, 0);

int blob_size = sqlite3_column_bytes(stmt, 0);

// 处理blob_value和blob_size

}

sqlite3_finalize(stmt);

“`

上面的代码将从名为test的数据表中读取Blob数据。这个SQL语句将会读取id和data两列的值,并根据id条件查询。在while循环中,我们可以使用sqlite3_column_blob和sqlite3_column_bytes函数来获取data列中的Blob数据和大小。

7. 关闭SQLite数据库

在C程序中,我们可以使用sqlite3_close函数来关闭SQLite数据库。使用以下命令来关闭SQLite数据库:

“`

sqlite3_close(db);

“`

上面的代码将关闭名为test.db的SQLite数据库。

到此,我们已经介绍了的方法。SQLite是一种方便的嵌入式数据库,可以在嵌入式应用程序中存储任意类型的数据。使用C编程语言,我们可以轻松地读写SQLite中的Blob数据。

相关问题拓展阅读:

sqlite数据类型有哪些

SQLite 数据类型是一个用来指定任何对象的数据类型的属性。SQLite 中的每一列,每个变量和表达式都有相关的数据类型。

您可以在创建表的同时使用这些数据类型。SQLite 使用一个更普遍的动态类型系统。在 SQLite 中,值的数据类型与值本身是相关的,而不是与它的容器相关。

SQLite 存储类

每个存储在 SQLite 数据库中的值都具有以下存储类之一:

存储类

描述

NULL    值是一个 NULL 值。    

INTEGER    值是一个带符号的整数,根据值的大小存储在 1、2、3、4、6 或 8 字节中。    

REAL    值是一个浮点值,存储为 8 字节的 IEEE 浮点数字。    

TEXT    值是一个文本字符串,使用数据库编码(UTF-8、UTF-16BE 或 UTF-16LE)存储。    

BLOB    值是一个 blob 数据,完全根据它的输入存储。    

SQLite 的存储类稍微比数据类型更普遍。INTEGER 存储类,例如,包含 6 种不同的不同长度的整数数据类型。

SQLite 亲和(Affinity)类型

SQLite支持列的亲和类型概念。任何列仍然可以存储任何类型的数据,当数据插入时,该字段的数据将会优先采用亲缘类型作为该值的存储方式。SQLite目前的版本支持以下五种亲缘类型:

亲和类型

描述

TEXT    数值型数据在入之前,需要先被转换为文本格式,之后再插入到目标字段手局中。    

NUMERIC    当文本数据入到亲缘性为NUMERIC的字段中时,如果转换操作不会导致数据信息丢失以及完全可逆,那么SQLite就会将该文本数据转换为INTEGER或REAL类型的数据,如果转换失败,SQLite仍会以TEXT方式存储该数据。对于NULL或BLOB类型的新数据,SQLite将不做任何转换,直接以NULL或BLOB的方式存储该数据。需要额外说明的是,对于浮点格式的常量文本,如”30000.0″,如果该值可以转换为INTEGER同时又不会丢失数值信息,那么SQLite就会将其转换为INTEGER的存储方式。    

INTEGER    对于亲缘类型为INTEGER的字段,其规则等同于NUMERIC,唯一差别是在执大蠢行CAST表达式时。    

REAL    其规则基本等同于NUMERIC,唯一的差别是不会将”30000.0″这样的文本数毕仿让据转换为INTEGER存储方式。    

NONE    不做任何的转换,直接以该数据所属的数据类型进行存储。      

SQLite 亲和类型(Affinity)及类型名称

下表列出了当创建 SQLite3 表时可使用的各种数据类型名称,同时也显示了相应的亲和类型:

数据类型

亲和类型

INT

INTEGER

TINYINT

ALLINT

MEDIUMINT

BIGINT

UNSIGNED BIG INT

INT2

INT8

INTEGER    

CHARACTER(20)

VARCHAR(255)

VARYING CHARACTER(255)

NCHAR(55)

NATIVE CHARACTER(70)

NVARCHAR(100)

TEXT

CLOB

TEXT    

BLOB

no datatype specified

NONE    

REAL

DOUBLE

DOUBLE PRECISION

FLOAT

REAL    

NUMERIC

DECIMAL(10,5)

BOOLEAN

DATE

DATETIME

NUMERIC

Linux下编译.c文件时sqlite3找不到库文件如何解决?(undefined reference to `sqlite3_open’)

建议更好写个makefile,包含上库段告陵文件

动态的路径一般是/usr/lib/握戚

静态库一般可能是安友氏装目录

可以试试rmp -q

或者find / -name

sqlite3

使用gcc 文件名 -lsqlite3

如何设置sqlite

您好!很高兴为你解答此类问题,具体方法请看以下:

1.SQLite简介

SQLite是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入 式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。

它能够支持 Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结棚侍合,比如Tcl、PHP、Java、C++、.Net等,还有ODBC接口,同样比起 Mysql、PostgreSQL这两款开源世界著名的数据库管理系统来讲,它的处理速度比他们都快。

2.SQLite的特点:

轻量级

SQLite和C/S模式的数据库软件不同,它是进程内的数据库引擎,因此不存在数据库的客户端和服务器。使用SQLite一般只需要带上它的一个动态 库,就可以享受它的全部功能。

而且那个动态库的尺寸也挺小,以版本3.6.11为例,Windows下487KB、Linux下347KB。

不需要”安装”

SQLite的核心引擎本身不依赖第三方的软件,链山吵使用它唯烂也不需要”安装”。有点类似那种绿色软件。

单一文件

数据库中所有的信息(比如表、视图等)都包含在一个文件内。这个文件可以自由复制到其它目录或其它机器上。

跨平台/可移植性

除了主流操作系统 windows,linux之后,SQLite还支持其它一些不常用的操作系统。

弱类型的字段

同一列中的数据可以是不同类型

开源

3.SQLite数据类型

一般数据采用的固定的静态数据类型,而SQLite采用的是动态数据类型,会根据存入值自动判断。SQLite具有以下五种常用的数据类型:

NULL: 这个值为空值

VARCHAR(n):长度不固定且其更大长度为 n 的字串,n不能超过 4000。

CHAR(n):长度固定为n的字串,n不能超过 254。

INTEGER: 值被标识为整数,依据值的大小可以依次被存储为1,2,3,4,5,6,7,8.

REAL: 所有值都是浮动的数值,被存储为8字节的IEEE浮动标记序号.

TEXT: 值为文本字符串,使用数据库编码存储(TUTF-8, UTF-16BE or UTF-16-LE).

BLOB: 值是BLOB数据块,以输入的数据格式进行存储。如何输入就如何存储,不改 变格式。

DATA :包含了 年份、月份、日期。

TIME: 包含了 小时、分钟、秒。

二.SQLiteDatabase的介绍

Android提供了创建和是用SQLite数据库的API。SQLiteDatabase代表一个数据库对象,提供了操作数据库的一些方法。在Android的SDK目录下有sqlite3工具,我们可以利用它创建数据库、创建表和执行一些SQL语句。下面是SQLiteDatabase的常用方法。

SQLiteDatabase的常用方法

方法名称

方法表示含义

openOrCreateDatabase(String path,SQLiteDatabase.CursorFactory factory)

打开或创建数据库

insert(String table,String nullColumnHack,ContentValues values)

插入一条记录

delete(String table,String whereClause,String whereArgs)

删除一条记录

query(String table,String columns,String selection,String selectionArgs,String groupBy,String having,String orderBy)

查询一条记录

update(String table,ContentValues values,String whereClause,String whereArgs)

修改记录

execSQL(String sql)

执行一条SQL语句

close()

关闭数据库

Google公司命名这些方法的名称都是非常形象的。例如openOrCreateDatabase,我们从字面英文含义就能看出这是个打开或创建数据库的方法

1、打开或者创建数据库

在Android 中使用SQLiteDatabase的静态方法openOrCreateDatabase(String path,SQLiteDatabae.CursorFactory factory)打开或者创建一个数据库。

它会自动去检测是否存在这个数据库,如果存在则打开,不存在则创建一个数据库;创建成功则返回一个SQLiteDatabase对象,否则抛出异常FileNotFoundException。

下面是创建名为“stu.db”数据库的代码:

openOrCreateDatabase(String path,SQLiteDatabae.CursorFactory factory)

参数1 数据库创建的路径

参数2 一般设置为null就可以了

eg: db=SQLiteDatabase.openOrCreateDatabase(“/data/data/com.lingdududu.db/databases/stu.db”,null);

2、创建表

创建一张表的步骤很简单:

编写创建表的SQL语句

调用SQLiteDatabase的execSQL()方法来执行SQL语句

下面的代码创建了一张用户表,属性列为:id(主键并且自动增加)、sname(学生姓名)、snumber(学号)

View Code

3、插入数据

ContentValues 是一种存储的机制,常用于数据库的操作。只能存储基本类型。

插入数据有两种方法:

①SQLiteDatabase的insert(String table,String nullColumnHack,ContentValues values)方法,

参数1 表名称,

参数2 空列的默认值

参数3 ContentValues类型的一个封装了列名称和列值的Map;

View Code

②编写插入数据的SQL语句,直接调用SQLiteDatabase的execSQL()方法来执行

View Code

4、删除数据

删除数据也有两种方法:

①调用SQLiteDatabase的delete(String table,String whereClause,String whereArgs)方法

参数1 表名称

参数2 删除条件

参数3 删除条件值数组

View Code

②编写删除SQL语句,调用SQLiteDatabase的execSQL()方法来执行删除。

View Code

5、修改数据

修改数据有两种方法:

①调用SQLiteDatabase的update(String table,ContentValues values,String whereClause, String whereArgs)方法

参数1 表名称

参数2 跟行列ContentValues类型的键值对Key-Value

参数3 更新条件(where字句)

参数4 更新条件数组

View Code

②编写更新的SQL语句,调用SQLiteDatabase的execSQL执行更新。

View Code

6、查询数据

在Android中查询数据是通过Cursor类来实现的,当我们使用SQLiteDatabase.query()方法时,会得到一个Cursor对象,Cursor指向的就是每一条数据。它提供了很多有关查询的方法,具体方法如下:

public Cursor query(String table,String columns,String selection,String selectionArgs,String groupBy,String having,String orderBy,String limit);

各个参数的意义说明:

参数table:表名称

参数columns:列名称数组

参数selection:条件字句,相当于where

参数selectionArgs:条件字句,参数数组

参数groupBy:分组列

参数having:分组条件

参数orderBy:排序列

参数limit:分页查询限制

参数Cursor:返回值,相当于结果集ResultSet

Cursor是一个游标接口,提供了遍历查询结果的方法,如移动指针方法move(),获得列值方法getString()等.

Cursor游标常用方法

方法名称

方法描述

getCount()

获得总的数据项数

isFirst()

判断是否之一条记录

isLast()

判断是否最后一条记录

moveToFirst()

移动到之一条记录

moveToLast()

移动到最后一条记录

move(int offset)

移动到指定记录

moveToNext()

移动到下一条记录

moveToPrevious()

移动到上一条记录

getColumnIndexOrThrow(String columnName)

根据列名称获得列索引

getInt(int columnIndex)

获得指定列索引的int类型值

getString(int columnIndex)

获得指定列缩影的String类型值

下面就是用Cursor来查询数据库中的数据,具体代码如下:

View Code

7、删除指定表

编写插入数据的SQL语句,直接调用SQLiteDatabase的execSQL()方法来执行

View Code

三. SQLiteOpenHelper

该类是SQLiteDatabase一个辅助类。这个类主要生成一 个数据库,并对数据库的版本进行管理。

当在程序当中调用这个类的方法getWritableDatabase()或者 getReadableDatabase()方法的时候,如果当时没有数据,那么Android系统就会自动生成一个数据库。

SQLiteOpenHelper 是一个抽象类,我们通常需要继承它,并且实现里面的3个函数:

1.onCreate(SQLiteDatabase)

在数据库之一次生成的时候会调用这个方法,也就是说,只有在创建数据库的时候才会调用,当然也有一些其它的情况,一般我们在这个方法里边生成数据库表。

2. onUpgrade(SQLiteDatabase,int,int)

当数据库需要升级的时候,Android系统会主动的调用这个方法。一般我们在这个方法里边删除数据表,并建立新的数据表,当然是否还需要做其他的操作,完全取决于应用的需求。

3. onOpen(SQLiteDatabase):

这是当打开数据库时的回调函数,一般在程序中不是很常使用。

写了这么多,改用用实际例子来说明上面的内容了。

下面这个操作数据库的实例实现了创建数据库,创建表以及数据库的增删改查的操作。

该实例有两个类:

com.lingdududu.testSQLite 调试类

com.lingdududu.testSQLiteDb 数据库辅助类

SQLiteActivity.java

View Code

StuDBHelper.java

View Code

main.xml

View Code

程序运行的效果图:

使用adb命令查看数据库:

1.在命令行窗口输入adb shell回车,就进入了Linux命令行,现在就可以使用Linux的命令了。

2.ls回车,显示所有的东西,其中有个data。

3.cd data回车,再ls回车,cd data回车,ls回车后就会看到很多的com…………….,那就是系统上的应用程序包名,找到你数据库程序的包名,然后进入。

4.进去后在查看所有,会看到有databases,进入databases,显示所有就会发现你的数据库名字,这里使用的是”stu_db”。

5.sqlite3 stu_db回车就进入了你的数据库了,然后“.schema”就会看到该应用程序的所有表及建表语句。

6.之后就可以使用标准的SQL语句查看刚才生成的数据库及对数据执行增删改查了。

注:ls,cd等命令都是linux的基本命令,不了解的同学可以看看有关这方面的资料。

下面介绍几个在SQLite中常用到的adb命令:

查看

.database 显示数据库信息;

.tables 显示表名称;

.schema 命令可以查看创建数据表时的SQL命令;

.schema table_name 查看创建表table_name时的SQL的命令;

插入记录

insert into table_name values (field1, field2, field3…);

查询

select * from table_name;查看table_name表中所有记录;

select * from table_name where field1=’xx’; 查询符合指定条件的记录;

删除

drop table_name; 删除表;

drop index_name; 删除索引;

-查询,插入,删除等操作数据库的语句记得不要漏了;

# sqlite3 stu_db

sqlite3 stu_db

SQLite version 3.6.22

Enter “.help” for instructions

Enter SQL statements terminated with a “;”

sqlite> .schema

.schema

CREATE TABLE android_metadata (locale TEXT);

CREATE TABLE stu_table(id int,sname varchar(20),sage int,ssex varchar(10)); —>创建的表

sqlite> select * from stu_table;

select * from stu_table;

1|xiaoming|21|male

sqlite>

插入数据

sqlite> insert into stu_table values(2,’xiaohong’,20,’female’);

插入的数据记得要和表中的属性一一对应

insert into stu_table values(2,’xiaohong’,20,’female’);

sqlite> select * from stu_table;

select * from stu_table;

1|xiaoming|21|male

2|xiaohong|20|female-> 插入的数据

sqlite>

当点击修改数据的按钮时候

sqlite> select * from stu_table;

select * from stu_table;

1|xiaoming|23|male->年龄被修改为23

2|xiaohong|20|female

sqlite>

当点击删除数据的按钮

sqlite> select * from stu_table;

select * from stu_table;

1|xiaoming|23|male id=2的数据已经被删除

总之,我们可以在代码中执行数据库的增删改查,也可以在adb命令行下实现。不过因为SQLite没有客户端,不能直接的查看数据库变化后的信息,所以常用adb命令行查看数据库改变后的信息。

前面用到的数据库,表都是自己在代码中创建,下面介绍如何使用外部已有的数据库的方法:

先用SQLite管理工具,sqliteadmin 具体操作很简单,在这里我就不详细介绍的了,但有一个地方时候很值得注意的,就是用sqliteadmin创建数据库的时候,数据库保存的路径不能是中文路径,中文路径会出现下面的错误提示:

我在sqliteadmin 创建好数据库StuDB,:

将创建好的数据库在DDMS中点击导入到data/data/程序的包名/

linux c sqlite blob的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux c sqlite blob,使用Linux C编程读写SQLite中的Blob数据,sqlite数据类型有哪些,Linux下编译.c文件时sqlite3找不到库文件如何解决?(undefined reference to `sqlite3_open’),如何设置sqlite的信息别忘了在本站进行查找喔。


数据运维技术 » 使用Linux C编程读写SQLite中的Blob数据 (linux c sqlite blob)