/**************************************************************************
* C语言SQLite3基本操作Demo
* 声明:
* 1. 本文仅仅是为了写一个C语言SQLite3的Demo;
* 2. 本文并没有说明如何在终端下进入SQLite3创建数据库,也没有解释
* sql语句的概念,仅仅给出了代码示例,这些内容需要你自己去
* 资料。
*
* 2015-7-4 晴 深圳 南山平山村 曾剑锋
*************************************************************************/ \\\\\\\-*- 目录-*-///////
| 一、cat user.h
| 二、cat user.c
| 三、cat main.c
| 四、cat Makefile
| 五、cat user.sql
\\\\\\\\\\\\\/////////// 一、cat user.h
#ifndef __USER_H__
#define __USER_H__ #include <stdio.h>
#include <stdlib.h>
#include <sqlite3.h>
#include <string.h> // 使用结构体来保存数据库中的数据
typedef struct USER {
char id[]; // 保存数据库中的id
char name[]; // 姓名
char password[]; // 密码
char startTime[]; // 用户创建的开始时间
struct USER* next; // 数据从数据库中提取出来是用链表保存
} User; // 查询user表Demo
void userDemo(void);
// 查询数据时的回调函数
static int select_callback(void* data, int col_count, char** col_values, char** col_name);
// 打印UserLinked链表
void printUserLinked(User* userLinked);
// 获取UserLinked链表
User* getUserLinked(char* sql);
// 释放链表中的数据
void freeUserLinked(User* userLinked);
// 更新数据库
int updateUserDB(char* sql); #endif 二、cat user.c
#include "user.h" // 存放链表的表头
static User* userLinkedHead = NULL;
// 存放当前记录的结构体地址
static User* userCurrent = NULL; void userDemo(void){
// 获取用户链表
User* userLinked = getUserLinked("select * from user;");
// 打印用户链表
printUserLinked(userLinked);
// 释放用户链表
freeUserLinked(userLinked);
} // 查询数据库时的回调函数
static int select_callback(void* data, int col_count, char** col_values, char** col_name){
int i;
userCurrent = calloc(, sizeof(User));
for (i = ; i < col_count; i++) {
if(strcmp(col_name[i], "id") == ){
strcpy(userCurrent->id, col_values[i]);
}
if(strcmp(col_name[i], "name") == ){
strcpy(userCurrent->name, col_values[i]);
}
if(strcmp(col_name[i], "password") == ){
strcpy(userCurrent->password, col_values[i]);
}
if(strcmp(col_name[i], "startTime") == ){
strcpy(userCurrent->startTime, col_values[i]);
}
}
// 创建链表头
if(userLinkedHead == NULL){
userLinkedHead = userCurrent;
return ;
}
// 采用头插的方式插入链表
userCurrent->next = userLinkedHead->next;
userLinkedHead->next = userCurrent; return ;
} // 将链表中的数据打印出来
void printUserLinked(User* userLinked){
User* userCurrent = userLinked;
while(userCurrent){
printf("id = %s\n", userCurrent->id);
printf("name = %s\n", userCurrent->name);
printf("password = %s\n", userCurrent->password);
printf("startTime = %s\n", userCurrent->startTime);
userCurrent = userCurrent->next;
}
} // 当程序退出的时候,要释放堆中的内存空间
void freeUserLinked(User* userLinked){
User* freeCurrent = userLinked;
User* freePre = userLinked;
while(freeCurrent){
freeCurrent = freePre->next;
free(freePre);
freePre = freeCurrent;
}
userLinkedHead = NULL;
} // 通过传入查询sql字符串来获取查询的链表
User* getUserLinked(char* sql){
sqlite3 *db;
sqlite3_open("./user.db", &db); sqlite3_exec(db, sql, select_callback, , NULL); sqlite3_close(db);
db = ; return userLinkedHead;
} // 通过sql来更新数据库
int updateUserDB(char* sql){
sqlite3 *db;
sqlite3_open("./user.db", &db); sqlite3_exec(db, sql, NULL, NULL, NULL); sqlite3_close(db);
db = ; return ;
} 三、cat main.c
#include "user.h" int main(int argc, char** argv){
userDemo();
return ;
} 四、cat Makefile
user: user.o main.o
gcc user.o main.o -lsqlite3 -o user user.o: user.h
gcc -c user.c main.o: user.h
gcc -c main.c clean:
rm -rf *.o user 五、cat user.sql
#创建表,id为自动增长
create table user (
id integer PRIMARY KEY AUTOINCREMENT,
name varchar(),
password varchar(),
startTime timestamp
); #插入初始值
insert into user (name, password, startTime) values ('zjf', 'zjf', current_timestamp);
insert into user (name, password, startTime) values ('lt', 'lt', current_timestamp);
insert into user (name, password, startTime) values ('cyq', 'cyq', current_timestamp); #查询
select * from user;
select * from user where name='zjf'; #日期的使用
select date('now');
select time('now');
select datetime('now');
select jolianday('now')-jolianday('1981-12-23');
select strftime('%Y.%m.%d', 'now');
select strftime('%Y.%m.%d', 'now', 'localtime'); #带日期的查询
select id, name, password, date(startTime) from user;
select id, name, password, time(startTime) from user;
select id, name, password, datetime(startTime) from user; #删除表
drop table user;

