如何批量生成MySQL不重复手机号大表实例代码
前言
在MySQL很多测试场景,需要人工生成一些测试数据来测试。本文提供一个构造MySQL大表存储过程,可以生成包含用户名,手机号码,出生日期等字段。也可以通过滤重来使得手机号码不重复,模拟现实场景。
一、生成脚本
生成说明:
以下使用存储过程批量生成包含用户名,手机号,出生日期等字段大表。
该存储过程使用基于uid作为主键,因此会生成少量重复手机号码,后面有滤重SQL脚本。
如果想一次性生成不重复手机号码,可以考虑修改以下脚本,去掉uid,基于mobile列作为主键
DROPTABLEIFEXISTSbig_table; DROPPROCEDUREIFEXISTSprc_gen_user; CREATETABLE`big_table`( `uid`int(11)NOTNULLAUTO_INCREMENT, `mobile`char(11)DEFAULTNULL, `passwd`varchar(50)DEFAULTNULL, `name`varchar(50)DEFAULTNULL, `sex`tinyintDEFAULTNULL, `birthday`datetimeDEFAULTNULL, `updated_time`datetimeDEFAULTNULL, PRIMARYKEY(`uid`) )ENGINE=InnoDBDEFAULTCHARSET=utf8; CREATEPROCEDUREprc_gen_user(l_cntint) BEGIN DECLARExINTDEFAULT0; DECLAREpchar(11); WHILEx二、数据填充
callprc_gen_user(1000); QueryOK,1rowaffected(1.38sec) selectcount(*)frombig_table; +----------+ |count(*)| +----------+ |1000| +----------+ 1rowinset(0.00sec) select'Leshami'author,'http://blog.csdn.net/leshami'Blog; +---------+------------------------------+ |author|Blog| +---------+------------------------------+ |Leshami|http://blog.csdn.net/leshami| +---------+------------------------------+三、滤重SQL语句
DELETEFROMbig_table WHEREmobileIN(SELECTmobile FROM(SELECTu1.mobile FROMbig_tableu1 GROUPBYu1.mobile HAVINGcount(*)>1)a) ANDuidNOTIN(SELECTuid FROM(SELECTmin(u2.uid)ASuid FROMbig_tableu2 GROUPBYu2.mobile HAVINGcount(*)>1)b);四、其它
本文参考了以下代码,下面代码实现是MySQL批量造用户数据,姓名/手机号/生日/密码
DROPPROCEDUREIFEXISTSbatchGenerateUsers; DELIMITER$$ CREATEPROCEDUREbatchGenerateUsers() BEGIN DECLARExINTDefault0; DECLAREpchar(11); WHILEx<10000DO SETx=x+1; SETp=concat('1',cast(3+(rand()*10)%7aschar(1)),right(left(trim(cast(rand()aschar(20))),11),9)); insertintomy_users(mobile,passwd,name,sex,birthday,updated_time) values(p, md5(ceiling(rand()*1000000)), concat(substring('赵钱孙李周吴郑王冯陈诸卫蒋沈韩杨朱秦尤许何吕施张孔曹严华金魏陶姜戚谢邹喻柏水窦章云苏潘葛奚范彭郎鲁韦昌马苗凤花方俞任袁柳酆鲍史唐费廉岑薛雷贺倪汤滕殷罗毕郝邬安常乐于时傅皮齐康伍余元卜顾孟平黄和穆萧尹姚邵堪汪祁毛禹狄米贝明臧计伏成戴谈宋茅庞熊纪舒屈项祝董粱杜阮蓝闵席季麻强贾路娄危江童颜郭梅盛林刁钟徐邱骆高夏蔡田樊胡凌霍虞万支柯咎管卢莫经房裘干解应宗丁宣贲邓郁单杭洪包诸左石崔吉钮龚',floor(1+190*rand()),1),substring('明国华建文平志伟东海强晓生光林小民永杰军金健一忠洪江福祥中正振勇耀春大宁亮宇兴宝少剑云学仁涛瑞飞鹏安亚泽世汉达卫利胜敏群波成荣新峰刚家龙德庆斌辉良玉俊立浩天宏子松克清长嘉红山贤阳乐锋智青跃元武广思雄锦威启昌铭维义宗英凯鸿森超坚旭政传康继翔栋仲权奇礼楠炜友年震鑫雷兵万星骏伦绍麟雨行才希彦兆贵源有景升惠臣慧开章润高佳虎根远力进泉茂毅富博霖顺信凡豪树和恩向道川彬柏磊敬书鸣芳培全炳基冠晖京欣廷哲保秋君劲轩帆若连勋祖锡吉崇钧田石奕发洲彪钢运伯满庭申湘皓承梓雪孟其潮冰怀鲁裕翰征谦航士尧标洁城寿枫革纯风化逸腾岳银鹤琳显焕来心凤睿勤延凌昊西羽百捷定琦圣佩麒虹如靖日咏会久昕黎桂玮燕可越彤雁孝宪萌颖艺夏桐月瑜沛诚夫声冬奎扬双坤镇楚水铁喜之迪泰方同滨邦先聪朝善非恒晋汝丹为晨乃秀岩辰洋然厚灿卓杨钰兰怡灵淇美琪亦晶舒菁真涵爽雅爱依静棋宜男蔚芝菲露娜珊雯淑曼萍珠诗璇琴素梅玲蕾艳紫珍丽仪梦倩伊茜妍碧芬儿岚婷菊妮媛莲娟一',floor(1+400*rand()),1),substring('明国华建文平志伟东海强晓生光林小民永杰军金健一忠洪江福祥中正振勇耀春大宁亮宇兴宝少剑云学仁涛瑞飞鹏安亚泽世汉达卫利胜敏群波成荣新峰刚家龙德庆斌辉良玉俊立浩天宏子松克清长嘉红山贤阳乐锋智青跃元武广思雄锦威启昌铭维义宗英凯鸿森超坚旭政传康继翔栋仲权奇礼楠炜友年震鑫雷兵万星骏伦绍麟雨行才希彦兆贵源有景升惠臣慧开章润高佳虎根远力进泉茂毅富博霖顺信凡豪树和恩向道川彬柏磊敬书鸣芳培全炳基冠晖京欣廷哲保秋君劲轩帆若连勋祖锡吉崇钧田石奕发洲彪钢运伯满庭申湘皓承梓雪孟其潮冰怀鲁裕翰征谦航士尧标洁城寿枫革纯风化逸腾岳银鹤琳显焕来心凤睿勤延凌昊西羽百捷定琦圣佩麒虹如靖日咏会久昕黎桂玮燕可越彤雁孝宪萌颖艺夏桐月瑜沛诚夫声冬奎扬双坤镇楚水铁喜之迪泰方同滨邦先聪朝善非恒晋汝丹为晨乃秀岩辰洋然厚灿卓杨钰兰怡灵淇美琪亦晶舒菁真涵爽雅爱依静棋宜男蔚芝菲露娜珊雯淑曼萍珠诗璇琴素梅玲蕾艳紫珍丽仪梦倩伊茜妍碧芬儿岚婷菊妮媛莲娟一',floor(1+400*rand()),1)), ceiling(rand()*10)%2, date(now()-interval(20+ceiling(rand()*100)%40)year), concat('2015-',1+ceiling(rand()*100)%12,'-',1+ceiling(rand()*100)%28)) ONDUPLICATEKEYUPDATE updated_time=now(); ENDWHILE; END$$ #callbatchGenerateUsers();并对其进行适当修改。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持。