MySQL之Text Protocol
1)[01]COM_QUIT
告诉服务器,客户端想要关闭连接
返回:或者关闭一个连接或者一个OK_Packet
有效负载:
1 [01]COM_QUIT
字段:
command(1)--0x01 COM_QUIT
例子:
01 00 00 00 01
2)[02]COM_INIT_DB
更改连接的默认架构
返回:OK_Packet或者ERR_Packet
有效负载:
1 [02]COM_INIT_DB
string[EOF] schema name
字段:
command(1)--0x02 COM_INIT_DB
schema_name(string.EOF)--name of the schema to change to
例子:
05 00 00 00 02 74 65 73 74 .....test
3) [03]COM_QUERY
一个COM_QUERY数据包像服务器发送基于text的立即执行的查询。
返回:服务器回复带COM_QUERY Response的COM_QUERY数据包。
查询语句的长度等于数据包里的length - 1。
有效负载:
1 [03]COM_QUERY
string[EOF] the query the server shall execute
字段:
command_id(1)--0x03 COM_QUERY
query(string.EOF)--query_text
返回:COM_QUERY Response
例子:
4)[04]COM_FIELD_LIST
注意:从MySQL5.7.11开始,COM_FIELD_LIST已弃用,将在未来版本删除。而是使用mysql_query()来执行SHOW COLUMNS语句。
COM_FIELD_LIST:
获取表的列定义
有效负载:
5)[05]COM_CREATE_DB
创建一个架构
有效负载:
1 [05]COM_CREATE_DB
string schema name
返回:OK_Packet或者ERR_Packet
例子:
05 00 00 00 05 74 65 73 74 .....test
6)[06]COM_DROP_DB
删除一个架构
有效负载:
1 [06] COM_DROP_DB
string schema name
返回:OK_Packet或者ERR_Packet
例子:
05 00 00 00 06 74 65 73 74 .....test
7)[07]COM_REFRESH
注意:从MySQL5.7.11开始,已删除COM_REFRESH。使用mysql_query()来执行刷新语句。
8)[08]COM_SHUTDOWN
注意:同(7)。
9)[09]COM_STATISTICS
获取人类可读的内部统计信息。
COM_STATISTICS:获取活动线程列表
去做:检查说明
返回:string.EOF
有效负载:
1 [09]COM_STATISTICS
10) [0a] COM_PROCESS_INFO
注意:同(7)。
11)[0b]COM_CONNECT
服务器中的内部命令
有效负载:
1 [0b]COM_CONNECT
返回:ERR_Packet
12)[0c]COM_PROCESS_KILL
注意:同(7)。
13)[0d]COM_DEBUG
COM_DEBUG触发内部调试信息转储到mysql-server的stdout。
此操作需要SUPER权限。
COM_DEBUG:
转存debug信息到stdout上。
返回:EOF_Packet或者ERR_Packet
有效负载:
1 [0d]COM_DEBUG
14) [0e]COM_PING
检查服务器是否还活着
返回:OK_Packet
有效负载:
1 [0e]COM_PING
15) [0f]COM_TIME
服务器的内部命令
有效负载:
1 [0f]COM_TIME
返回:ERR_Packet
16) [10] COM_DELAYED_INSERT
服务器的内部命令
有效负载:
1 [10]COM_DELAYED_INSERT
返回:ERR_Packet
17)[11]COM_CHANGE_USER
更改现连接的用户并且重置连接状态。
用户变量
临时表
预处理语句
还有其他
接下来是与初步握手相同的状态。
COM_CHANGE_USER:更改现连接的用户。
返回:
Authentication Method Switch Request Packet
or ERR_Packet
有效负载:
1 [11]COM_CHANGE_USER
string[NULL] user
if capabilities &SECURE_CONNECTION{
1 auth-response-len
string[$len] auth-response
}else{
string[NULL] auth-response
}
string[NULL] schema-name
if more data{
2 character -set
if capabilities & CLIENT_PLUGIN_AUTH
{
string[NULL] auth plugin name
}
if capabilities & CLIENT_CONNECT_ATTRS
{
lenenc-int length of all key-values
lenenc-str key
lenenc-str value
if -more data in 'length of all key-values', more keys and values pairs
}
}
Fields
command (1) -- command byte
username (string.NUL) -- user name
auth_plugin_data_len (1) -- length of the auth_plugin_data filed
auth_plugin_data (string.var_len) -- auth data
schema (string.NUL) -- default schema
character_set (2) -- new connection character set (see
Protocol::CharacterSet
)auth_plugin_name (string.NUL) -- name of the auth plugin that auth_plugin_data corresponds to
connect_attrs_len (lenenc_int) -- length in bytes of the following block of key-value pairs
18) [1f] OM_RESET_CONNECTION
重置会话状态,比COM_CHANGE_USER轻量级,因为不关闭和重新开启连接,不需要重新认证。
有效负载:
1 [1f] COM_RESET_CONNECTION
返回:
ERR_Packet或者OK_Packet
19) [1d] COM_DAEMON
服务器的内部命令
有效负载:
1 [1d] COM_DAEMON
返回:ERR_Packet
MySQL之Text Protocol的更多相关文章
- Hadoop Pipes Exception: Illegal text protocol command
Hadoop Pipes Exception: Illegal text protocol command 对于Hadoop pipes 出现这样的错误,基本上编译代码依赖的.so和.a 版本不匹配 ...
- Mysql 中 text类型和 blog类型的异同
MySQL存在text和blob: (1)相同 在TEXT或BLOB列的存储或检索过程中,不存在大小写转换,当未运行在严格模式时,如果你为BLOB或TEXT列分配一个超过该列类型的最大长度的值值,值被 ...
- mysql的text类型长度问题
在我的概念中,mysql中的text字段应该是没有长度限制的,但是今天事实告诉我,text类型的长度是有限制的.其中mysql的text类型有64K长度限制的,MEDIUMTEXT中型是2G,LONG ...
- mysql中text数据类型
有个小问题记录下: 需要从第三方api接口获取数据,返回的数据的长度不定,设计表的时候设计成了varchar(256):结果存数据的时候提示表字段长度不够. 一直从300改到500,600,700都一 ...
- MySQL中TEXT与BLOB字段类型的区别
这篇文章主要介绍了MySQL中TEXT与BLOB字段类型的区别,本文总结了6大区别,需要的朋友可以参考下 在MySQL中有两个字段类型容易让人感觉混淆,那就是TEXT与BLOB,特别是自己写博客程 ...
- Mysql的Text和Blob的比较
MySQL存在text和blob: (1)相同 在TEXT或BLOB列的存储或检索过程中,不存在大小写转换,当未运行在严格模式时,如果你为BLOB或TEXT列分配一个超过该列类型的最大长度的值,值被截 ...
- MySQL多Text字段报8126错误(解决过程)
一.背景 我们的MySQL数据库有一张10个Text的字段的表,还包括几个char和varchar字段,由于业务需求,我在表中加多一个Text字段的时候,插入记录的出现了下面的错误: Row size ...
- 一次故障解决过程梳理:mysql varchar text timestamp
CHAR 类型的一个变体是 VARCHAR 类型,char(M),M是指字节长度,和varchar(M)一样 故障原因:mysql主键设置为int(9),但数据量已经大于int(9)的范围了 tips ...
- mysql的text字段长度?mysql数据库中text字段长度不够的问题
类型是可变长度的字符串,最多65535个字符: 可以把字段类型改成MEDIUMTEXT(最多存放16777215个字符)或者LONGTEXT(最多存放4294967295个字符). MySQL ...
随机推荐
- using 关键字有两个主要用途
转自:https://www.jianshu.com/p/5357dc4efcf8 using 关键字有两个主要用途: (一).作为指令,用于为命名空间创建别名或导入其他命名空间中定义的类型. (二) ...
- 【Leetcode_easy】674. Longest Continuous Increasing Subsequence
problem 674. Longest Continuous Increasing Subsequence solution class Solution { public: int findLen ...
- 基于Docker+Jenkins实现自动化部署
使用码云搭建Git代码存储仓库 https://gitee.com/login 使用码云创建私有私有git仓库 将本地springboot项目上传到git仓库中 基于Docker安装Jenkins环境 ...
- c#窗体程序绘制简单心形
分析思路: 两个圆形和一个矩形如图叠加再逆时针旋转45°,就能得到一个极其简陋的心. 我们只需要将圆心放在矩形上边中点和右边中点即可. 代码如下: private void button1_Cli ...
- Asp.Net文件的上传和下载
aspx页面: <%@ Page Language="C#" AutoEventWireup="true" CodeFile="上传和下载文件. ...
- [转帖]Oracle报错ORA-26563--当重命名表时碰到物化视图
Oracle报错ORA-26563--当重命名表时碰到物化视图 https://www.toutiao.com/i6739137279115133447/ 原创 波波说运维 2019-09-26 00 ...
- java项目报错 :A class file was not written. The project may be inconsistent...
问题: 打开ecplise,发现我的几个项目报错,上午还用的好好的,整我一脸懵,出现那么多错误还都是一种问题,错误提示翻译过来是:(类文件找不到) : 问题经过具体描述: 不只是在我的springMV ...
- AlgorithmMap Dev Log
Log 2019.08.29 ------------------------------------------------------------------------------------- ...
- 病毒 | wordpress网站内容被篡改、自动跳转、变全英文的解决办法
去年10月开始,网站经常有文章被莫名其妙的篡改,而且后面还经常出现跳转到色情网站的问题,让人烦不胜烦,困扰了好几个月,最后终于解决了.这里特次记录和总结下此次恼人的事件. 时间:2018年10月 问题 ...
- python学习-39 生成器总结
总结 1.语法上和函数类似:生成器函数和常规函数几乎是一样的.它们都是使用def语句进行定义,差别在于,生成器使用yield语句返回一个值,常规函数使用return语句返回一个值. 2.自动实现迭代器 ...