【C语言数据库】Sqlite3基础介绍

1. SQLite简介

SQLite is a C-language library that implements a small, fast, self-contained, high-reliability, full-featured, SQL database engine. SQLite is the most used database engine in the world. SQLite is built into all mobile phones and most computers and comes bundled inside countless other applications that people use every day.

SQLite是一个C语言库,它实现了一个小型、快速、独立、高可靠性、功能齐全的SQL数据库引擎。 SQLite 是世界上使用最广泛的数据库引擎。SQLite内置于所有手机和大多数计算机中,并捆绑在人们每天使用的无数其他应用程序中。

D. Richard Hipp于2000年春设计了SQLite(最初是作为Tcl扩展),设计目的是让程序无需安装数据库管理系统或不需要数据库管理员即可运行。与Client-Server DBMS(客户端-服务器端数据库管理系统)不同,SQLite没有与应用程序通信的独立进程。而是将SQLite库(静态或动态)集成到应用程序中,该应用程序通过调用函数来使用SQLite的功能,从而减少数据库操作的延迟。对于不需要高并发的简单查询,SQLite的性能得益于避免进程间通信的开销。

SQLite将整个数据库(table、index和data)存储为单个文件,允许多个进程或线程同时访问同一数据库(写入时锁定数据库文件)。SQLite读取操作可以是多任务的,但由于无服务器设计,写入只能顺序执行。由于SQLite必须依赖文件系统锁,因此它不是需要密集型写入的部署首选。

2. SQLite的C语言接口

Sqlite3数据库中有表如下:

CREATE TABLE IF NOT EXISTS "COMPANY" (
ID INTEGER PRIMARY KEY,
NAME TEXT NOT NULL,
AGE INTEGER NOT NULL
);INSERT INTO COMPANY (NAME, AGE) VALUES ("Stone", 25);
INSERT INTO COMPANY (NAME, AGE) VALUES ("White", 18);
INSERT INTO COMPANY (NAME, AGE) VALUES ("Ruby", 27);
ID  NAME   AGE
--  -----  ---
1   Stone  25 
2   White  18 
3   Ruby   27 

2.1 打开关闭数据库

数据库连接对象为 sqlite3

  • sqlite3_open_v2() 生成
  • sqlite3_close_v2() 销毁
int sqlite3_open_v2(		/* Open database */const char *filename,   /* Database filename (UTF-8) */sqlite3 **ppDb,         /* OUT: SQLite db handle */int flags,              /* Flags */const char *zVfs        /* Name of VFS module to use */
);

参数:

  1. filename 数据库文件名。
  2. **ppDB 即使发生错误,数据库连接句柄通常也会在 *ppDb 中返回。唯一的例外是,如果无法分配内存来保存 sqlite3* 对象,则 NULL 将被写入 *ppDb 而不是指向 sqlite3 对象的指针。
  3. flags 用于设置打开模式的标识,基础标识有:
    • SQLITE_OPEN_READONLY 数据库以只读模式打开。 如果数据库尚不存在,则返回错误。
    • SQLITE_OPEN_READWRITE 如果可能,数据库将打开以进行读写,或者仅在文件受到操作系统写保护时才进行读取。 无论哪种情况,数据库都必须已经存在,否则会返回错误。
    • SQLITE_OPEN_READWRITE | SQLITE_OPEN_CREATE 打开数据库进行读写,如果数据库不存在则创建该数据库。这是 sqlite3_open()sqlite3_open16() 始终使用的行为。
  4. zVfs sqlite3_vfs 对象的名称,该对象定义新数据库连接应使用的操作系统接口。如果值为 NULL,则使用默认的 sqlite3_vfs 对象。

函数int sqlite3_db_readonly(sqlite3 *db, const char *zDbName) 可以用来判断数据库是否真正可读写。第一个参数是数据库句柄,第二个参数是数据库连接的名字,主连接为 "main"

如果数据库打开(或创建)成功,则返回 SQLITE_OK。否则返回错误代码。

  • int sqlite3_errmsg(sqlite3 *) 用于失败后获取错误的英语描述。
  • const char *sqlite3_errcode(sqlite3 *) 用于失败后获取错误代号。
int sqlite3_close_v2(sqlite3*)	/* Close database, and destruct the sqlite3 object. */;

2.2 执行SQL语句

sqlite3_exec() 函数是sqlite3_prepare_v2()sqlite3_step()sqlite3_finalize() 的便捷包装器,它允许应用程序运行多个 SQL 语句,而无需使用大量C代码。

int sqlite3_exec(sqlite3* db,                               /* An open database */const char *sql,                           /* SQL to be evaluated */int (*callback)(void*,int,char**,char**),  /* Callback function */void *,                                    /* 1st argument to callback */char **errmsg                              /* Error msg written here */
);

