Sqlite3数据库

工具库的使用:程序编写时#include <库名.h>即可调用库中的函数 编译时链接工具库;

注意:数据库中不区分字母大小写;
SQLite 中的事务是数据库操作中非常重要的一个概念,它用于确保数据库操作的完整性和一致性。以下是关于 SQLite 中事务的详细介绍:

1. 事务的基本概念

事务是一组数据库操作的集合,这些操作要么全部成功,要么全部失败。在事务执行过程中,如果任何一个操作失败,那么整个事务都会被撤销,数据库会恢复到事务开始之前的状态。事务具有以下四个特性(ACID):

  • 原子性(Atomicity):事务中的所有操作要么全部执行,要么全部不执行。
  • 一致性(Consistency):事务执行前后,数据库的状态都必须满足完整性约束。
  • 隔离性(Isolation):多个事务并发执行时,一个事务的执行不会被其他事务干扰。
  • 持久性(Durability):一旦事务提交,其对数据库的更改就会被永久保存。

2. 事务的使用

在 SQLite 中,事务的使用主要通过 SQL 语句来控制。以下是事务的基本操作:

(1)开始事务

使用 BEGIN TRANSACTIONBEGIN 语句来开始一个事务。例如:

BEGIN TRANSACTION;

或者

BEGIN;

这两个语句的效果是相同的,都表示开始一个新的事务。

(2)提交事务

如果事务中的所有操作都成功执行,可以使用 COMMIT 语句来提交事务,将事务中的更改永久保存到数据库中。例如:

COMMIT;

提交事务后,事务中的所有更改都会被写入数据库。

(3)回滚事务

如果事务中的某个操作失败,可以使用 ROLLBACK 语句来回滚事务,撤销事务中的所有更改,使数据库恢复到事务开始之前的状态。例如:

ROLLBACK;

回滚事务后,事务中的所有操作都不会对数据库产生影响。

3. 事务的隔离级别

SQLite 支持以下几种事务隔离级别:

  • READ UNCOMMITTED(读未提交):允许一个事务读取另一个事务未提交的数据。这种隔离级别下,可能会出现脏读、不可重复读和幻读的问题。
  • READ COMMITTED(读已提交):一个事务只能读取另一个事务已经提交的数据。这种隔离级别下,不会出现脏读,但可能会出现不可重复读和幻读。
  • REPEATABLE READ(可重复读):一个事务在读取数据时,其他事务不能对这些数据进行修改,直到当前事务完成。这种隔离级别下,不会出现脏读和不可重复读,但可能会出现幻读。
  • SERIALIZABLE(可串行化):这是最高的隔离级别,事务之间完全隔离,不会出现任何并发问题。但这种隔离级别下的性能开销最大。

SQLite 默认的隔离级别是 SERIALIZABLE,但可以通过设置 PRAGMA read_uncommitted 来改变隔离级别。例如:

PRAGMA read_uncommitted = 1; -- 设置为 READ UNCOMMITTED

4. 自动提交模式

SQLite 默认是自动提交模式(autocommit mode)。在这种模式下,每条单独的 SQL 语句都会自动开启一个事务,并在执行完成后自动提交事务。例如:

INSERT INTO table_name (column1, column2) VALUES (value1, value2);

在自动提交模式下,这条 INSERT 语句会自动开启一个事务,执行完成后自动提交。

如果需要手动控制事务,可以通过执行 BEGIN TRANSACTIONBEGIN 语句来关闭自动提交模式。关闭自动提交模式后,需要手动提交或回滚事务。例如:

BEGIN TRANSACTION;
INSERT INTO table_name (column1, column2) VALUES (value1, value2);
COMMIT;

5. 事务的注意事项

  • 事务的嵌套:SQLite 不支持嵌套事务。如果在事务中再执行 BEGIN TRANSACTION,会报错。
  • 锁机制:在事务执行过程中,SQLite 会使用锁机制来保证数据的一致性。锁的类型包括共享锁(shared lock)和排他锁(exclusive lock)。共享锁允许多个事务同时读取数据,但不允许修改;排他锁则允许一个事务独占数据,其他事务不能读取或修改。
  • 性能影响:事务的使用会对数据库性能产生一定的影响。频繁地开启和提交事务会增加系统的开销,因此在实际应用中需要合理控制事务的使用。

6. 示例

以下是一个使用事务的完整示例:

-- 开始事务
BEGIN TRANSACTION;-- 插入数据
INSERT INTO students (name, age) VALUES ('Alice', 20);
INSERT INTO students (name, age) VALUES ('Bob', 22);-- 更新数据
UPDATE students SET age = 21 WHERE name = 'Alice';-- 提交事务
COMMIT;

如果在事务执行过程中出现任何错误,可以使用 ROLLBACK 来回滚事务,撤销所有更改。

