pymysql 库的使用

pymysql库的使用

1.安装

pip install pymysql -i https://mirrors.aliyun.com/pypi/simple

MySQL 的安装可以按照操作系统来操作。

2.初始化

初始化连接 MySQL 数据库
host:MySQL 安装地址,如果是本地就是 localhost 或者 127.0.0.1。
user:用户名默认值:root。
password:在安装的过程中输入的密码。
port:端口号,默认就是 3306。
database:输入创建的数据库

import pymysql

db = pymysql.connect(host=host, user=user, password=password, port=port, database=database)

3.创建游标

完成上述操作已经就是连接上数据库了,想要操作数据还需要建立游标

cursor = db.cursor()  # 创建游标用来执行SQL 语句

4.插入数据

插入、更新和删除操作都是对数据库进行更改的操作,而更改操作都必须是一个事务,所以标准写法需要加上异常处理:commit或是rollback

sql = "insert into students (id, user_name, age) values ('1', '张三', 20)"
try:
	cursor.execute(sql)
	db.commit()
except:
	db.rollback()
db.close()

4.1.动态插入SQL

# 创建对应表结构的字典
data = {
'id': 2,
'user_name': '李四',
'age': 30,
}
table = 'students'
keys = ', '.join(data.keys())
values = ', '.join(['%s'] * len(data))  # 此处返回的是[%s, %s, %s]
sql = f'insert into {table} ({keys}) values ({values})'
try:
    if cursor.execute(sql, tuple(data.values())):
        print('成功')
        db.commit()
except:
    print('错误')
    db.rollback()

5.更新数据

sql = 'update students set age = %s where user_name = %s'
try:
	cursor.execute(sql, (25, '张三'))
	db.commit()
except:
	db.rollback()

6.删除数据

sql = 'delete from students where id = 2;'
try:
	cursor.execute(sql)
	db.commit()
except:
	db.rollback()

7.查询数据

rowcount:可以获取,这条查询语句有多少行。
fetchone:获取第一条数据,内部有一个偏移指针,调用了 fetchone 之后指针移动到第二条了,所以最后的 fetchall 不是三个。
fetchall:一次性获取查询语句的所有结果。

sql = 'select * from students'
try:
    cursor.execute(sql)
    print('数量:', cursor.rowcount)
    result = cursor.fetchone()
    print('第一个条:', result)
    results = cursor.fetchall()
    print(type(results), results)
except:
    print('Error')

可以通过下面的方法逐条获取

cursor.execute(sql)
row = cursor.fetchone()
while row:
	print('result:', row)
	row = cursor.fetchone()

关注公众号可以领取python 学习相关资料

公众号:爬虫探索者或者pctansuo
在这里插入图片描述

完整代码

import pymysql

db = pymysql.connect(host='localhost', user='root', password='ambition', port=3306, database='spiders')

cursor = db.cursor()  # 创建游标用来执行SQL 语句

sql = "insert into students (id, user_name, age) values ('1', '张三', 20)"
try:
    cursor.execute(sql)
    db.commit()
except:
    db.rollback()

data = {
    'id': '2',
    'user_name': '李四',
    'age': 30,
}
table = 'students'
keys = ', '.join(data.keys())
values = ', '.join(['%s'] * len(data))  # 此处返回的是[%s, %s, %s]
sql = f'insert into {table} ({keys}) values ({values})'
try:
    if cursor.execute(sql, tuple(data.values())):
        print('成功')
        db.commit()
except:
    print('错误')
    db.rollback()

sql = 'update students set age = %s where user_name = %s'
try:
    cursor.execute(sql, (25, '张三'))
    db.commit()
except:
    db.rollback()

sql = 'delete from students where id = 2;'
try:
    cursor.execute(sql)
    db.commit()
except:
    db.rollback()

sql = 'select * from students'
try:
    cursor.execute(sql)
    print('数量:', cursor.rowcount)
    result = cursor.fetchone()
    print('第一个条:', result)
    results = cursor.fetchall()
    print(type(results), results)
except:
    print('Error')

cursor.execute(sql)
row = cursor.fetchone()
while row:
    print('result:', row)
    row = cursor.fetchone()
db.close()  # 关闭数据库连接
  • 15
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爬虫探索者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值