参数:

  1. sqlite3* db 数据库句柄
  2. const char *sql 要执行的SQL语句。
  3. int (*callback)(void*, int, char**, char**) 回调函数用于执行完SQL语句之后的结果集。如果不使用则设为 NULL
  4. void* 回调函数的第一个参数。
  5. char **errmsg 错误语句。不设为 NULL 并且没有发生错误,则函数 sqlite3_exec() 在返回之前将该参数的指针设置为 NULL

If an sqlite3_exec() callback returns non-zero, the sqlite3_exec() routine returns SQLITE_ABORT without invoking the callback again and without running any subsequent SQL statements.

如果sqlite3_exec() 执行的callback回调函数返回非零,则sqlite3_exec() 例程返回 SQLITE_ABORT,而不会再次调用callback,也不会运行任何后续SQL语句。

执行成功就返回 SQLITE_OK

2.2.1 C语言案例

#include <stdio.h>
#include <stdlib.h>
#include <sqlite3.h>void errorMessage(sqlite3 *db, const char *errMsg);
int callback(void *NotUsed, int argc, char **argv, char **azColName);int main(int argc, char *argv[]) {char *filename = "database.db";     /* Database filename */sqlite3 *db = NULL

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/788402.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

DM数据库状态

DM 数据库包含以下几种状态&#xff1a; 配置状态&#xff08;MOUNT&#xff09;&#xff1a; 不允许访问数据库对象&#xff0c;只能进行控制文件维护、归档配置、数据库模式修改等操作&#xff1b;打开状态&#xff08;OPEN&#xff09;&#xff1a; 不能进行控制文件维护、…

day4|gin的中间件和路由分组

中间件其实是一个方法&#xff0c; 在.use就可以调用中间件函数 r : gin.Default()v1 : r.Group("v1")//v1 : r.Group("v1").Use()v1.GET("test", func(c *gin.Context) {fmt.Println("get into the test")c.JSON(200, gin.H{"…

特征融合篇 | YOLOv8改进之将Neck网络更换为GFPN(附2种改进方法)

前言:Hello大家好,我是小哥谈。GFPN(Global Feature Pyramid Network)是一种用于目标检测的神经网络架构,它是在Faster R-CNN的基础上进行改进的,旨在提高目标检测的性能和效果。其核心思想是引入全局特征金字塔,通过多尺度的特征融合来提取更丰富的语义信息。具体来说,…

JVM面试题(二)

###1. 对象的访问定位的两种方式&#xff1f; Java对象的访问定位主要有两种方式&#xff1a;句柄访问和直接指针访问。 句柄访问&#xff1a; 在句柄访问方式中&#xff0c;Java堆会被划分为两部分&#xff1a;一部分存放对象实例数据&#xff0c;另一部分存放对象实例数据的…

FPGA + 图像处理 (二) RGB转YUV色域、转灰度图及仿真

前言 具体关于色域的知识就不细说了&#xff0c;简单来讲YUV中Y通道可以理解为就是图像的灰度图&#xff0c;因此&#xff0c;将RGB转化为YUV是求彩色图的灰度直方图、进行二值化操作等的基础。 HDMI时序生成模块 这里先介绍一下仿真时用于生成HDMI时序&#xff0c;用这个时…

自贡市第一人民医院:超融合与 SKS 承载 HIS 等核心业务应用,加速国产化与云原生转型

自贡市第一人民医院始建于 1908 年&#xff0c;现已发展成为集医疗、科研、教学、预防、公共卫生应急处置为一体的三级甲等综合公立医院。医院建有“全国综合医院中医药工作示范单位”等 8 个国家级基地&#xff0c;建成高级卒中中心、胸痛中心等 6 个国家级中心。医院日门诊量…

Ubuntu 23.04 安装es

在Ubuntu 23.04上安装Elasticsearch的过程可能与之前版本类似&#xff0c;以下是基于最新稳定版Elasticsearch的一般安装步骤&#xff1a; 准备工作&#xff1a; 确保系统已更新至最新版本&#xff1a; sudo apt update && sudo apt upgrade安装Java Development Kit (…

【Tomcat】Apache官方结束Tomcat 8.5分支版本技术支持

根据 Apache 官方发布的声明&#xff0c;Apache官方将于2024年3月31日后正式结束对于Tomcat 8.5这个分支版本的技术支持&#xff0c;包括以下几点&#xff1a; 1&#xff09;不太可能继续为 8.5 分支发布新的版本&#xff1b; 2&#xff09;仅影响 8.5 分支的漏洞将不会被解决&…

时空序列预测模型—PredRNN(Pytorch)

https://cloud.tencent.com/developer/article/1622038 (强对流天气临近预报)时空序列预测模型—PredRNN(Pytorch) 代码分为3文件&#xff1a; PredRNN_Cell.py #细胞单元 PredRNN_Model.py #细胞单元堆叠而成的主干模型 PredRNN_Main_Seq2seq_test.py #用于外推的Seq2seq 编…

【Docker】搭建便捷的Docker容器管理工具 - dockerCopilot

【Docker】搭建便捷的Docker容器管理工具 - dockerCopilot 前言 本教程基于绿联的NAS设备DX4600 Pro的docker功能进行搭建。前面有介绍过OneKey&#xff0c;而dockerCopilot便是OneKey的升级版&#xff0c;作者对其进行了重新命名&#xff0c;并且对界和功能都进行了全面的优…

负载均衡集群

一、集群的基本原理 集群&#xff1a;数据内容是一致的&#xff0c;集群可以被替代 分布式&#xff1a;各司其职&#xff0c;每台服务器存储自己独有的数据&#xff0c;对外作为单点被访问是访问整体的数据&#xff1b; 分布式是不能被替代的&#xff1b;分布式分为MFS、GFS、…

结构体内存对齐和位段(重点)!!!

乐观学习&#xff0c;乐观生活&#xff0c;才能不断前进啊&#xff01;&#xff01;&#xff01; 我的主页&#xff1a;optimistic_chen 我的专栏&#xff1a;c语言 点击主页&#xff1a;optimistic_chen和专栏&#xff1a;c语言&#xff0c; 创作不易&#xff0c;大佬们点赞鼓…

数据结构栈和堆列

目录 栈&#xff1a; 栈的概念&#xff1a; 栈的实现&#xff1a; 栈接口的实现&#xff1a; 1.初始化栈&#xff1a; 2.入栈&#xff1a; 3.出栈&#xff1a; 4. 获取栈顶元素&#xff1a; 5.获取栈中有效数据的个数&#xff1a; 6.检测栈是否为空&#xff0c;如果为…

谈谈SSH整合--一起学习吧之系统架构

SSH整合是一种非常实用的Web应用程序开发框架&#xff0c;能够大大提高开发效率和应用程序的质量。 一、定义 SSH整合是指将Spring、Hibernate和Struts2这三个框架进行集成&#xff0c;形成一个统一的Web应用程序开发框架。这种整合可以大大提高开发效率和应用程序的稳定性。…

【备忘录】docker-maven-plugin 使用

在使用docker-maven-plugin 插件时&#xff0c;经常会碰到一些奇怪的问题&#xff1a; 比如&#xff1a; 1、docker远程访问时&#xff0c;认证安全问题&#xff1f; 2、dockerHost 访问地址准确性&#xff1f; 3、需要多个tag时如何处理&#xff1f; 4、push 到仓库时&#xf…

Java代码示例:演示多态特性及子类方法重写(day17)

java代码里面体现多态的特点&#xff1a; 第一步创建一个父类father&#xff0c; 然后创建子类subclasses&#xff0c; 最后创建一个DemoMulti, 上面的父类特有的方法不是私有的&#xff0c;因此子类能够继承。 新建一个父类方法Father 创建子类subclasses 在下面的代码中…

LabVIEW深度学习

目录 一、配置环境1.1、显卡选择1.2、下载显卡驱动1.3、下载并安装Anaconda1.4、配置Anaconda软件包下载服务器1.5、配置虚拟环境tf_gpu1.6、安装vscode1.7、安装tensorflow1.8、下载安装Git1.9、安装TensorFlow Object Detection API框架1.10、安装依赖的python软件包1.11、配…

Python 简单使用 RabbitMQ

一、安装 pip install pika 二、推送消息到队列中 执行pythone方法 import pika import time# 用户名和密码 user_info pika.PlainCredentials(admin,admin)# 连接服务器上的rabbitMQ服务 connection pika.BlockingConnection(pika.ConnectionParameters(127.0.0.1, 5672,…

HTTPS、对称/非对称加密、SSL/TLS

问题描述&#xff1a;HTTP的请求和响应都是明文传输&#xff0c;有安全隐患 HTTPS&#xff1a;HTTPS并不是一个单独的协议&#xff0c;是在 TCP 和 HTTP 之间加入了 SSL/TLS 安全协议&#xff0c;使得报文能够加密传输&#xff0c;SSL是TLS的前身&#xff0c;现在使用的大多都…

Taro活动列表中,对某一个活动添加分享按钮

采用data-留下分享链接的拼接参数 1.在item文件中写按钮 openType“share” <ButtonclassName{classes.rowRightShareButton}openType"share"data-share-transfer-id{lastGiftingTransferId}data-share-picture-url{shareUrl}data-share-title{shareTitle}onClic…