通过合理使用事务,可以确保数据库操作的完整性和一致性,提高数据库系统的可靠性。
主键:

  • 唯一的标识一行(一张表中只能有一个主键)
  • 主键应该说对用户没有意义的(常用于索引)
  • 永远不要更新主键,否则违反用户没有意义原则
  • 主键不应包含动态变化的数据,如时间戳、创建时间列、修改时间列等
  • 主键应当有计算机自动生成(保证唯一性)

唯一约束:

  • 用来保证一个列(或一组列)中数据唯一,类似于主键,但跟主键有区别
  • 表可以包含多个唯一约束,但只允许一个主键
  • 唯一约束列可修改或更新
  • 创建表时可通过unique来设置
    检查约束:
  • 用来保证一个列(或一组列)中的数据满足一组指定的条件
  • 指定范围,检查最大或最小范围,通过check实现
    视图不包含数据,因此在每次使用视图时,实际上都必须执行查询语句
    视图相当于创建视图的时候as后面的SQL语句查询得到的结果集合
    从返会结果信息(视图)中再检索视图与表一样

索引是为了在大数据库中,实现搜索、查找、条件查找等
索引避免使用情况:
表的数据量不大
表的大部分操作不是查询
大量出现NULL值的情况

C程序调用sqlite3接口;

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

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

相关文章

虚拟路由与单页应用(SPA):详解

在单页应用&#xff08;SPA&#xff0c;Single Page Application&#xff09;中&#xff0c;虚拟路由&#xff08;也称为前端路由&#xff09;是一种关键的技术&#xff0c;用于管理页面导航和状态变化&#xff0c;而无需重新加载整个页面。为了帮助你更好地理解这一概念&#…

练习:运动计划

需求&#xff1a;键盘录入星期数&#xff0c;显示今天的减肥活动。 周一&#xff1a;跑步&#xff1b; 周二&#xff1a;游泳&#xff1b; 周三&#xff1a;慢走&#xff1b; 周四&#xff1a;骑动感单车&#xff1b; 周五&#xff1a;拳击&#xff1b; 周六&#xff1a;…

通过webrtc+canvas+css实现简单的电脑滤镜拍照效果

这里我们用的是webrtc中的MediaDevices.getUserMedia()的浏览器api进行的效果实现&#xff0c;MediaDevices.getUserMedia() 会提示用户给予使用媒体输入的许可&#xff0c;媒体输入会产生一个MediaStream&#xff0c;里面包含了请求的媒体类型的轨道。此流可以包含一个视频轨道…

《TCP/IP网络编程》学习笔记 | Chapter 20:Windows 中的线程同步

《TCP/IP网络编程》学习笔记 | Chapter 20&#xff1a;Windows 中的线程同步 《TCP/IP网络编程》学习笔记 | Chapter 20&#xff1a;Windows 中的线程同步用户模式和内核模式用户模式同步内核模式同步 基于 CRITICAL_SECTION 的同步内核模式的同步方法基于互斥量对象的同步基于…

VBA-Excel

VBA 一、数据类型与变量 常用数据类型&#xff1a; Byte&#xff1a;字节型&#xff0c;0~255。Integer&#xff1a;整数型&#xff0c;用于存储整数值&#xff0c;范围 -32768 到 32767。Long&#xff1a;长整型&#xff0c;可存储更大范围的整数&#xff0c;范围 -214748364…

kotlin 内联函数 inline

高阶函数实现的原理&#xff1a;函数类型其实是生成了一个对象 。 inline翻译成中文的意思就是内联&#xff0c;在kotlin里面inline被用来修饰函数&#xff0c;表明当前函数在编译时是以内嵌的形式进行编译的&#xff0c;从而减少了一层函数调用栈&#xff1a; inline fun fun…

PairRE: Knowledge Graph Embeddings via Paired Relation Vectors(论文笔记)

CCF等级&#xff1a;A 发布时间&#xff1a;2020年11月 25年3月24日交 目录 一、简介 二、原理 1.整体 2.关系模式 3.优化模型 三、实验性能 四、结论和未来工作 一、简介 将RotatE进行生级&#xff0c;RotatE只对头实体h进行计算&#xff0c;PairRE对头尾实体都进行…

从报错到成功:Mermaid 流程图语法避坑指南✨

&#x1f680; 从报错到成功&#xff1a;Mermaid 流程图语法避坑指南 &#x1f680; &#x1f6a8; 问题背景 在开发文档或技术博客中&#xff0c;我们经常使用 Mermaid 流程图 来可视化代码逻辑。但最近我在尝试绘制一个 Java Stream 转换流程图时&#xff0c;遭遇了以下报错…

深入解析 Redis 实现分布式锁的最佳实践

