用python来操作MySQL,首先需要安装PyMySQL库(pip install pymysql)。

连接MySQL:

import pymysql
connect=pymysql.connect(host='localhost',user='root',password='xxxx',port=3306)

注:此时还未创建数据库,如已创建数据库,在连接时需再加上一个参数db

注:host为指定的连接服务器的地址,设置为'localhost'代表连接到本地的MySQL服务上,user为用户名,password为密码,port为指定的端口(默认为3306)。

创建游标:(我们需要用游标来执行各种操作)

cursor=connect.cursor()

关闭游标:

cursor.close()

关闭连接:

connect.close()

执行单条sql语句:

cursor.execute(...)

执行多条sql语句:

cursor.executemany(...)

提交事务:

connect.commit()

回滚事务:

connect.rollback()

在Python中对数据库进行增删改等操作使用的是事务处理,因此在执行增删改SQL语句后,需要提交事务才能在数据库中完成操作,并且还需添加错误判断,当执行SQL语句失败后,需要对事务进行回滚。增删改模板如下:

sql='...'

try:
cursor.execute(sql)
connect.commit()
except:
connect.rollback()

创建数据库:

cursor.execute("CREATE DATABASE db_test DEFAULT CHARACTER SET utf8")   #创建名为db_test的数据库

选择数据库:

connect.select_db('db_name')

创建表:

sql='CREATE TABLE IF NOT EXISTS students (id VARCHAR(255) NOT NULL,name VARCHAR(255)\
NOT NULL,age INT NOT NULL,PRIMARY KEY(id))' #创建一个名为students的数据表,分为id,name和age三列,其中id为主键
cursor.execute(sql)

插入数据:

id=''
name='Hu'
age=5 sql='INSERT INTO students(id,name,age) VALUES (%s,%s,%s)' try:
cursor.execute(sql,(id,name,age))
connect.commit()
except:
connect.rollback()

修改数据:

sql='UPDATE students SET age=%s WHERE name=%s'

try:
cursor.execute(sql,(4,'Hu'))
connect.commit()
except:
connect.rollback()

更新数据(如果数据存在,则更新数据,如果数据不存在,则插入数据):

data={'id':'',
'name':'Bo',
'age':11}
#为了方便修改数据,把数据以字典形式传入,这样就不需要修改sql语句了 table='students' keys=','.join(data.keys())
values=','.join(['%s']*len(data)) sql='INSERT INTO {table}({keys}) VALUES ({values}) ON DUPLICATE KEY UPDATE '.format(table=table,keys=keys,values=values)
#相当于INSERT INTO students(id,name,age) VALUES (%s.%s,%s) ON DUPLICATE KEY UPDATE update=','.join(["{key}=%s".format(key=key) for key in data.keys()])
#相当于id=%s,name=%s,age=%s sql=sql+update try:
cursor.execute(sql,tuple(data.values())*2)
connect.commit()
print("Sucessful")
except:
connect.rollback()
print("Failed")

删除数据:

sql='DELETE FROM xxx WHERE ...'

try:
cursor.execute(sql)
connect.commit()
except:
connect.rollback()

连接MySQL数据库+增删改操作的完整模板如下:

import pymysql

connect = pymysql.connect(host='...',   # IP地址
port=3306, # 端口号
user='...', # 用户名
password='...', # 密码
db='...', # 数据库名
charset='utf8') # 链接字符集 cursor = connect.cursor() # 创建游标 sql='...' try:
cursor.execute(sql) # 执行SQL语句
connect.commit() # 提交事务
except Exception as e:
connect.rollback() # 如果发生错误,则回滚事务
finally:
cursor.close() # 关闭游标
connect.close() # 关闭数据库

查询数据:

sql='SELECT * FROM xxx WHERE ...'
cursor.execute(sql)

获取查询结果的条数:

cursor.rowcount

获取第一条数据:(元组形式)

cursor.fetchone()

获取所有数据:

cursor.fetchall()

获取指定数量的数据:

cursor.fetchmany(num)

逐条获取数据:

results = cursor.fetchall()

for row in results:
print(row)

fetchall()会将结果以元组形式全部返回,如果数据量很大,那么占用的开销会非常高。因此,推荐使用如下方法来逐条读取数据:

row=cursor.fetchone()

while row:
print(row)
row=cursor.fetchone()

总结来说,执行什么样的操作要根据SQL语句来定。因此需要学习好SQL的语法。

参考:https://cuiqingcai.com/5578.html

https://cloud.tencent.com/developer/article/1457448

