mysql函数怎么调用 mysql函数nvl( 二 )


调试过程参考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函数怎么调用的信息别忘了在本站进行查找喔 。

推荐阅读