初学SQLITE3的运用

一:

数据定义(DDL):用户定义、删除和修改数据模式      (create、drop、alter)

数据查询(DQL):用于查询数据                   (select)

数据操纵(DML):用于增、删、改数据                          (insert、update、delete)

数据控制(DCL):用于控制数据访问权限                       (grant、revoke、deny)

基本常用命令(前面都有个点):.exit   退出  .help  查看手册  .tables  查看表  .schema stu  查看表的结构

   SQL由命令组成,每个命令以分号(;)结束

二:

1、创建表

在SQL中,创建和删除数据库对象的语句一般被称为数据定义语言(data definition language,DDL),

操作这些对象中数据的语句称为数据操作语言(data manipulation language,DML)。创建表的语句属于DDL,

用CREATE TABLE命令,如下定义:

CREATE [TEMP] TABLE table_name (column_definitions [, constraints]);
举例

create table if not exists student (name text, id integer, sex text);

说明:text(字符,字符串) 、integer(整型)

        创建表时可以指定一个关键字,防止有同名存在

举例:

create table food_types(id integer primary key, name text );

2、改变表的结构

alter table student rename to stu; //修改表名
alter table student add column score integer; //增加一列

3、插入数据

"insert into student (name, id, sex) values ('%s', %d, '%c');", name, id, sex
可以不插入所有项数据

4、修改数据

update student set sex = "f" where name = "jsetc";
更新这张表名字为 "jsetc" sex这一项

5、查询数据

select *from student;  查询所有
select *from student where score > 3 / between 2 and 4;             查询某一条件的信息
select name from student    查询某一列
select Sname from student where Sdept = 'CS';

6、删除数据

delete from student where name = "test";

三:

1、 int sqlite3_open(const char* fileName, sqlite3** ppDB);

函数功能:打开一个数据库;若该数据库文件不存在,则自动创建。 

打开或者创建数据库的命令会被缓存,直到这个数据库真正被调用的时候才会被执行。

返回值:执行成功返回SQLITE_OK,否则返回其他值;

2、 int sqlite3_exec(sqlite3* pDB, const char *sql, sqlite_callback callback, void*para, char** errMsg);

       函数功能:编译和执行零个或多个SQL 语句,查询的结果返回给回调函数callback

3、 回调函数sqlite_callback介绍
typedef int (*sqlite_callback)(void* para,int columnCount,char** columnValue,char** columnName);
函数功能:由用户处理查询的结果

输入参数:para,从sqlite3_exec()传入的参数指针;columnCount, 查询到的这一条记录有多少个字段(即这条记录有多少列);

columnValue,查询出来的数据都保存在这里,它实际上是个1 维数组(不要以为是2 维数组),每一个元素都是一个char * 值,

是一个字段内容(用字符串来表示,以‘\0’结尾);columnName,与columnValue 是对应的,表示这个字段的字段名称。


输出参数:无
返回值:执行成功返回SQLITE_OK,否则返回其他值

4、 int sqlite3_get_table(sqlite3* pDB, const char *sql,char ***pResult, int * rowCount,int * columnCount, char** errMsg);
函数功能:执行SQL 语句,通过一维数组返回结果;一般用于数据记录查询

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值