赞
踩
SQLite第一个Alpha版本诞生于2000年5月. 至今已经有10个年头了. SQLite也迎来了一个版本 SQLite 3已经发布.
SQLite是一款轻型的数据库,是遵守ACID的关系式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如Tcl、PHP、Java等,还有ODBC接口,同样比起Mysql、PostgreSQL这两款开源世界著名的数据库管理系统来讲,它的处理速度比他们都快。
创建表:create table XXX(name text, passwd text)
向表中插入数据:insert into XXX values("jack", "ps666")
查询表中数据:select * from XXX;
删除指定记录项:delete from XXX where name = "rose"
删除表:drop table XXX
- int sqlite3_open(const char *filename, sqlite3 **ppDb)
- /*********************************************************************************
- * Description: 打开数据库
- * Input: filename:数据库路径名 ppDb:代指打开的数据库(打开的数据库句柄)
- * Return: 成功返回 SQLITE_OK
- 失败返回 错误码
- * Others: 不存在,则创建
- **********************************************************************************/
- int sqlite3_exec(sqlite3* ppDb, const char *sql, sqlite_callback, void *data, char **errmsg)
- /*********************************************************************************
- * Description: 执行sql语句
- * Input: ppDb:为刚才使用sqlite3_open打开的数据库链接
- sql: sql语句
- sqlite_callback:回调函数 用于查询 不关心写NULL
- data: 回调函数的参数 不关心写NULL
- errmsg:返回的错误信息
- * Return: 成功返回0 失败返回错误码
- * Others:
- **********************************************************************************/
- int sqlite3_close(sqlite3 *ppDb);
- /*********************************************************************************
- * Description: 关闭数据库
- * Input: ppDb:为刚才使用sqlite3_open打开的数据库链接
- * Return:
- * Others:
- **********************************************************************************/
- /*===============================================================
- * Copyright (C) 2022 All rights reserved.
- *
- * 文件名称:sqlite3.c
- * 创 建 者:QiuCC
- * 创建日期:2022年08月20日
- * 描 述:
- *
- * 更新日志:
- *
- ================================================================*/
- #include <stdio.h>
- #include <string.h>
- #include <stdlib.h>
- #include <sqlite3.h>
- #include <strings.h>
- #define N 100
-
- int main(int argc, char *argv[])
- {
- //创建数据库句柄db
- sqlite3 *db;
-
- //使用数据库句柄打开数据库
- int ret = sqlite3_open("./my.db", &db);
- if(ret < 0)
- {
- perror("打开数据库");
- exit(-1);
- }
-
- //用于存放数据库中需要执行的数据库指令
- char sql[N] = "create table if not exists stu_table(name text, score int);";
-
- char *errmsg;
- ret = sqlite3_exec(db, sql, NULL, NULL, &errmsg);
- if(ret != 0)
- {
- printf("sqlite3_exec:%s\n", errmsg);
- exit(-1);
- }
-
- //拷贝指令到sql中将数据进行写入
- strcpy(sql, "insert into stu_table values ('lisi', 86);");
- ret = sqlite3_exec(db, sql, NULL, NULL, &errmsg);
- if(ret != 0)
- {
- printf("sqlite3_exec:%s\n", errmsg);
- exit(-1);
- }
-
- strcpy(sql, "insert into stu_table values ('zhangsan', 91)");
- ret = sqlite3_exec(db, sql, NULL, NULL, &errmsg);
- if(ret != 0)
- {
- printf("sqlite3_exec:%s\n", errmsg);
- exit(-1);
- }
-
- //关闭数据库
- sqlite3_close(db);
-
- return 0;
- }
从上述结果中可以看出,我们成功的将创建了一张成绩的表,并且内部数据均正确,这里值得注意的是,我们的数据库命令在输入完成时一定要加上分号,不然就无法正确执行。
好的,以上就是本期内容了!!!
欢迎大家参考指正!!!
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。