mysqltest语法整理
1. mysqltest是mysql自带的测试引擎, 它实现了一种小语言,用来描述测试过程,并将测试结果与预期对比。
小语言按照语法大致分为三类:mysql command,sql,comment。sql和comment很容易理解,前者是mysql支持的sql,
后者是注释,一般用来描述测试过程. mysqltest解释的是以test为后缀名的文本文件
mysqltest case的语法比较简单,分三类:
1. command
command用来控制运行时的行为,后面重点介绍。
一般有两种写法:
command; # 这是后面带;的
--command # 前面带--,不需要;
另外,while和if要稍微特殊些。
2. sql
就是普通的sql语句,CASE里面大部分都是sql,以分号结束。
3. comment
就是注释,用#开头
mysqltest提供了几十个command,下面只介绍我们常用的。
1. --error
有些CASE就是要验证sql失败的情况,在sql语句前面加上—error 错误码就可以了。--error后面可以跟两种值,一种是error no,另外一种是sqlstate,如果是后者需要加上S做前缀。
比如:
--error 65535
create table t1(pk createtime primary key, a int);
或
--error SHY000
select a from t1 union select * from t2;
2. disable_abort_on_error / enable_abort_on_error
默认情况下(enable)sql执行失败后mysqltest就退出了,后面的内容就不会执行,也不会生成reject文件,显示执行disable命令可以在sql失败后继续执行后面的内容,并生成reject文件。
3. disable_query_log / enable_query_log
默认情况下(enable)所有的sql语句都会在result文件中记录,在一些情况下(比如使用了循环可能query特别多)不想打开显示调用disable既可。
其他形如enable_XX/disable_XX的命令还有很多,用法都类似。
4. enable_parsing/disable_parsing
用来注释多行,跟comment类似。
5. connect/disconnect与conncetion
测试session的时候可能会用到这两个命令,前者是建立或断开一个连接。后者是表示使用哪个连接执行sql语句,可以在多个connection之间切换
比如:
connect (conn3,127.0.0.1,root,,test,25042);
connection conn3;
create table t1(a int primary key);
drop table t1;
disconnect conn3;
6. system/exec
执行shell命令
7. perl [terminator]
嵌入perl code,直到terminator位置,比如:
perl END_OF_FILE;
print "This is another test\n";
END_OF_FILE
8. vertical_results/horizontal_results
功能跟sql语句的’\G’类似
9. exit
退出,其后的内容不会执行
10. let $var_name = value
变量赋值,整数、字符串都可以
11. inc $var_name/dec $var_name
整数加1/减1,是mysqltest唯一支持的运算。
12. eval
执行sql语句,支持变量的传递,比如:
eval insert into t1(i,c1,c256,dt,d) values(0,'1','$i','2012-10-10 12:00:00','2012-10-10');
13. query
mysqltest解释每一行的时候会先判断是sql语句还是command,如果是query指定的,都认为是sql语句,这是避免comand名字与sql有冲突,一般也不会。
14. send/reap/eval_send
发送query后不用等待结果立即返回,在reap之前不能使用同一个connection发送sql语句。
eval_send支持变量传递。
15. echo
打印
16. query_get_value(query, col_name, row_num)
获得query返回的结果中某行某列的值
17. source
多个case可能共用一块代码,这块代码可以单独放到一个文件,通过source导入。
18. require
将下一个query的结果与require指定的结果文件做对比,如果匹配失败就报“this test is not supported”的错误。这个一般用于判断test是否可以在某版本中使用。
19. result
显式指定保存运行结果的文件路径
20. sleep/real_sleep
休眠.
21. replace_column
对查询结果的某些列的值进行替换,有些结果是随着执行时间变化的,比如createtime或modifytime类型,为了比较可以用这个命令将这个值替换成某常量。比如:
--replace_column 2 searched
select pk,b from t1;
22. if(exptr)
{
}
当Exptr非0,就执行大括号部分。注意,mysqltest没有提供else if或else。低版本的mysqltest不支持exptr为比较表达式。
比如:
if($value_now == $value_orig)
{
--echo succeed
}
23. while(exptr)
{
}
执行大括号部分,知道exptr为0. 低版本的mysqltest不支持exptr为比较表达式。没有break类似的命令,可以使用end试试。
比如:
while($i < 10000)
{
eval insert into t1(i,c1,c256,dt,d) values(0,'1','$i','2012-10-10 12:00:00','2012-10-10');
inc $i;
}
其他的命令还有:
1. ping,shutdown,save_master_pos,sync_slave_with_master , sync_with_master 等等,类似于mysqladmin/mysql(我们暂不支持)的功能。
2. start_timer等计时命令
3. append_file, mv, remove_file,chmod,write_file等文件操作的命令
详细请参考:http://dev.mysql.com/doc/mysqltest/2.0/en/mysqltest-commands.html
语法代码实列如下:
--echo # 修改session的值,使用脚本来测别名的更改.
connect (conn1,$OBMYSQL_MS0,root@sys,,ob,$OBMYSQL_PORT);
connect (conn2,$OBMYSQL_MS0,admin@oracle,admin,test,$OBMYSQL_PORT);
let $current_num=1;
let $number=575;
while ($current_num <= $number)
{
connection conn1;
let $tz_name = query_get_value(select name from oceanbase.__all_time_zone_name order by name, name, $current_num);
connection conn2;
eval alter session set time_zone='$tz_name';
eval select sessiontimezone from dual;
inc $current_num;
}
mysqltest语法整理的更多相关文章
- Markdown 语法整理
Markdown 语法整理 白宁超 2015年7月24日14:57:49 一.字体设置 A First Level Header == A Second Level Header -- # 标题 ## ...
- JQuery插件之【jqGrid】常用语法整理
jqGrid常用语法整理,包含数据获取.常用函数.触发事件等 jqGrid表格数据获取相关语法 获取表格所有数据 $("#grid").jqGrid("getRowDat ...
- Markdown语法整理
标题 语法格式:'#'+'空格'+'文本',一共6级 # 一级标题 ## 二级标题 ### 三级标题 #### 四级标题 ##### 五级标题 ###### 六级标题 斜体 语法格式:1个星号包裹,我 ...
- SQL中部分语法整理
1.SELECT DISTINCT 语句 关键词DISTINCT用于返回唯一不同的值. 语法: SELECT DISTINCT 列名称 FROM 表名称 2.SELECT INTO语句 SELECT ...
- SQL语法整理
SQL是Structured Query Language的缩写,中文全名为结构化查询语言,是一种用于数据存储,查询,更新和管理的关系数据库系统. SQL语法 创建表 create table tab ...
- SQL_Server 常用语句以及语法整理
下列语句部分是Mssql语句,不可以在access中使用. SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT,DELETE, ...
- JSP基础知识➣语法整理(二)
A.脚本程序 脚本程序可以包含任意量的Java语句.变量.方法或表达式,只要它们在脚本语言中是有效的. 脚本程序的语法格式:<% 代码片段 %>,但是不能包含文件的方法和变量的声明 B.J ...
- Markdown 语法整理大集合2017
简明教程:https://ouweiya.gitbooks.io/markdown/ 1.标题 代码 注:# 后面保持空格 # h1 ## h2 ### h3 #### h4 ##### h5 ### ...
- ABAP OO 开发语法整理
[转自 http://blog.csdn.net/saphome/article/details/6956933] 在类中,只能用TYPE 附加关键字指定数据类型. •TYPES: 一般的类型定义方法 ...
随机推荐
- Python 生成器 (generator) & 迭代器 (iterator)
python 生成器 & 迭代器 生成器 (generator) 列表生成式 列表生成式用来生成一个列表,虽然写的是表达式,但是储存的是计算出来的结果,因此生成的列表受到内存大小的限制 示例: ...
- 图书分享 -《Natural Language Processing with Python》
-<Natural Language Processing with Python> 链接:https://pan.baidu.com/s/1_oalRiUEw6bXbm2dy5q_0Q ...
- WinCC的画面使用技巧
以下内容以VB脚本为主,仅在VB脚本无法实现的功能中使用C脚本. 画面导航 画面导航的作用是打开起始画面.前一张画面和后一张画面等,只能用C脚本实现. 打开起始画面: OpenHomePictu ...
- Sql Server 判断表是否存在方法总结
#使用场景: 1.在创建表之前,需要先判断该表是否已经存在: 2.在删除表之前,需要先判断该表是否已经存在: #方法总结: 1.判断实体表是否存在的方法: 1).方法一: * from sysObje ...
- Loj #6503. 「雅礼集训 2018 Day4」Magic
Loj #6503. 「雅礼集训 2018 Day4」Magic 题目描述 前进!前进!不择手段地前进!--托马斯 · 维德 魔法纪元元年. 1453 年 5 月 3 日 16 时,高维碎片接触地球. ...
- Python中字符的编码与解码
1 文本和字节序列 我们都知道字符串,就是由一些字符组成的序列构成串,那么字符又是什么呢?计算机只能识别二进制的东西,那么计算机又为什么会显示我们的汉字,或者是某个字母呢? 由于最早发明使用计算机是美 ...
- Z从壹开始前后端分离【 .NET Core2.2/3.0 +Vue2.0 】框架之八 || API项目整体搭建 6.3 异步泛型仓储+依赖注入初探
本文梯子 本文3.0版本文章 回顾 1.Sqlsugar 的使用 2.修改数据连接字符串 今天要完成的浅紫色部分 一.设计仓储基类接口——IBaseRepository.cs 二.将其他的仓储接口,继 ...
- go-家庭收支记账软件例子
家庭收支记账软件项目 项目需求说明 1) 模拟实现基于文本界面的<家庭记账软件> 2) 该软件能够记录家庭的收入.支出,并能够打印收支明细表 项目的界面 看代码效果 项目代码实现 实现基本 ...
- JVM内存分配策略,及垃圾回收算法
本人免费整理了Java高级资料,一共30G,需要自己领取;传送门:https://mp.weixin.qq.com/s/JzddfH-7yNudmkjT0IRL8Q 说起垃圾收集(Garbage Co ...
- Java日期时间API系列7-----Jdk8中java.time包中的新的日期时间API类的特点
1.不变性 新的日期/时间API中,所有的类都是不可变的,这对多线程环境有好处. 比如:LocalDateTime 2.关注点分离 新的API将人可读的日期时间和机器时间(unix timestamp ...