码农知识堂 - 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()

  • 相关阅读:
    Spark框架概述
    IDEA工具快捷键的使用
    中国个人生活小家电市场投资前景分析及供需格局研究预测报告
    Java预习46
    RP原型资源分享-购物类App
    【VS2019 Qt5 VTK9.2】临时解决配置相关问题的简单方法
    抖音开放平台探索价值共生新生态,促进高校招生就业提质增效
    用于准确量化颅面对称性和面部生长的 3D 头影测量方案(Matlab代码实现)
    数据库(一):MySQL
    VMware虚拟机安装Centos7系统(网络模式、桌面选择、手动分区、Kdump)
  • 原文地址: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号