1.基础使用
学习目标:掌握python执行SQL语句操作MySQL数据库软件
打开cmd下载安装
安装成功
connection就是一个类,conn类对象。
因为位置不知道,所以使用关键字传参。
表明我们可以正常连接到MySQL
演示、执行非查询性质的SQL语句
python里面最后这个分号可以不用写,sql里面必须要写。
""" 演示python pymysql库的基础操作 """ from pymysql import Connection # 构建到MySQL数据库的链接 conn = Connection( host="localhost", # 主机名(ip) localhost表示自己电脑,ip可用127.0.0.1 port = 3306, # 端口 默认是3306 user = "root", # 账户 password = "123456" # 密码 ) # print(conn.get_server_info()) # MySQL的基础信息 # 执行非查询性质SQL cursor = conn.cursor() # 获取到游标卡尺 # 选择数据库 conn.select_db("sys") # 执行sql cursor.execute("create table test_pymysql(id int);") # 执行查询性质SQL # 关闭链接 conn.close()
执行查询性质的SQL语句
结果以双层元组(元组嵌套)的形式展示。
将表格的形式变成了一个又一个的元组。
""" 演示python pymysql库的基础操作 """ from pymysql import Connection # 构建到MySQL数据库的链接 conn = Connection( host="localhost", # 主机名(ip) localhost表示自己电脑,ip可用127.0.0.1 port = 3306, # 端口 默认是3306 user = "root", # 账户 password = "123456" # 密码 ) # print(conn.get_server_info()) # MySQL的基础信息 # 执行非查询性质SQL cursor = conn.cursor() # 获取到游标卡尺 # 选择数据库 conn.select_db("sys") # 执行sql cursor.execute("select * from s") results = cursor.fetchall() for r in results: print(r) # 执行查询性质SQL # 关闭链接 conn.close()
总结
2.数据插入
学习目标:掌握python执行SQL语句插入数据到MySQL
commit提交
需要通过commit确认
自动commit
总结
3.综合案例
学习目标:使用SQL语句和pymysql库完成综合案例的开发
构建表
print输出演示一下。
完整代码演示
使用for循环,每循环一次,导入一次数据。
导入完数据后,使用f5刷新就能看到数据。
""" SQL 综合案例,读取文件,写入MySQL数据库中 """ from file_define import JsonFileReader,TexFileReader from data_define import Record from pymysql import Connection text_file_reader = TexFileReader("D:/2011年1月销售数据(1)(1).txt") json_file_reader = JsonFileReader("D:/2011年2月销售数据JSON(2).txt") jan_data: list[Record] = text_file_reader.read_data() # 一月份数据 feb_data: list[Record] = json_file_reader.read_data() # 二月份数据 # 将2个月份的数据合并为1个list来存储 all_data: list[Record] = jan_data + feb_data # 构造MySQL链接对象 conn = Connection( host="localhost", port=3306, user="root", password="123456", autocommit=True ) # 获得游标对象 cursor = conn.cursor() # 选择数据库 conn.select_db("py_sql") # 组织SQL语句 for record in all_data: sql = (f"insert into orders(order_date,order_id,money,province)" f" values('{record.date}','{record.order_id}',{record.money},'{record.province}')") cursor.execute(sql) conn.close()