mysql初学者怎么使用 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初学者怎么使用 , 是这样mysql初学者怎么使用的 。
systemctl start mysqld.service 是以系统服务来启动的,主要注册到环境变量中才能启动
service mysql start 是单独启动mysql服务
如何使用mysql连接数据库?如何使用PLSQL连接服务器上的数据库,开发初学者都需要会这个问题 。下面说一下步骤,帮助大家配置host并成功查询数据 。
1、首先鼠标右键PLSQL,选择属性 , 打开PLSQL所在文件夹位置 。
2、在文件夹中,找到instantclient文件夹 。这里将该文件移出到PLSQL安装文件外,方便之后修改 。
3、然后在instantclient下 , 找到tnsnames.ora,用编辑器打开 。
4、在tnsnames.ora中,可以配置数据库连接 。数据库名称、协议类型、host、port、sid 。配置好之后 , 保存 。
5、打开PLSQL,输入username、password , 选择到配置的数据库,进行连接 。点击“file”--“new”--“SQL Window”,打开窗口,输入查询命令,F8执行,连接成功了 。
MySQL数据库新特性之存储过程入门教程 在MYSQL 中 终于引入了存储过程这一新特性 这将大大增强MYSQL 的数据库处理能力 在本文中 将指导读者快速掌握MYSQL 的存储过程的基本知识 带领用户入门
存储过程介绍
存储过程是一组为了完成特定功能的SQL语句集 经编译后存储在数据库中 用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它 存储过程可由应用程序通过一个调用来执行 而且允许用户声明变量 同时 存储过程可以接收和输出参数 返回执行存储过程的状态值 也可以嵌套调用
存储过程的优点

推荐阅读