• GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源。

MySQL 的表有很多种,对表的操作主要是增删改查,今天来浅谈一下这些操作的底层代码和流程,以下以 tmp table为例子,为了更好的说明操作流程,该表没有建立 primary key。

1.首先创建一张 tmp table,第三个参数 is_virtual=false 代表这不是虚拟表,如果这个值设置为true那说明这是虚拟表,主要给存储过程建立临时表来存储参数的,这种虚拟表没有handler,只能存储列信息和单行列值,不能存放多行值,不能进行增删操作。

Table *table = create_tmp_table_from_fields(thd, *get_field_list(), false, options, table_alias);

创建表过程中会做以下操作:

1、初始化表:table->init_tmp_table
2、用传进来的create_field 信息创建表的列:make_field
3、创建表增删改查用的操作句柄:setup_tmp_table_handler

2、查找操作

table->file->ha_rnd_init(true) handler 初始化
int rec = table->file->ha_rnd_next(table->record[0]) 从第一行开始查找,一次指针向下跳一行,table->record[0]用于存储查到的值
对结果的判断:
switch (rec) {
case 0: {
查找成功可以取出查到的值,此时该行值在table->field[col],col代表第几列
break;
}
case HA_ERR_END_OF_FILE:
if (table->file->ha_rnd_end()) return true; 查找到最后一行退出
break;
default:
查找出错处理

3、插入一行,这个操作相对简单只有两步

for (ulonglong u = 0; u < upper_bound; ++u)
if (table->field[i]->store(u, true)) return true; 首先循环把值u存入第i列的record[0]
if (write_row()) return true;直接把值从record[0]写入表即可

3、更新一行

  if (table->file->ha_rnd_init(true)) return true; 初始化handler
for (int i = 0; i < offset_table + 1; i++) {
if (table->file->ha_rnd_next(table->record[1])) return true; 让指针跳到指定要更新的那一行,注意这里该行的值存在record[1]
}
memcpy(table->record[0], table->record[1], (size_t)table->s->reclength);把值从record[1]拷贝到record[0]
(*value)->save_in_field(get_field(i), false); 把value值存入第i列的record[0],注意此时别的列值还是表里查到的值,这样record[0]就是新的值
if (table->file->ha_update_row(table->record[1], table->record[0])) 更新数据,这里record[1]是旧的值即表里的值,record[0]是新的值即待更新的值
return true;
if (table->file->ha_rnd_end()) return true; 结束本次handler

4、删除一行

table->file->ha_rnd_init(true) handler初始化
for (int i = 0; i < offset_table + 1; i++) {
if (table->file->ha_rnd_next(table->record[0])) return true; 让指针跳到指定要删除的那一行
}
ret = table->file->ha_delete_row(table->record[0]); 删除当前行
if (table->file->ha_rnd_end()) return true; 结束本次handler

5、关闭表

      close_tmp_table(table); 关闭临时表
free_tmp_table(table); 释放表资源

6、打开表

open_tmp_table(TABLE *table)这个打开表

以上是没有主键和索引的临时表操作,如果是有主键的表就涉及到索引的查询操作,这期不涉及这个知识点,下期再谈。

Enjoy GreatSQL

文章推荐:

面向金融级应用的GreatSQL正式开源

https://mp.weixin.qq.com/s/cI_wPKQJuXItVWpOx_yNTg

Changes in GreatSQL 8.0.25 (2021-8-18)

https://mp.weixin.qq.com/s/qcn0lmsMoLtaGO9hbpnhVg

MGR及GreatSQL资源汇总

https://mp.weixin.qq.com/s/qXMct_pOVN5FGoLsXSD0MA

GreatSQL MGR FAQ

https://mp.weixin.qq.com/s/J6wkUpGXw3YkyEUJXiZ9xA

在Linux下源码编译安装GreatSQL/MySQL

https://mp.weixin.qq.com/s/WZZOWKqSaGSy-mpD2GdNcA

关于 GreatSQL

GreatSQL是由万里数据库维护的MySQL分支,专注于提升MGR可靠性及性能,支持InnoDB并行查询特性,是适用于金融级应用的MySQL分支版本。

Gitee:

https://gitee.com/GreatSQL/GreatSQL

GitHub:

https://github.com/GreatSQL/GreatSQL

Bilibili:

https://space.bilibili.com/1363850082/video

微信&QQ群:

可搜索添加GreatSQL社区助手微信好友,发送验证信息“加群”加入GreatSQL/MGR交流微信群

QQ群:533341697

微信小助手:wanlidbc

本文由博客一文多发平台 OpenWrite 发布!

最新文章

  1. Python全栈开发【面向对象】
  2. 18.tty驱动程序框架
  3. NIO源码阅读
  4. [转]双数组TRIE树原理
  5. [HDOJ5783]Divide the Sequence(贪心)
  6. MyTask2
  7. Orchard 源码探索(Module,Theme,Core扩展加载概述)
  8. POJ训练计划2299_Ultra-QuickSort(归并排序求逆序数)
  9. .NET下,关于文件夹权限设置的小细节
  10. 卷积神经网络CNN公式推导走读
  11. java中构造方法及其作用
  12. python 单例模式的四种创建方式
  13. MR汇聚工具步骤
  14. code forces 805B (水)
  15. 外部访问docker容器(docker run -p/-P 指令)
  16. c语言数组应用
  17. Python3 tkinter基础 Button command 单击按钮 在console中打印文本
  18. MemCahced 使用及常见问题说明
  19. hdoj 2717 Catch That Cow
  20. 改成maven工程

热门文章

  1. 推荐一款新框架PyScript:在 HTML 嵌入 Python 代码!
  2. 文件操作(Java)
  3. 使用pdfcrack &amp; crunch暴力破解PDF密码
  4. K8S 使用Kubeadm搭建单个Master节点的Kubernetes(K8S)~本文仅用于测试学习
  5. 【Windbg】记一次线程卡主的问题
  6. NPM Error:gyp: No Xcode or CLT version detected!
  7. .NET中线程锁的使用
  8. 给王心凌打Call的,原来是神奇的智能湖仓
  9. Charles如何抓取https请求-移动端+PC端
  10. canal的使用