调试过程参考macOS VSCode 编译调试 MySQL 5.7[2]
内部Item对象参考从SQL语句到MySQL内部对象[3]
源码面前没有秘密,建义对 DB 感兴趣的尝试 debug 调试 。本文环境为 mac + vscode + lldb
vscode 插件mysql函数怎么调用:
mysql 源码:
补?。? MySQL = 8.0.21需要对 cmake/mysql_version.cmake 文件打补丁 (没有严格测试所有版本)
创建cmake-build-debug目录,后续 mysql 编译结果,以及启动后生成的文件都在这里
在 mysql 工程目录下面创建.vscode/settings.json文件
内容没啥好说的,都是指定目录及 boost 配置 , 其中WITH_DEBUG打开 debug 模式,会在 /tmp/debug.trace 生成 debug 信息
View-Command Palette-CMake: Configure执行后生成 cmake 配置
View-Command Palette-CMake: Build编译生成最终 mysql 相关命令
发现老版本编译很麻烦,各种报错,mysql 5.7 代码量远超过 5.5, 只能硬着头皮看 5.7
首先初始化 my.cnf 配置,简单的就可以,共它均默认
初始化数据文件,非安全模式,调试用
由于用 vscode 接管 mysql, 所以需要配置.vscode/launch.json
然后点击run and debug mysqld
mysql 启动 , 看到输出日志无异常,此时可以用 mysql-client 连接
首先在 sql_parser.cc:5435 处打断点
mysql_parse是 sql 处理的入口,至于 tcp connection 连接先可以忽略
执行上述 sql 自动跳转到断点处,Step Into ,Step Over ,Step Out这些调试熟悉下即可
接下来分别调用主要函数:mysql_execute_command ,execute_sqlcom_select ,handle_query ,select-join-exec() ,Query_result_send::send_data ,Item::send ,Item_string:val_str ,Protocol_text::store ,net_send_ok
启动 mysql 时init_common_variables会初始化一堆变量,其中会调用set_server_version生成版本信息,修改这个就可以
看好条件编译的是哪块,修改即可 , 重新CMake: Build编译再运行
这里不做过深分析,简单讲
sql_yacc.cc函数PTI_function_call_generic_ident_sys解析 sql, 识别出version()是一个函数调用
find_native_function_builder查找 hash 表,找到对应version函数注册的单例工厂函数
mysql 启动时调用item_create_init将这些函数 builder 注册到 hash 表native_functions_hash
MySQL 代码太庞大,5.1 大约 100w 行,5.5 130w 行 , 5.7 以后 330w 行 , 只能挑重点读源码 。最近很多群里的人在背八股,没必要,有那时间学着调试下源码 , 读读多好
原文出处:
【mysql函数怎么调用 mysql函数nvl】mysql函数怎么调用的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于mysql函数nvl、mysql函数怎么调用的信息别忘了在本站进行查找喔 。
推荐阅读
- b站2022直播收入,b站直播赚钱比例
- 单机飞机射击游戏,单机的飞机射击游戏
- 休闲拼接游戏手机,拼接小游戏
- go语言挖矿 gos挖矿
- 遵义专业sap咨询服务,遵义高端商务会所
- linux命令行进去登录,linux登录账号命令是啥
- 苹果游戏推荐格斗,苹果好玩的格斗类游戏
- mysql创建错怎么结束 mysql创建表错误
- 怎么给老电视连上网络的简单介绍