C语言SQLite3基本操作Demo的更多相关文章

  1. C语言指针基本操作

    C语言指针基本操作 指针  指针介绍 如果说C语言最有魅力的地方在哪,那么毋庸置疑,非指针莫属了. 众所周知,C语言中每个变量都有一个内存地址,可以通过&进行访问.指针是一个变量,它的值是一个 ...

  2. 【软件多国语言】一个demo

    之前上学的时候做过一个东西,需要中英文软件界面,并且需要随时可以切换,当时是师妹来做的,用的最直接也是最笨的办法, what? if(中文) { button1.Text = "花姑娘&qu ...

  3. ios在SQLite3基本操作

    iOS关于sqlite3操作 iPhone中支持通过sqlite3来訪问iPhone本地的数据库. 详细用法例如以下 1:加入开发包libsqlite3.0.dylib 首先是设置项目文件.在项目中加 ...

  4. sqlite3基本操作

    在移动设备上进行高性能高效率的大量数据存储,我们一般用得时sqlite这款轻巧型的数据库,这里介绍其增删改查基本功能 在ios开发中我们需要先导入"libsqlite3.dylib" ...

  5. Linux 中 sqlite3 基本操作

    https://www.runoob.com/sqlite/sqlite-commands.html 一 .linux 下安装数据库和创建一个数据库 1. Linux 下安装sqlite3 需要两个命 ...

  6. c语言二叉树基本操作

    编译器为vs2013 #include "stdafx.h" #include<malloc.h> #include<stdlib.h> #define O ...

  7. 转贴:C语言链表基本操作

    http://www.oschina.net/code/snippet_252667_27314#comments 这个代码有很多错误,估计是从老谭书上抄来但是很多还抄错了:对照老谭的书好好研究下.切 ...

  8. C语言文件基本操作

    1.用文本方式储存‘1’,‘0’,‘2’存入文件,然后用二进制方式从文件开头读出一个short型数据,并验证结果是否正确 #include<stdio.h> #include<str ...

  9. C语言文件读写Demo

    CIODemo.c #include <stdio.h> #include <time.h> #define INPUT_BUFFER_SIZE 100 * 1024 int ...

随机推荐

  1. Mutex, semaphore, spinlock

    Mutex是一把钥匙,一个人拿了就可进入一个房间,出来的时候把钥匙交给队列的第一个.一般的用法是用于串行化对critical section代码的访问,保证这段代码不会被并行的运行. Semaphor ...

  2. MongoDB(课时9 范围运算)

    3.2.2.4 范围查询 只要是数据库,必须存在有“$in”(在范围之中).“$nin”(不在范围之中). 范例:查询姓名是“张三”,“李四”,“王五” db.students.find({" ...

  3. 《剑指offer》第三_一题(找出数组中重复的数字,可改变数组)

    // 面试题3(一):找出数组中重复的数字 // 题目:在一个长度为n的数组里的所有数字都在0到n-1的范围内.数组中某些数字是重复的,但不知道有几个数字重复了, // 也不知道每个数字重复了几次.请 ...

  4. TPCx-BB源码分析

    Copy from: 一篇文章看懂TPCx-BB(大数据基准测试工具)源码 TPCx-BB是大数据基准测试工具,它通过模拟零售商的30个应用场景,执行30个查询来衡量基于Hadoop的大数据系统的包括 ...

  5. 算法笔记--2-sat

    强连通分量的应用,详见<挑战程序设计>P324 例题1:HDU Peaceful Commission 思路:强连通分量分解,看有没有两个同一个国家的代表在一个强连通分量里,如果有,就是N ...

  6. Java 常用对象-Math类

    2017-11-02 21:26:18 Math类:Math 类包含用于执行基本数学运算的方法,如初等指数.对数.平方根和三角函数. *属性摘要 *常用方法 random() : 返回[0.0,1.0 ...

  7. Html概述

    Html概述 主要思想,主要思想很重要 一.Html是什么 一种标记语言(用标签进行标记) 对要显示的文字进行标记 二.Html核心 标签(只认标签) 封装,所以必须有头尾,你才知道标签的范围,你才知 ...

  8. English Words Type

    经常见到的: v = 动词,兼指及物动词和不及物动词,verb的缩写 n = 名词,noun的缩写 adj = 形容词, adjective的缩写 adv.表示副词, adverb的缩写 prep.表 ...

  9. LeetCode--067--二进制求和

    问题描述: 给定两个二进制字符串,返回他们的和(用二进制表示). 输入为非空字符串且只包含数字 1 和 0. 示例 1: 输入: a = "11", b = "1&quo ...

  10. C#下实现的K-Means优化[1]-「离群点检测」

    资源下载 #本文PDF版下载 C#下实现的K-Means优化[1]-「离群点检测」 前言 在上一篇博文中,我和大家分享了「C # 下实现的多维基础K-MEANS聚类」的[C#下实现的基础K-MEANS ...