码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【解决方案】数据随机生成脚本


    因需要生成数据,验证数据库相关问题,且此需求可能以后也会经常遇到,因此分享出来~

    在基础的云ECS,通过python3执行即可

    1. # encoding=utf-8
    2. import pymysql
    3. import random
    4. import time
    5. # create table student_source(id int NOT NULL PRIMARY KEY AUTO_INCREMENT,name varchar(20),subject varchar(20),score int(5))
    6. class RandomDataInsert:
    7. # 初始化类
    8. def __init__(self, ty):
    9. self.type = ty
    10. self.coon = None
    11. self.sqlList = []
    12. pass
    13. # 连接数据库
    14. def connectDB(self, ip, port, dbname, user=None, pwd=None, ):
    15. if self.type == 'mysql':
    16. self.coon = pymysql.connect(
    17. host=ip,
    18. user=user,
    19. passwd=pwd,
    20. port=port,
    21. db=dbname,
    22. charset='utf8'
    23. )
    24. return True
    25. # 关闭连接
    26. def disconnectDB(self):
    27. self.coon.close()
    28. # 添加sql语句
    29. def appendSql(self, sql):
    30. if sql is not None:
    31. self.sqlList.append(sql)
    32. # 执行SQL
    33. def executeInsertAll(self):
    34. try:
    35. cur = self.coon.cursor()
    36. for sql in self.sqlList:
    37. print("Going to execute: ", sql)
    38. cur.execute(sql)
    39. self.coon.commit()
    40. cur.close()
    41. except Exception as e:
    42. print('发生异常', e)
    43. self.coon.rollback()
    44. # 生成数据SQL小工厂
    45. def defineSql(ope, count):
    46. for i in range(count):
    47. subject = random.choice(['Chinese', 'Math', 'English'])
    48. score = random.randint(0, 100)
    49. name = ''.join(random.sample(
    50. ['z', 'y', 'x', 'w', 'v', 'u', 't', 's', 'r', 'q', 'p', 'o', 'n', 'm', 'l', 'k', 'j', 'i', 'h', 'g', 'f',
    51. 'e', 'd', 'c', 'b', 'a'], 2))
    52. sql = "insert into student values(null,'" + name + "','" + subject + "'," + str(score) + ");"
    53. ope.appendSql(sql)
    54. # 主函数
    55. if __name__ == '__main__':
    56. print('Random DB Insert begin!!')
    57. sqlList = RandomDataInsert('mysql')
    58. sqlList.connectDB('实例名称', 3306, '数据库', '账户', '密码')
    59. print(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time())))
    60. defineSql(sqlList, 20)
    61. print("defineSql,sqlList:{}", len(sqlList.sqlList))
    62. sqlList.executeInsertAll()
    63. sqlList.disconnectDB()

  • 相关阅读:
    【正点原子Linux连载】第二十六章 APP主界面开发项目 摘自【正点原子】I.MX6U嵌入式Qt开发指南V1.0.2
    volatile修饰数组
    VUE3 之 Teleport - 这个系列的教程通俗易懂,适合新手
    【C++】类和对象(上)
    二百零七、Flume——Flume实时采集5分钟频率的Kafka数据直接写入ODS层表的HDFS文件路径下
    IO流【Java对象的序列化和反序列化、File类在IO中的作用、装饰器模式构建IO流体系、Apache commons-io工具包的使用】(四)-全面详解(学习总结---从入门到深化)
    如何恢复电脑上删除的文件?
    Ubuntu18.04 lite.ai.toolkit配置、编译、测试
    c++基础(八)——类对象作为类成员
    opencv-图像变换:傅里叶变换
  • 原文地址:https://blog.csdn.net/victorzzzz/article/details/128000557
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号