用Python操作MySQL(pymysql)的更多相关文章

  1. mysql数据库----python操作mysql ------pymysql和SQLAchemy

    本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy 一.pymysql pymsql是Python中操作MySQL的模块,其使用方法和MySQ ...

  2. day40:python操作mysql:pymysql模块&SQL注入攻击

    目录 part1:用python连接mysql 1.用python连接mysql的基本语法 2.用python 创建&删除表 3.用python操作事务处理 part2:sql注入攻击 1.s ...

  3. python成长之路【第十三篇】:Python操作MySQL之pymysql

    对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎 ...

  4. Python操作MySQL:pymysql和SQLAlchemy

    本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb ...

  5. Python(九) Python 操作 MySQL 之 pysql 与 SQLAchemy

    本文针对 Python 操作 MySQL 主要使用的两种方式讲解: 原生模块 pymsql ORM框架 SQLAchemy 本章内容: pymsql 执行 sql 增\删\改\查 语句 pymsql ...

  6. Python操作MySQL

    本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb ...

  7. Python操作Mysql之基本操作

    pymysql python操作mysql依赖pymysql这个模块 下载安装 pip3 install pymysql 操作mysql python操作mysql的时候,是通过”游标”来进行操作的. ...

  8. Python 操作 MySQL 之 pysql 与 ORM(转载)

    本文针对 Python 操作 MySQL 主要使用的两种方式讲解: 原生模块 pymsql ORM框架 SQLAchemy 本章内容: pymsql 执行 sql 增\删\改\查 语句 pymsql ...

  9. Python开发【第十九篇】:Python操作MySQL

    本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb ...

  10. Python全栈开发之MySQL(二)------navicate和python操作MySQL

    一:Navicate的安装 1.什么是navicate? Navicat是一套快速.可靠并价格相宜的数据库管理工具,专为简化数据库的管理及降低系统管理成本而设.它的设计符合数据库管理员.开发人员及中小 ...

随机推荐

  1. spring cloud各个版本之间的区别

    最近公司在使用spring cloud进行开发,对于spring cloud版本号一直有疑惑. 那个版本在前?那个版本在后? 那个版本是最新的? 一.常见版本号说明 举个瓜:2.0.3 RELEASE ...

  2. Java核心技术梳理-IO

    一.引言 IO(输入/输出),输入是指允许程序读取外部数据(包括来自磁盘.光盘等存储设备的数据).用户输入数据.输出是指允许程序记录运行状态,将程序数据输出到磁盘.光盘等存储设备中. IO的主要内容包 ...

  3. NETRemoting学习笔记

    1..NET Remoting概念 1.一种分布式处理方式.从字面意义上看出,他是基于.net平台的一种远程对象开发技术,该技术是将远程计算机中的数据视为分布式对象来进行开发. 2.一种网络通信技术. ...

  4. 1014 福尔摩斯的约会(C#)

    一.题目内容: 大侦探福尔摩斯接到一张奇怪的字条:我们约会吧! 3485djDkxh4hhGE 2984akDfkkkkggEdsb s&hgsfdk d&Hyscvnm.大侦探很快就 ...

  5. 必须掌握的Linux用户组知识

    在 Linux 系统中用户组起着重要作用.用户组提供了一种简单方法供一组用户互相共享文件.用户组也允许系统管理员更加有效地管理用户权限,因为管理员可以将权限分配给用户组而不是逐一分配给单个用户. 尽管 ...

  6. Jmeter计数器的使用-转载

    说一下jmeter中,配置元件-计数器的使用. 如果需要引用的数据量较大,且要求不能重复或者需要自增,那么可以使用计数器来实现. 1.启动jmeter,添加线程组,右键添加配置元件——计数器,如下图: ...

  7. go调度: 第二部分-go调度器

    前言 这个博客是三部分中提供go调度器的语义和机制的部分. 博客三部分的顺序: 1) go调度: 第一部分-操作系统调度 2) go调度: 第二部分-go调度器 3) go调度: 第三部分-并发 介绍 ...

  8. SQL SERVER升级2017

    SQL SERVER升级2017 摘要 本文只介绍了SQL SERVER升级到2017(在简单环境下),分为开始升级前的检查事项,升级操作步骤,升级后对新实例的配置. 检查事项 1.检查当前版本是否可 ...

  9. Linux 常见 RAID 及软 RAID 创建

    RAID可以大幅度的提高磁盘性能,以及可靠性,这么好的技术怎么能不掌握呢!此篇介绍一些常见RAID,及其在Linux上的软RAID创建方法. mdadm 创建软RAID mdadm -C -v /de ...

  10. 阿里云云计算助理工程师认证(ACA)

    经过两天的学习(观看视频,阅读官方帮助文档),完成了初级云计算认证. 本次考试难度相对较低,考察内容较为初级 考点主要考察学员是否真正的动手实验过,不局限于视频中讲解的内容,较多的考点为视频中操作演示 ...