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. Python的环境是如何安装的,我来教你

    01 初见Python Python编程语言是荷兰人Guido van Rossum在1990年代开发出来的. Gudio拥数学和计算机双硕士学位,但他更喜欢计算机.当时Gudio觉得现有的编程语言无 ...

  2. Jquery Ajax如何添加header参数

    转自网络 1 $.ajax({ 2 type: "POST", 3 url: "http://192.168.0.88/action.cgi?ActionID=WEB_R ...

  3. 关于Git的一些常规操作

    最近刚换了新的办公电脑,Git有重新安装了一遍,很多步骤久了不操作就忘了,又是好一顿折腾,于是这次就顺便记下来了. 不错的Git教程: https://www.liaoxuefeng.com/wiki ...

  4. 修改oracle监听占用8080端口号的问题

    前期: 先确认Oracle已经安装并正常运行 输入lsnrctl start 启动 Oracle 输入lsnrctl status 查看Oracle运行状态 可以看到第二个PORT = 8081 是我 ...

  5. [leetcode] Add to List 74. Search a 2D Matrix

    /** * Created by lvhao on 2017/8/1. * Write an efficient algorithm that searches for a value in an m ...

  6. C语言测一个浮点数的位数长度

    测浮点数的位数牵扯到一个精度的问题,用普通的测整形数值的方法不能实现,于是我自己写了一个测浮点数的函数. #include <stdio.h> //for printf int lengt ...

  7. stm32学习笔记之SysTick的思考

    原文来自--SevenZ的笔记.http://blog.21ic.com/user1/8247/archives/2011/85920.html ? 首先我们要明白什么是SysTick定时器? Sys ...

  8. 【排序】题解_P1093奖学金

    题目描述 奖学金 某小学最近得到了一笔赞助,打算拿出其中一部分为学习成绩优秀的前5名学生发奖学金.期末,每个学生都有3门课的成绩:语文.数学.英语.先按总分从高到低排序,如果两个同学总分相同,再按语文 ...

  9. PHP 获取重复数组中 第二多的元素

    $target = ["重复项目", "repeat", "repeat", "重复", "重复项目" ...

  10. 【JavaWeb】HTML&CSS 基础

    HTML&CSS 基础 HTML 基础 HTML 标签 HTML标题:HTML 标题(Heading)是通过 h1 - h6 等标签进行定义的. HTML段落: HTML 段落是通过 p 标签 ...