1、当我们测试的时候需要大量的数据的时候,往往需要我们自己造数据,一条一条的加是不现实的,这时候就需要使用脚本来批量生成数据了。

import pymysql
import random
import string # 建立数据库连接
mysql = pymysql.connect(host="数据库IP", user="数据库用户名",port=3306,password="数据库密码", charset='utf8', autocommit=True)
# 建立游标
cursor = mysql.cursor(pymysql.cursors.DictCursor) # 定义要执行的SQL语句
for i in range(1,200001): # for循环来组合新增语句
jbxx_unid =8183 + i # ID从目前数据库中最大的一个开始
# UUID是32位字母加数字组成,所以先生成随机26位字母加数字随机数,然后加上序号保证UUID的唯一性
ran_str = ''.join(random.sample(string.ascii_letters + string.digits, 26))
i_len = len(str(i))
if i_len == 1:
jbxx_uuid = ran_str.lower() +"00000" + str(i)
elif i_len == 2:
jbxx_uuid = ran_str.lower() + "0000" + str(i)
elif i_len == 3:
jbxx_uuid = ran_str.lower() + "000" + str(i)
elif i_len == 4:
jbxx_uuid = ran_str.lower() + "00" + str(i)
elif i_len == 5:
jbxx_uuid = ran_str.lower() + "0" + str(i)
else:
jbxx_uuid = ran_str.lower() + str(i)
# 需要插入数据的数据要唯一性的都加循环数字
jbxx_psid = 9998942509 + i
jbxx_name = "test" + str(i)
# 新增的SQL语句,用format来替换我们的参数。
sql = """
INSERT INTO `myslave`.`t_ps_jbxx` (
`jbxx_unid`,
`jbxx_uuid`,
`jbxx_cdate`,
`jbxx_udate`,
`jbxx_psid`,
`jbxx_name`,
`jbxx_sex`,
`jbxx_mz`,
`jbxx_zbm`,
`jbxx_zbmczqk`,
`jbxx_gj`,
`jbxx_sjf`,
`jbxx_swf`,
`jbxx_whcd`,
`jbxx_tctsjn`,
`jbxx_birthday`,
`jbxx_sfzhm`,
`jbxx_age`,
`jbxx_zjxy`,
`jbxx_xycd`,
`jbxx_bqmm`,
`jbxx_bqzy`,
`jbxx_rjqzw`,
`jbxx_zffl`,
`jbxx_cyjb`,
`jbxx_sisheqk`,
`jbxx_sishiqk`,
`jbxx_gldj`,
`jbxx_hkfl`,
`jbxx_jjs`,
`jbxx_yyymjjsqk`,
`jbxx_ypxqq`,
`jbxx_ypxqz`,
`jbxx_xxqq`,
`jbxx_xxqz`,
`jbxx_ypxq`,
`jbxx_xxq`,
`jbxx_yx`,
`jbxx_dbjg`,
`jbxx_dbrq`,
`jbxx_spjg`,
`jbxx_pjrq`,
`jbxx_rjsj`,
`jbxx_rdsj`,
`jbxx_gydw`,
`jbxx_drdw`,
`jbxx_dbddqk`,
`jbxx_grjl`,
`jbxx_zybz`,
`jbxx_curs`,
`jbxx_arcode`,
`jbxx_isFull`,
`jbxx_abbr`,
`jbxx_lgf`,
`jbxx_sfzk`,
`jbxx_sfxxy`,
`jbxx_sfem`,
`jbxx_password`,
`jbxx_hy`,
`jbxx_zm`,
`jbxx_xxytype`,
`jbxx_epassword`
)
VALUES
(
'{0}',
'{1}',
'2018-03-23 16:25:37',
'2020-01-07 15:31:51',
'{2}',
'{3}',
'1',
'15',
NULL,
NULL,
'520600',
NULL,
NULL,
'80',
NULL,
'1974-07-08 00:00:00',
NULL,
'45',
'00',
NULL,
'13',
'90000',
'000',
'1',
NULL,
'',
NULL,
NULL,
NULL,
NULL,
NULL,
'2006-12-05 00:00:00',
'2022-09-04 00:00:00',
'2006-12-05 00:00:00',
'2022-09-04 00:00:00',
'150900',
'150900',
NULL,
NULL,
NULL,
NULL,
NULL,
NULL,
NULL,
'3319',
NULL,
NULL,
NULL,
'1',
'0c3be3ee22ab48158433bf0a054edad8',
'3319110000',
'0',
'HPJ',
NULL,
NULL,
'0',
'0',
'123456789',
'20',
'盗窃、抢劫',
'SWFXXY',
''
);
""".format(jbxx_unid,jbxx_uuid,jbxx_psid,jbxx_name)
# 执行SQL语句
cursor.execute(sql)
print("成功插入{}条数据!".format(i)) # 关闭光标对象
cursor.close()
# 关闭数据库连接
print("插入完成所有数据!关闭数据库连接!")
mysql.close()

