sqlite基础API
/* 打开/创建数据库文件
* 如果数据库文件不存在就创建数据库文件。
* 数据库操作句柄保存在第二个参数中。
* 第一个参数:文件路径及其文件名
* 第二个参数:sqlite3操作句柄
* 返回值:SQLITE_OK表示成功
*/
int sqlite3_open(
const char *filename,
sqlite3 **ppDb
); /* 执行sql语句
* 第一个参数:数据库操作句柄
* 第二个参数:sql语句
* 第三个参数:回调参数
* 第四个参数:传入回调函数的参数
* 第五个参数:保存操作失败的错误信息
* 返回值:SQLITE_OK表示成功
*/
int sqlite3_exec(
sqlite3 * ,
const char *sql,
int (*callback)(void *, int, char **, char **),
void *,
char **errmsg
); /* 释放申请的动态内存
*/
void sqlite3_free(void *); /* 关闭数据库操作
* 参数:数据库操作句柄
*/
int sqlite3_close(sqlite3 *);
简单应用:
#include <sqlite3.h>
#include <stdio.h> int main(void)
{
sqlite3 *db;
char *err_msg = NULL;
char *sql = "create table test_table(ID INT PRIMARY KEY NOT NULL, \
NAME TEXT NOT NULL, \
AGE INT NOT NULL, \
ADDRESS CHAR(), \
SALARY REAL);";
int ret; ret = sqlite3_open("test.db", &db);
if (ret != SQLITE_OK) {
printf("%s[%d] sqlite3_open error!\n", __func__, __LINE__);
goto error;
} ret = sqlite3_exec(db, sql, NULL, NULL, &err_msg);
if (ret != SQLITE_OK) {
printf("%s[%d] sqlite3_exec error!\n", __func__, __LINE__);
goto error;
}
char *tmp = "insert into test_table values(1,'test',1,'beijing', 1000);";
ret = sqlite3_exec(db, tmp, NULL, NULL, &err_msg);
if (ret != SQLITE_OK) {
printf("%s[%d] sqlite3_exec error!\n", __func__, __LINE__);
goto error;
} error: if (err_msg) {
sqlite3_free(err_msg);
}
if (db) {
sqlite3_close(db);
} return ;
}
sqlite基础API的更多相关文章
- SQLite基础教程目录
SQLite基础教程目录 SQLite主页 SQLite概述 SQLite -安装 SQLite -命令 SQLite -语法 SQLite -数据类型 SQLite -创建数据库 SQLite -附 ...
- Linux高性能server编程——Linux网络基础API及应用
Linux网络编程基础API 具体介绍了socket地址意义极其API,在介绍数据读写API部分引入一个有关带外数据发送和接收的程序,最后还介绍了其它一些辅助API. socket地址API 主 ...
- 服务器编程入门(4)Linux网络编程基础API
问题聚焦: 这节介绍的不仅是网络编程的几个API 更重要的是,探讨了Linux网络编程基础API与内核中TCP/IP协议族之间的关系. 这节主要介绍三个方面的内容:套接字( ...
- Linux 高性能服务器编程——Linux网络编程基础API
问题聚焦: 这节介绍的不仅是网络编程的几个API 更重要的是,探讨了Linux网络编程基础API与内核中TCP/IP协议族之间的关系. 这节主要介绍三个方面的内容:套接字(so ...
- Android BLE与终端通信(一)——Android Bluetooth基础API以及简单使用获取本地蓝牙名称地址
Android BLE与终端通信(一)--Android Bluetooth基础API以及简单使用获取本地蓝牙名称地址 Hello,工作需要,也必须开始向BLE方向学习了,公司的核心技术就是BLE终端 ...
- SVG 学习<四> 基础API
目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...
- mongoose 基础api 图表整理
一.背景 今天看 mongoose 的基础 API,参考了下面的链接做了图表以供查阅. 参考资料: http://www.cnblogs.com/xiaohuochai/p/7215067.html ...
- React实例入门教程(1)基础API,JSX语法--hello world
前 言 毫无疑问,react是目前最最热门的框架(没有之一),了解并学习使用React,可以说是现在每个前端工程师都需要的. 在前端领域,一个框架为何会如此之火爆,无外乎两个原因:性能优秀,开发 ...
- 【原创】React实例入门教程(1)基础API,JSX语法--hello world
前 言 毫无疑问,react是目前最最热门的框架(没有之一),了解并学习使用React,可以说是现在每个前端工程师都需要的. 在前端领域,一个框架为何会如此之火爆,无外乎两个原因:性能优秀,开发效率 ...
随机推荐
- 吴裕雄--天生自然JAVA线程编程笔记:进程与线程
- 怎么调出原生态launcher
adb shell am start -n com.android.launcher3/.Launcher
- PAT Advanced 1110 Complete Binary Tree (25) [完全⼆叉树]
题目 Given a tree, you are supposed to tell if it is a complete binary tree. Input Specification: Each ...
- java链接redis服务器
1.首先你需要下载驱动包jedis.jar确保下载最新驱动包. 2.public class RedisUtil { //服务器IP地址 private static String ADDR = &q ...
- __init__.py在Python中的用处
1.Python中的package定义很简单,其层次结构与程序所在目录的层次结构相同, 这一点与Java类似,唯一不同的地方在于,python中的package必须包含一个__init__.py的文件 ...
- Java中包的基本管理与编译
在写程序的过程中,总会出现代码编译过关,但是项目偏偏报错的情况,遇到几种情况,都在此一一记录,希望以后少走弯路. 1.添加jsp文件的时候,会报错 Multiple annotations found ...
- 4. react 基础 - 编写 todoList 功能
编写 TodoList 功能 react 入口 js #src/index.js import React from 'react'; import ReactDOM from 'react-dom' ...
- mysql6数据库安装与配置
详细步骤可以参考这篇文章 https://www.cnblogs.com/duguangming/p/10623520.html 1.下载并打开mysql6数据库安装文件 2.默认点击下一步 3.点击 ...
- jquery如何获取div下ul的某个li
$('div ul').each(function(){ alert($(this).find('li').eq(x)) }) $("div ul li:eq(1)")// $(& ...
- PAT甲级——1146 Topological Order (25分)
This is a problem given in the Graduate Entrance Exam in 2018: Which of the following is NOT a topol ...