前言 在分布式系统中&#xff0c;多个进程或线程可能会同时访问同一个共享资源&#xff0c;这就可能导致数据不一致的问题。为了保证数据的一致性&#xff0c;我们通常需要使用分布式锁。Redis 作为高性能的内存数据库&#xff0c;提供了一种简单高效的方式来实现分布式锁。本…

2025年03月10日人慧前端面试(外包滴滴)

目录 普通函数和箭头函数的区别loader 和 plugin 的区别webpack 怎么实现分包&#xff0c;为什么要分包webpack 的构建流程变量提升react 开发中遇到过什么问题什么是闭包vue 开发中遇到过什么问题vue中的 dep 和 watcher 的依赖收集是什么阶段什么是原型链react setState 是同…

Android10 系统截屏功能异常的处理

客户反馈的问题&#xff0c;设备上使用状态栏中“长截屏”功能&#xff0c;截屏失败且出现系统卡死问题。 在此记录该问题的处理 一现象&#xff1a; 设备A10上使用系统“长截屏”功能&#xff0c;出现截屏失败&#xff0c;系统死机。 二复现问题并分析 使用设备操作该功能&…

openvela新时代的国产开源RTOS系统

openvela 简介 openvela 操作系统专为 AIoT 领域量身定制&#xff0c;以轻量化、标准兼容、安全性和高度可扩展性为核心特点。openvela 以其卓越的技术优势&#xff0c;已成为众多物联网设备和 AI 硬件的技术首选&#xff0c;涵盖了智能手表、运动手环、智能音箱、耳机、智能家…

ENSP学习day9

ACL访问控制列表实验 ACL&#xff08;Access Control List&#xff0c;访问控制列表&#xff09;是一种用于控制用户或系统对资源&#xff08;如文件、文件夹、网络等&#xff09;访问权限的机制。通过ACL&#xff0c;系统管理员可以定义哪些用户或系统可以访问特定资源&#x…

JVM的组成--运行时数据区

JVM的组成 1、类加载器&#xff08;ClassLoader&#xff09; 类加载器负责将字节码文件从文件系统中加载到JVM中&#xff0c;分为&#xff1a;加载、链接&#xff08;验证、准备、解析&#xff09;、和初始化三个阶段 2、运行时数据区 运行时数据区包括&#xff1a;程序计数…

RAG(Retrieval-Augmented Generation)基建之PDF解析的“魔法”与“陷阱”

嘿&#xff0c;亲爱的算法工程师们&#xff01;今天咱们聊一聊PDF解析的那些事儿&#xff0c;简直就像是在玩一场“信息捉迷藏”游戏&#xff01;PDF文档就像是个调皮的小精灵&#xff0c;表面上看起来规规矩矩&#xff0c;但当你想要从它那里提取信息时&#xff0c;它就开始跟…

Python网络编程入门

一.Socket 简称套接字&#xff0c;是进程之间通信的一个工具&#xff0c;好比现实生活中的插座&#xff0c;所有的家用电器要想工作都是基于插座进行&#xff0c;进程之间要想进行网络通信需要Socket&#xff0c;Socket好比数据的搬运工~ 2个进程之间通过Socket进行相互通讯&a…

人工智能(AI)系统化学习路线

一、为什么需要系统化学习AI&#xff1f; 人工智能技术正在重塑各行各业&#xff0c;但许多初学者容易陷入误区&#xff1a; ❌ 盲目跟风&#xff1a;直接学习TensorFlow/PyTorch&#xff0c;忽视数学与算法基础。 ❌ 纸上谈兵&#xff1a;只看理论不写代码&#xff0c;无法解…

mac calDAV 日历交互

安装Bakal docker https://sabre.io/dav/building-a-caldav-client/ 在Bakal服务器上注册账户 http://localhost:8080/admin/?/users/calendars/user/1/ 在日历端登录账户&#xff1a; Server: http://127.0.0.1:8080/dav.php Server Path: /dav.php/principals/lion No e…

手机号登录与高并发思考

基础逻辑 一般来说这个验证码登录分为手机号、以及邮箱登录 手机号短信验证&#xff0c;以腾讯云SMS 服务为例&#xff1a; 这个操作无非对后端来说就是两个接口&#xff1a; 一个是获取验证码&#xff0c;这块后端生成6位数字expire_time 去推送到腾讯云sdk &#xff0c;腾…

Python设计模式 - 适配器模式

定义 适配器模式&#xff08;Adapter Pattern&#xff09;是一种结构型设计模式&#xff0c;它用于将一个类的接口转换为客户端所期待的另一个接口。 注&#xff1a;在适配器模式定义中所提及的接口是指广义的接口&#xff0c;它可以表示一个方法或者一组方法的集合。 结构 …