使用软件:Navicat for MySQL、PyCharm Community Edition 2021.3.3
一、pycharm安装pymysql包
第一步 点击“File”——点击“Settings”
data:image/s3,"s3://crabby-images/b3d0b/b3d0ba46ea6becfb55b2f5a7f344f16cf03081d4" alt=""
第二步 点击“Python Interpreter”——点击“+”
data:image/s3,"s3://crabby-images/b0e8e/b0e8e4f7176e72741035ffb76249eef22e709870" alt=""
?第三步 搜索“pymysql”——点击“Install Package”?,下载成功即可
data:image/s3,"s3://crabby-images/668e7/668e7c519ba20660f59ede36b3ac2c8768775963" alt=""
?二、使用Python的三方库PyMySQL来访问MySQL数据库
1、准备数据库
drop database if exists sxs;
create database sxs default charset utf8;
use sxs;
drop table if exists s_student;
create table s_student
(
dnum int not null comment '学号',
dname varchar(10) not null comment '姓名',
dclass varchar(20) not null comment '班级',
primary key (dnum)
);
insert into s_student values
(100, 'candy', '1班'),
(101, 'jeny', '3班'),
(102, 'marry', '2班'),
(103, 'jane', '2班');
data:image/s3,"s3://crabby-images/3926c/3926c2230d523f4b0102bca3d8ef5ca6fee12178" alt=""
2、使用pymysql增加数据
import pymysql
def main():
num = int(input('学号: '))
name = input('名字: ')
class1 = input('班级: ')
# 1. 创建数据库连接对象
con = pymysql.connect(host='localhost', port=3306,
database='sxs', charset='utf8',
user='root', password='root111')
try:
# 2. 通过连接对象获取游标
with con.cursor() as cursor:
# 3. 通过游标执行SQL并获得执行结果
result = cursor.execute(
'insert into s_student values (%s, %s, %s)',
(num, name, class1)
)
if result == 1:
print('添加成功!')
# 4. 操作成功提交事务
con.commit()
finally:
# 5. 关闭连接释放资源
con.close()
if __name__ == '__main__':
main()
结果展示:
data:image/s3,"s3://crabby-images/31cf5/31cf5bf45a2cebb19f2b5ffca24bd1242ac14f44" alt=""
data:image/s3,"s3://crabby-images/a371a/a371a4132586dc43c4aecb9542e017015be68506" alt=""
3、使用pymysql删除数据
import pymysql
def main():
num = int(input('学号: '))
con = pymysql.connect(host='localhost', port=3306,
database='sxs', charset='utf8',
user='root', password='root111',
autocommit=True)
try:
with con.cursor() as cursor:
result = cursor.execute(
'delete from s_student where dnum=%s',
(num, )
)
if result == 1:
print('删除成功!')
finally:
con.close()
if __name__ == '__main__':
main()
?结果展示
data:image/s3,"s3://crabby-images/755b5/755b59f549ec3baac7dbbef2ef2849179d2864b6" alt=""
data:image/s3,"s3://crabby-images/4e5a1/4e5a1fc548fcb397aeef40088b5f4a0294f9b4b4" alt=""
4、使用pymysql查询数据
import pymysql
from pymysql.cursors import DictCursor
def main():
con = pymysql.connect(host='localhost', port=3306,
database='sxs', charset='utf8',
user='root', password='root111')
try:
with con.cursor(cursor=DictCursor) as cursor:
cursor.execute('select dnum as num, dname as name, dclass as class1 from s_student')
results = cursor.fetchall()
print(results)
print('学号\t姓名\t\t班级')
for dept in results:
print(dept['num'], end='\t')
print(dept['name'], end='\t')
print(dept['class1'])
finally:
con.close()
if __name__ == '__main__':
main()
?结果展示:
data:image/s3,"s3://crabby-images/977ae/977ae46108e5a9e8ac8e8ff38aaa5b683c50057a" alt=""
5、使用pymysql修改数据
import pymysql
def main():
num = int(input('学号: '))
name = input('名字: ')
class1 = input('班级: ')
con = pymysql.connect(host='localhost', port=3306,
database='sxs', charset='utf8',
user='root', password='root111',
autocommit=True)
try:
with con.cursor() as cursor:
result = cursor.execute(
'update s_student set dname=%s, dclass=%s where dnum=%s',
(name, class1, num)
)
if result == 1:
print('更新成功!')
finally:
con.close()
if __name__ == '__main__':
main()
?结果展示:
data:image/s3,"s3://crabby-images/45390/453901f8debcbbda5e461632ea94a022d7249573" alt=""
?data:image/s3,"s3://crabby-images/84ae2/84ae2fc5f6fa1310e63222b8b88527a92d9bb7ea" alt=""
|