【SQL】【事务】

注入SQL语句,让数据库执行

int mysql_queery(MYSQL* mysql , const char * query)

mysql:已经连接的MYSQL对象指针

query:要执行的SQL语句字符串

返回值 非0失败 成功0

关闭连接的数据库

void mysql_close()

mysql_store_result() //用于查询结果集的函数,主要处理select,show等返回结果集的SQL语句

内部流程: 将完整的结果集从服务器端读取搭配客户端,并存储在本地中

MYSQL_RES* mysql_store_result(MYSQL* mysql)

返回值:成功返回一个MYSQL_RES*的结果集指针,用于后续的读操作

失败返回NULL(查询无结果,内存不足)

使用场景:

1.需要随机访问结果集:由于结果集已经全部加载到本地内存,可以自由移动游标

(可通过mysql_data_seek()定位到具体行)

2.适用结果集较小,适合数据量不大的查询,避免服务器端长时间保持结果集

3.需要多次遍历结果集:因为将结果集已经加载到本地,所以可以反复读取,无需重新查询

mysql_num_row()用于获取 结果集 中的数的函数

my_ulonglong mysql_num_rows(MYSQL_RES* result)

参数:结果集指针

返回值:返回结果集中的行数(无符号长整形)

mysql_field_count()用于获取结果集 字段()数量的函数

unsigned int mysql_field_count(MYSQL_RES* mysql)

参数:数据库连接对象指针

返回值:返回最近一次查询的结果集字段(如果查询并无返回字段,返回0)

mysql_fetch_row()

从结果集中读取一行数据,每调用一次自动移动到下一行继续读取,直到结果集末尾返回NULL

MYSQL_ROW* mysql_fetch_row(MYSQL_RES *result)

参数:获取的结果集指针

返回值:MYSQL_ROW指针,本质上是一个字符串数组(char **)

失败返回NULL

数据库中的"事务",不可分割的操作集合,这些操作要么全部执行,要么失败全回滚

事务必须满足四大核心特点,简称ACID

1.原子性(A)

事务是一个"原子"操作单元,要么全执行,要么在某个步骤失败后,所有已经执行的操作全部被撤销(回滚),数据回到事务最开始的状态。

例子:扣款和收款同时成功时,才能执行完毕,否则有一方失败,操作回滚

2.一致性(C)

事务执行前后,数据库从一个"一致状态"切换为另一个"一致状态",即满足数据预设的约束

例子;转账前后,两个账户的总金额不变

3.隔离性(I)

多个事务同时执行时,彼此的操作互不干扰,每个事物都感受不到其他事物的存在。

数据库通过调整隔离级别来控制并发事务的交互程度(避免脏读,不可重复读,幻读)

4.持久性(D)

事务一旦提交,其对数据库的修改永久保存到数据库中,即使发生系统崩溃,数据也不会丢失

相关推荐
2301_7641505614 分钟前
c++如何读取和解析带BOM头的UTF-8与UTF-16文本流【详解】
jvm·数据库·python
qq_4240985617 分钟前
HTML函数开发用窄边框笔记本有优势吗_便携与性能权衡【指南】
jvm·数据库·python
Wyz2012102420 分钟前
CSS如何实现导航栏下划线随鼠标移动_利用-hover伪类与过渡动画控制
jvm·数据库·python
2201_7610405921 分钟前
SQL如何统计每个用户的首次行为时间_MIN聚合与分组
jvm·数据库·python
qq_1898070327 分钟前
mysql如何实现定时清理缓存数据_利用event scheduler执行
jvm·数据库·python
Polar__Star29 分钟前
golang如何实现低功耗设备唤醒机制_golang低功耗设备唤醒机制实现教程
jvm·数据库·python
a95114164231 分钟前
CSS怎么在flex布局中实现项目均分间距_设置justify-content space-evenly
jvm·数据库·python
2201_7610405937 分钟前
Golang如何做灰度发布_Golang灰度发布教程【实战】
jvm·数据库·python
小梦爱安全39 分钟前
SQL Server(Linux)安装
数据库·microsoft·sqlserver
baidu_3409988244 分钟前
CSS Grid布局如何实现项目在网格内填充_掌握justify-items属性
jvm·数据库·python