使用Python对MySQL数据库插入二十万条数据的更多相关文章

  1. [MyBatis]五分钟向MySql数据库插入一千万条数据 批量插入 用时5分左右

    本例代码下载:https://files.cnblogs.com/files/xiandedanteng/InsertMillionComparison20191012.rar 我的数据库环境是mys ...

  2. [MyBatis]向MySql数据库插入一千万条数据 批量插入用时6分 之前时隐时现的异常不见了

    本例代码下载:https://files.cnblogs.com/files/xiandedanteng/InsertMillionComparison20191012.rar 这次实验的环境仍然和上 ...

  3. 解决Python向MySQL数据库插入中文数据时出现乱码

    解决Python向MySQL数据库插入中文数据时出现乱码 先在MySQL命令行中输入如下语句查看结果: 只要character_set_client character_set_database ch ...

  4. Python向mysql数据库插入数据

    一.向表tcolor中插入数据的主要流程如下: import datetimeimport pymysql.cursorsconnection = pymysql.connect(host='loca ...

  5. 用Python向MySQL数据库插入数据

    最近一直在学习MySQL数据库,很感兴趣.这次我做了一个简单的尝试,使用Python3.4与MySQL数据库进行交互,将一份从雪球网上下载的某股票数据上传至MySQL数据库.仅为初学者提供参考,高手请 ...

  6. mysql 数据库查询最后两条数据

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/u011925175/article/details/24186917  有一个mysql数据库的 ...

  7. Python操作MySQL数据库(二)

    pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同. 下载安装: pip install pymysql 1.执行SQL语句 #!/usr/bin/env pytho ...

  8. 【java】[sql]使用Java程序向MySql数据库插入一千万条记录,各种方式的比较,最后发现insert批量插入方式对效率提升最明显

    我的数据库环境是mysql Ver 14.14 Distrib 5.6.45, for Linux (x86_64) using EditLine wrapper 这个数据库是安装在T440p的虚拟机 ...

  9. Python数据库(二)-Mysql数据库插入数据

    通过python连接mysql数据库,并插入数据 # -*- coding:utf-8 -*- __author__ = "MuT6 Sch01aR" import pymysql ...

随机推荐

  1. Core3.0中Swagger使用JWT

    前言 学习ASP.NETCore,原链接 https://www.cnblogs.com/laozhang-is-phi/p/9511869.html 原教程是Core2.2,后期也升级到了Core3 ...

  2. IDEA控制台打印程序内汉字乱码及txt文本乱码

    控制台打印汉字乱码 解决IntelliJ IDEA控制台输出中文乱码问题 txt文本乱码 解决IDEA读取txt文本中显示的中文乱码问题

  3. [译] ConstraintLayout 可视化[Design]编辑器(这到底是什么)[第四部分]

    原文地址:Testing Views in Isolation with Espresso 原文作者:Ataul Munim 译文出自:掘金翻译计划 译者:yazhi1992 校对者:lovexiao ...

  4. springclud中附件上传

    package org.springblade.desk.controller; import com.baomidou.mybatisplus.core.metadata.IPage; import ...

  5. Deep Neural Networks for YouTube Recommendations YouTube的经典推荐框架

    https://zhuanlan.zhihu.com/p/52169807 王喆大佬的讲解

  6. NVL函数:空值转换函数

    NVL(表达式1,表达式2) 如果表达式1为空值,NVL返回值为表达式2的值,否则返回表达式1的值. 该函数的目的是把一个空值(null)转换成一个实际的值.其表达式的值可以是数字型.字符型和日期型. ...

  7. centos7.5安装Oracle11gR2

    centos7.5安装Oracle11gR2 说明:由于上一台旧的笔记本电脑(CPU:i5-7200,内存:8G,硬盘:128SSD+1T机械)卸任,所以打算在家搭建一个个人服务器(主要是换不锈钢盆不 ...

  8. 性能超四倍的高性能.NET二进制序列化库

    二进制序列化在.NET中有很多使用场景,如我们使用分布式缓存时,通常将缓存对象序列化为二进制数据进行缓存,在ASP.NET中,很多中间件(如认证等)也都是用了二进制序列化. 在.NET中我们通常使用S ...

  9. Salesforce 大数据量处理篇(二)Index

    本篇参考: https://developer.salesforce.com/docs/atlas.en-us.202.0.salesforce_large_data_volumes_bp.meta/ ...

  10. 醒醒!Python已经支持中文变量名啦!

    最近,我在翻阅两本比较新的 Python 书籍时,发现它们都犯了一个严重的低级错误! 这两本书分别是<Python编程:从入门到实践>和<父与子的编程之旅>,它们都是畅销书,都 ...