当前位置: 首页 > 图文教程 > 数据库 > MYSQL > mysql 动态生成测试数据

MYSQL
PHP中操作MySQL的一些要注意的问题
数据恢复简介
SQL SERVER 2000 安装(症状归纳)
轻松应对JSP连接MySQL数据库问题
Mysql关于数据库和表的几个最基本命令
批量更改sql server数据库所有者的对象
VFP中用SPT访问SQL Server数据库
SQL Server如何访问sybase数据库的表
SQL Server Compact Edition 程序建立步骤
C# 怎样实现远程连接SQL Server2005
SQL数据库用户只有“名称”而无“登陆名”解决
SQL Server中取汉字拼音的函数
SQL扩展存储过程安装与卸载
实现jsp页面二级下拉框联动,实时读取数据库数据
Sql server 提示挂起问题
最详细的SQL注入相关的命令整理
简介影响mysqld安全的四个选项
精讲MySQL数据库的SQL语法参考
教你怎样在MySQL中提高全文搜索效率
将你的网站从MySQL改为Postgre SQL

MYSQL 中的 mysql 动态生成测试数据


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 120 ::
收藏到网摘: n/a

mysql 动态生成测试数据的语句,方便测试数据。 一、问题
要生成两类数据:
A类:两位的 01 02 03 。。。09 10 11。。。19 20 21 。。。98 99
另一类B类:三位的 100 101 102 。。。110 111 112。。。998 999
二、解决办法
1、建表
复制代码 代码如下:

CREATE TABLE `test`.`ta` (
`a` varchar(45) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

2、创建存储过程
复制代码 代码如下:

DELIMITER $$
DROP PROCEDURE IF EXISTS `test`.`proc_tp` $$
CREATE DEFINER=`root`@`localhost` PROCEDURE `proc_tp`(in prex int,in max int)
begin
declare i INT DEFAULT 0;
declare s varchar(500);
WHILE (i<10 and prex<max) DO
select concat(prex,i) into s;
insert into ta (a) values (s);
set i=i+1;
if(i=10 and prex<max) then
set prex=prex+1;
set i=0;
end if;
END WHILE ;
end $$
DELIMITER ;

3、分别调用执行存储过程
CALL proc_tp(0,10) 创建A类数据
CALL proc_tp(10,100) 创建B类数据
4、查询结果
SELECT * FROM ta t order by cast(a as signed) asc;