MySQL适配器PyMySQL详解

作者:Blue·Sky 时间:2024-01-16 23:49:11 

本文我们为大家介绍 Python3 使用 PyMySQL 连接数据库,并实现简单的增删改查。

什么是 PyMySQL?

PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb。

PyMySQL 遵循 Python 数据库 API v2.0 规范,并包含了 pure-Python MySQL 客户端库。

PyMySQL 安装
在使用 PyMySQL 之前,我们需要确保 PyMySQL 已安装。

PyMySQL 下载地址:https://github.com/PyMySQL/PyMySQL。

如果还未安装,我们可以使用以下命令安装最新版的 PyMySQL:


$ pip install PyMySQL

如果你的系统不支持 pip 命令,可以使用以下方式安装:

1、使用 git 命令下载安装包安装(你也可以手动下载):


$ git clone https://github.com/PyMySQL/PyMySQL
$ cd PyMySQL/
$ python3 setup.py install

2、数据库操作实例,直接上代码。


import pymysql
import datainfo
import time

#获取参数

host = datainfo.host
username = datainfo.username
password = datainfo.password
database = datainfo.db

print()

#测试数据库连接
def testconnect():

#打开数据库链接

db = pymysql.connect(host,username,password,database)

#使用cursor() 方法创建一个游标对象 cursor

cursor = db.cursor()

#使用execute()方法执行SQL查询

cursor.execute("select version()")

#使用fetchone ()获取单条数据

data = cursor.fetchone()

print(data)

db.close()

#插入数据库
def InsertDate():
#打开数据库链接

db = pymysql.connect(host,username,password,database,charset='utf8')

#使用cursor() 方法创建一个游标对象 cursor

cursor = db.cursor()

create_time = time.strftime('%Y-%m-%d %H:%M:%S')
update_time = time.strftime('%Y-%m-%d %H:%M:%S')
start_time = time.strftime('%Y-%m-%d %H:%M:%S')
end_time = time.strftime('%Y-%m-%d %H:%M:%S')
remark = "测试插入信息"
print("开始")
#Sql 插入语句
sql = "insert into demo(start_time,end_time,creat_time,update_time,remark) " \
  "VALUES ('%s','%s','%s','%s','%s')"\
  %(start_time,end_time,create_time,update_time,remark)
try:
 #执行sql
 print("执行插入")
 tt = cursor.execute(sql)
 print(tt)
 db.commit()
except UnicodeEncodeError as e :
 #发生错误时回滚
 print(e)
 db.rollback()
db.close()

#查询操作
def selectData():
db = pymysql.connect(host, username, password, database, charset='utf8')

# 使用cursor() 方法创建一个游标对象 cursor

cursor = db.cursor()

sql = "select * from demo where id >='%d'" %(1)
try:
 #执行sql
 print("执行查询")
 cursor.execute(sql)
 results = cursor.fetchall()
 for row in results:
  id = row[0]
  start_time = row[1]
  end_time = row[2]
  create_time = row[3]
  update_time = row[4]
  remark = row[5]
  #打印结果
  print("id = %d,start_time=%s,end_time=%s,create_time=%s,update_time=%s,remark=%s" %(id,start_time,end_time,create_time,update_time,remark))

db.commit()
except UnicodeEncodeError as e :
 #发生错误时回滚
 print(e)

db.close()

#更新操作
def update_data():
db = pymysql.connect(host, username, password, database, charset='utf8')

# 使用cursor() 方法创建一个游标对象 cursor

cursor = db.cursor()
update_time = time.strftime('%Y-%m-%d %H:%M:%S')
sql = "update demo set update_time ='%s' where id >='%d' " %(update_time,1)
try:
 #执行sql
 print("执行更新")
 cursor.execute(sql)

db.commit()
except UnicodeEncodeError as e :
 #发生错误时回滚
 print(e)
 db.rollback()
db.close()

#删除操作
def delete_Date():
db = pymysql.connect(host, username, password, database, charset='utf8')

# 使用cursor() 方法创建一个游标对象 cursor

cursor = db.cursor()

sql = "delete from demo where id <'%d' " %(1)
try:
 #执行sql
 print("执行删除")
 cursor.execute(sql)

db.commit()
except UnicodeEncodeError as e :
 #发生错误时回滚
 print(e)
 db.rollback()
db.close()

if __name__ == '__main__':
testconnect()
InsertDate()
selectData()
update_data()
delete_Date()

来源:http://www.cnblogs.com/BlueSkyyj/p/7559626.html

标签:MySQL,适配器,PyMySQL
0
投稿

猜你喜欢

  • python3编写ThinkPHP命令执行Getshell的方法

    2023-10-04 14:17:15
  • MySQL 逻辑备份与恢复测试的相关总结

    2024-01-19 14:19:20
  • python实现飞机大战游戏

    2021-09-30 12:05:06
  • python3 实现自定义切片类为左闭右闭详情

    2022-11-02 11:36:51
  • Python 递归式实现二叉树前序,中序,后序遍历

    2022-09-22 17:38:32
  • 用Python实现给Word文档盖章

    2021-07-08 21:18:00
  • Python算法之栈(stack)的实现

    2022-09-01 15:26:15
  • Python time.time()方法

    2022-11-27 16:55:47
  • Python实现在Linux系统下更改当前进程运行用户

    2023-03-27 02:53:33
  • python区块链创建多个交易教程

    2021-05-28 13:40:42
  • 浅析Django 接收所有文件,前端展示文件(包括视频,文件,图片)ajax请求

    2023-03-30 14:35:25
  • 无忧贴子管理器(ListView组件)

    2009-01-02 17:56:00
  • python实现的自动发送消息功能详解

    2021-12-09 20:45:18
  • Python接口自动化之文件上传/下载接口详解

    2022-01-02 17:32:28
  • 一文详解如何创建自己的Python装饰器

    2021-09-10 02:43:43
  • select * from sp_who的解决方案

    2024-01-15 09:55:52
  • 利用MySqlBulkLoader实现批量插入数据的示例详解

    2024-01-24 08:46:00
  • Python基础入门之seed()方法的使用

    2021-11-17 04:10:19
  • 详解python Todo清单实战

    2021-11-03 06:24:50
  • 解析MYSQL显示表信息的方法

    2024-01-15 12:17:49
  • asp之家 网络编程 m.aspxhome.com