Linux C 实现sqlite3数据库的基本操作

发布于:2023-01-10 ⋅ 阅读:(459) ⋅ 点赞:(0)

一、数据库简介

        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

三、sqlite3相关接口函数

1、打开数据库——sqlite_open()

int sqlite3_open(const char *filename, sqlite3 **ppDb)
/*********************************************************************************  
* Description:  打开数据库
* Input:         filename:数据库路径名  ppDb:代指打开的数据库(打开的数据库句柄)
* Return:        成功返回 SQLITE_OK 
				 失败返回 错误码
* Others:        不存在,则创建
**********************************************************************************/

2、执行sql语句——sqlite_exec()

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:       
**********************************************************************************/

3、关闭数据库——sqlite_close()

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;
}

五、结果展示

        从上述结果中可以看出,我们成功的将创建了一张成绩的表,并且内部数据均正确,这里值得注意的是,我们的数据库命令在输入完成时一定要加上分号,不然就无法正确执行。 

好的,以上就是本期内容了!!!

欢迎大家参考指正!!!