python程序中使用MySQL数据库
python程序中使用MySQL数据库
1、python中使用MySQL数据库需要借助第三方模块 pymysql(pip install pymysql)
2、pymysql本质是一个套接字客户端软件,在python 程序中使用pymysql对象链接服务器端
1 pymysql连接数据库
#方式1:
import pymysql
#step1 链接
conn = pymysql.connect(
host="localhost",
user="root",
password="123",
db="myschool",
charset="utf8")
cursor = conn.cursor() #step2 拿游标
sql = "select * from class;" #step3 拼接sql语句
res1 = cursor.execute(sql) #step4 调用execute()执行sql语句
print(res1) #res不是查询的数据结果,而是查到数据的行数
#step5 得到查询数据
res2 = cursor.fetchone() #fetchone返回查到第一行数据,以元组的形式返回
res3 = cursor.fetchmany(2) #fetchmany(n) 返回查到的接着n条记录
res4 = cursor.fetchall() #fetchall() 返回剩下所有的数据记录
cursor.close() #step6 #关闭游标
conn.close() #step7 #关闭客户端链接
1、方式1清楚地列出了使用pymysql连接数据库的主要步骤
2、当使用查询操作时,查询的数据需要使用 fetchone()等函数获得,返回元组形式的结果
3、使用增、删、改操作时,涉及到拼接sql语句时的字符串引号问题,需要注意sql注入问题
4、此外,还有第二种连接方式,用字典进行连接参数的管理,这样子更优雅
#方式2:
import pymysql.cursors
config = {
'host': '127.0.0.1',
'port': 3306,
'user': 'root',
'password': 'root',
'db': 'myschool',
'charset': 'utf8' }
conn = pymysql.connect(**config) #step1 创建连接
#cursor = conn.cursor() #step2 创建游标方式1
with conn.cursor() as cursor: #创建游标方法2 不需要再手动关闭游标
sql = "select * from class;" #step3 拼接sql语句
cursor.execute(sql) #step4 执行sql语句
res = cursor.fetchall() #step5 得到查询数据
print(res)
conn.close() #step6 关闭连接,释放内存
2 sql 注入
sql注入现象见:https://www.cnblogs.com/linhaifeng/articles/7525619.html#_label3
1、通过前端的表单提交的数据中携带sql语句, 欺骗服务器, 在后端对数据进行存储时, 执行恶意的sql语句
2、比如在使用pymysql操作数据库是使用字符串拼接生产sql语句, 就会出现sql注入漏洞
3、使用pymysql时, 不要自己拼接字符串, 而是使用execute方法, pymysql模块已经对提交的数据做了处理, 不会出
现sql注入
3 增删改查操作
1、查主要使用的是execute()和fetchone()系列函数
2、增删改主要使用的是execute()和commit()函数
#示例1:查
import pymysql
conn = pymysql.connect(host="localhost",user="root",password="123",
db="myschool",charset="utf8")
cursor = conn.cursor()
sql = "select * from student;"
res = cursor.execute(sql)
data = cursor.fetchall() #fetchone()\fetchmany(size)
print(data)
cursor.close()
conn.close()
3、需要注意的一点是,不要自己拼接sql语句的字符串、使用在execute中传参的方式
#示例2:增
import pymysql
conn = pymysql.connect(host="localhost",user="root",password="123",
db="myschool",charset="utf8")
cursor = conn.cursor()
#方式1
sql = "insert into student(sname,cid) values("tom",2);"
res = cursor.execute(sql,)
print(res) #打印sql影响成功的行数
conn.commit() #提交后才发现表中插入记录成功
#方式2
sql = "insert into student(sname,cid) values(%s,%d);"
res = cursor.execute(sql,("tom",2)) #参数放在元祖中
print(res)
conn.commit() #提交后才发现表中插入记录成功
#方式3
sql='insert into student(sname,cid) values(%s,%d);'
res=cursor.executemany(sql,[("jack",3),("lili",4)]) #插入多行,列表
print(res)
conn.commit() #提交后才发现表中插入记录成功
cursor.close()
conn.close()
#删、改的操作类似
4 pymysql使用总结
1、pymysql.connect()参数说明
host(str) #MySQL服务器地址
port(int) #MySQL服务器端口,默认3306
user(str) #用户名
password(str) #密码
db(str) #数据库名
charset(str) #连接编码
2、connection对象支持的方法
cursor() #获得游标
commit() #提交当前事务
rollback() #回滚当前事务
close() #关闭连接
3、cursor对象支持的方法
execute() #执行一个sql语句
fetchone() #获取结果集中的一条记录
fetchmany(size) #获取结果集中的多条记录,size指定条数
fetchall() #获取结果集中的所有剩下所有条
rowcount() #返回数据条数或影响行数
rownumber #返回数据条数或影响行数
close() #关闭游标对象
python程序中使用MySQL数据库的更多相关文章
- python项目中对mysql数据库进行配置,并进行连接测试
在settings.py中配置mysql数据库进行相关配置 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME ...
- Java程序中实现 MySQL数据库的备份与还原
案例代码: 数据库备份 //mysqldump -h端口号 -u用户 -p密码 数据库 > d:/test.sql --备份D盘 //备份 public static void dataBase ...
- shell中读写mysql数据库
本文介绍了如何在shell中读写mysql数据库.主要介绍了如何在shell 中连接mysql数据库,如何在shell中创建数据库,创建表,插入csv文件,读取mysql数据库,导出mysql数据库为 ...
- Django中使用mysql数据库并使用原生sql语句操作
Django自身默认使用sqlite3这个轻量级的数据库,但是当我们开发网站时,sqlite3就没有mysql好,sqlite3适合一些手机上开发使用的数据库. 准备的软件mysql数据库,版本5.7 ...
- Windows10系统的Linux子系统中安装MySQL数据库心得
后端开发童鞋们, 自己开发机用的是Windows系统电脑(台式机或笔记本), 而开发的程序和使用的数据库等要运行在Linux服务器上, 这种情况有木有? 提前声明: 本文并不讨论操作系统的比较, 以及 ...
- 【Python】Windows平台下Python、Pydev连接Mysql数据库
Mysql数据库是跨平台的,不是说Python一定就要连接Mongodb. Python连接Mysql数据库是非常easy的. 首先,你要配置好Python的开发环境,详见<[Python]Wi ...
- 【mysql】备份篇2:使用java程序定期备份mysql数据库
承接备份篇1, 在备份篇1中,使用dat文件加+系统计划任务程序完成mysql定期备份任务 在这一篇,备份使用java程序定期备份mysql数据库. 下面代码和程序思想给出: package com. ...
- 在 Android 应用程序中使用 SQLite 数据库以及怎么用
part one : android SQLite 简单介绍 SQLite 介绍 SQLite 一个非常流行的嵌入式数据库.它支持 SQL 语言,而且仅仅利用非常少的内存就有非常好的性能.此外它还是开 ...
- django 中连接mysql数据库的操作步骤
django中连接mysql数据库的操作步骤: 1 settings配置文件中 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mys ...
随机推荐
- sql nvarchar类型和varchar类型存储中文字符长度
今天遇到了,随手记录一下. sql server 存储数据里面 NVARCHAR 记录中文的时候是 一个中文对应一个字符串长度,记录英文也是一个字母一个长度 标点符号也是一样. ...
- 172. 阶乘后的零 Java解法
https://leetcode-cn.com/problems/factorial-trailing-zeroes/ 172. 阶乘后的零 这题要完成其实要知道一个很巧妙的思想,就是阶乘里面,后面的 ...
- Oracle JDK与OpenJDK到底有什么不同?
不知道各位developer平时是否有过疑问,Oracle JDK是什么,OpenJDK又是什么? Oracle JDK便是平常我们在windows系统上做开发使用的JDK,又称作SUN JDK.O ...
- Linux中bash shell环境变量
别名 别名是命令的快捷方式.为那些需要经常执行,但需要很长时间输入的长命令创建快捷方式很有用.语法是: alias ppp='ping www.baidu.com' 它们并不总是用来缩短长命令.重要的 ...
- 10w数组去重,排序,找最多出现次数(精华)
package cn.tedu.javaweb.test; import java.util.*; /* * @author XueWeiWei * @date 2019/6/11 8:19 */@S ...
- springboot-权限控制shiro(二)
目录 1. 场景描述 2. 解决方案 1. 场景描述 (1)最近有点小忙,公司真实项目内容有点小多以及不想只介绍理论,就使用springboot单独部署了个shiro的demo项目,还是理论和实际项结 ...
- hdoj 3732 Ahui Writes Word (多重背包)
之前在做背包的题目时看到了这道题,一看,大喜,这不是裸裸的01背包吗!! 然后华丽丽的超时,相信很多人也和我一样没有考虑到数据量的大小. 时隔多日,回过头来看这道题,依旧毫无头绪....不过相比之前 ...
- 关于STM32GPIO按键上下拉配置的认识
说真的,后知后觉这个问题还是有点值得研究的,一开始学习我用的板子在按键模块电路中GPIO输入脚是有外部上下拉电阻的,如下图所示:当KEY1接V3.3,在其后为它接一个下拉电阻,可以保证按下按键输入高电 ...
- Scala函数式编程(三)
Scala既是一门面向对象(OOP)语言,又是一门函数式编程(FP)语言.作为一门支持函数式编程的语言,Scala鼓励面向表达式编程(EOP)模型.简单来说,EOP中每个语句都有返回值.这一模式很明显 ...
- 自己实现spring核心功能 二
前言 上一篇我们讲了spring的一些特点并且分析了需要实现哪些功能,已经把准备工作都做完了,这一篇我们开始实现具体功能. 容器加载过程 我们知道,在spring中refesh()方法做了很多初始化的 ...