一:
数据定义(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 语句,通过一维数组返回结果;一般用于数据记录查询