python pymsql的用法 180903
一.
1.pymysql 的下载
pip3 install pymysql
2.pymysql的使用
import pymysql
name=input("请输入用户名:")
password=input("请输入密码:")
# 1.连接
conn=pymysql.connect(
host="127.0.0.1",
port=3306,
db="db5",
user="root",
password="",
charset="utf8"
)
# 2.创建游标
cur=conn.cursor()
# 注意 %s需要加引号
sql="select * from userinfo where name='%s' and password='%s'"%(name,password)
result=cur.execute(sql)
# 执行sql语句返回sql查询成功的记录数目
print(result)
# 关闭游标和连接
cur.close()
conn.close()
if result:
print("登陆成功")
else:
print("登陆失败")
二,execute()之sql注入
# 问题 :
# 最后那一个空格,在一条sql语句中如果遇到select * from userinfo where username='mjj' -- asadasdas' and pwd='' 则--之后的条件被注释掉了(注意--后面还有一个空格)
# 1.sql 注入之:用户存在,绕过密码;
# mjj' -- 任意字符
#2.sql注入之:用户不存在,绕过用户与密码;
# xxx' or 1=1 -- 任意字符
# 解决方案:
# 错误原因:对sql进行字符串拼接
# 改写为(execute帮我们做字符串拼接,我们无需且一定不能再为%s加引号了)
import pymysql
name=input("请输入用户名:")
password=input("请输入密码:")
# 1.连接
conn=pymysql.connect(
host="127.0.0.1",
port=3306,
db="db5",
user="root",
password="",
charset="utf8"
)
# 2.创建游标
cur=conn.cursor()
#%s不加引号 pymysql 自动加
sql="select * from userinfo where name=%s and password=%s"
result=cur.execute(sql,[name,password])
# 执行sql语句返回sql查询成功的记录数目
print(result)
# 关闭游标和连接
cur.close()
conn.close()
if result:
print("登陆成功")
else:
print("登陆失败")
三 增删改 conn.commit()
commit()方法:在数据库里增、删、改的时候,必须要进行提交,否则插入的数据不生效。
import pymysql
name=input("请输入用户名:")
password=input("请输入密码:")
# 1.连接
conn=pymysql.connect(
host="127.0.0.1",
port=3306,
db="db5",
user="root",
password="",
charset="utf8"
)
# 2.创建游标
cur=conn.cursor()
# 操作:
sql="insert into userinfo(name,password) values(%s,%s)"
# 插入一条数据:
result=cur.execute(sql,[name,password]) # 执行sql语句返回sql查询成功的记录数目
# 同时插入多条数据:
result=cur.executemany(sql,[("tai","888"),("wus","999")]) # 修改数据
sql="update userinfo set name=%s where id=3"
result=cur.execute(sql,name) # 删除数据
sql="delete from userinfo where id=7"
result=cur.execute(sql) # 一定要提交 坑
conn.commit()
# 关闭游标和连接
cur.close()
conn.close()
四.查 fetchone fetchmany fetchall
fetchone() 获取下一行数据,第一次为首行
import pymysql
# 1.连接
conn=pymysql.connect(
host="localhost",
port=3306,
user="root",
password='',
db="db5",
charset="utf8"
)
# 2.创建游标
cur=conn.cursor()
sql="select * from userinfo"
cur.execute(sql)
# 查询第一行的数据
row=cur.fetchone() #获取下一行
print(row) #(1, 'alex', '123')
# 查询第二行的数据
row=cur.fetchone()
print(row) #(3, 'lili', '666')
# 3.关闭游标
cur.close()
# 4.关闭连接
conn.close()
fetchall() 获取所有行数据源
import pymysql
# 1.连接
conn=pymysql.connect(
host="localhost",
port=3306,
user="root",
password='',
db="db5",
charset="utf8"
)
# 2.创建游标
cur=conn.cursor()
sql="select * from userinfo"
cur.execute(sql)
# 查询所有的数据
row=cur.fetchall()
print(row) # 3.关闭游标
cur.close()
# 4.关闭连接
conn.close()
fetchmany(4) 获取4行数据
import pymysql
# 1.连接
conn=pymysql.connect(
host="localhost",
port=3306,
user="root",
password='',
db="db5",
charset="utf8"
)
# 2.创建游标
cur=conn.cursor()
sql="select * from userinfo"
cur.execute(sql)
# 查询三条的数据
row=cur.fetchmany(3)
print(row)
# 3.关闭游标
cur.close()
# 4.关闭连接
conn.close()
补充:
问题
1. 默认情况下,我们获取到的返回值是元组,只能看到每行的数据,却不知道每一列代表的是什么
解决方案:
使用以下方式来返回字典,每一行的数据都会生成一个字典
在实例化的时候,将属性cursor设置为pymysql.cursors.DictCursor
示例:
cur=conn.cursor(cursor=pymysql.cursors.DictCursor)
案例:
import pymysql
# 1.连接
conn=pymysql.connect(
host="localhost",
port=3306,
user="root",
password='',
db="db5",
charset="utf8"
)
# 2.创建游标
cur=conn.cursor(cursor=pymysql.cursors.DictCursor)
sql="select * from userinfo"
cur.execute(sql)
# 查询所有的数据
row=cur.fetchall()
print(row)
# [{'id': 1, 'name': 'alex', 'password': '123'}, {'id': 3, 'name': 'lili', 'password': '666'}, {'id': 4, 'name': 'tai', 'password': '888'}, {'id': 5, 'name': 'wus', 'password': '999'}, {'id': 6, 'name': 'lili -- hhk', 'password': '666'}] # 3.关闭游标
cur.close()
# 4.关闭连接
conn.close()
问题2:
在fetchone示例中,在获取行数据的时候,可以理解开始的时候,有一个行指针指着第一行的上方,获取一行,它就向下移动一行,
# 所以当行指针到最后一行的时候,就不能再获取到行的内容,所以我们可以使用如下方法来移动行指针:
解决方案:
cursor.scroll(1,mode='relative') # 相对当前位置移动
cursor.scroll(2,mode='absolute') # 相对绝对位置移动
第一个值为移动的行数,整数为向下移动,负数为向上移动,mode指定了是相对当前位置移动,还是相对于首行移动
# 1.连接
conn=pymysql.connect(
host="localhost",
port=3306,
user="root",
password='',
db="db5",
charset="utf8"
)
# 2.创建游标
cur=conn.cursor(cursor=pymysql.cursors.DictCursor)
sql="select * from userinfo"
cur.execute(sql)
# 查询所有的数据
row=cur.fetchone()
print(row)
#相对位置
cur.scroll(-1,mode='relative')#设置之后,光标相对于当前位置往前移动了一行
row=cur.fetchone()
print(row)
#绝对位置
cur.scroll(3,mode='absolute')#设置之后,光标相对于绝对位置往下运动相应量.
row=cur.fetchone()
print(row) # 3.关闭游标
cur.close()
# 4.关闭连接
conn.close()
python pymsql的用法 180903的更多相关文章
- Python回调函数用法实例详解
本文实例讲述了Python回调函数用法.分享给大家供大家参考.具体分析如下: 一.百度百科上对回调函数的解释: 回调函数就是一个通过函数指针调用的函数.如果你把函数的指针(地址)作为参数传递给另一个函 ...
- day01-day04总结- Python 数据类型及其用法
Python 数据类型及其用法: 本文总结一下Python中用到的各种数据类型,以及如何使用可以使得我们的代码变得简洁. 基本结构 我们首先要看的是几乎任何语言都具有的数据类型,包括字符串.整型.浮点 ...
- 【Python】关于Python有意思的用法
开一篇文章,记录关于Python有意思的用法,不断更新 1.Python树的遍历 def sum(t): tmp=0 for k in t: if not isinstance(k,list): tm ...
- python中xrange用法分析
本文实例讲述了python中xrange用法.分享给大家供大家参考.具体如下: 先来看如下示例: >>> x=xrange(0,8) >>> print x xra ...
- 浅谈Python在信息学竞赛中的运用及Python的基本用法
浅谈Python在信息学竞赛中的运用及Python的基本用法 前言 众所周知,Python是一种非常实用的语言.但是由于其运算时的低效和解释型编译,在信息学竞赛中并不用于完成算法程序.但正如LRJ在& ...
- python scapy的用法之ARP主机扫描和ARP欺骗
python scapy的用法之ARP主机扫描和ARP欺骗 目录: 1.scapy介绍 2.安装scapy 3.scapy常用 4.ARP主机扫描 5.ARP欺骗 一.scapy介绍 scapy是一个 ...
- python函数的用法
python函数的用法 目录: 1.定义.使用函数 1.函数定义:def 2.函数调用:例:myprint() 3.函数可以当作一个值赋值给一个变量 例:a=myprint() a() 4.写r ...
- python 中@ 的用法【转】
这只是我的个人理解: 在Python的函数中偶尔会看到函数定义的上一行有@functionName的修饰,当解释器读到@的这样的修饰符之后,会先解析@后的内容,直接就把@下一行的函数或者类作为@后边的 ...
- Python Enum 枚举 用法汇总
Python Enum 枚举 用法汇总 import os import sys if sys.version_info.major + sys.version_info.minor * 0.1 &l ...
随机推荐
- luogu P5287 [HNOI2019]JOJO
传送门 神™这题暴力能A,这出题人都没造那种我考场就想到的数据,难怪我的垃圾做法有分 先考虑没有撤销操作怎么做,因为每次插入一段一样的字符,所以我们可以把\(x\)个字符\(c\)定义为\(cx\), ...
- ado.net 使用:ExecuteReader 无法获取输出参数
解决方法: 要获取到输出参数.需要连接关闭之后才行. 一般都是用using把打开数据库连接的reader包起来
- eclipse+tomcat出现警告警告: [SetPropertiesRule]...
启动tomcat出现警告: [SetPropertiesRule]{Server/Service/Engine/Host/Context} Setting property 'source' to ' ...
- python Flask web框架
目录: --> Flask --> 配置文件 --> 配置文件解析 --> 配置文件导入 --> 路由 --> 路由参数 --> 常用路由匹配 --> ...
- Python Libhunt
有一个网站,Python Libhunt: https://python.libhunt.com 这个网站类似于Github的Awesome xxx系列,不过它是随时更新的,排序方式,分类也更加友好. ...
- org.hibernate.boot.MappingNotFoundException: Mapping (RESOURCE) not found :
可能原因: hibernate映射文件hibernate.cfg.xml中mapping中resource写错了文件名或者路径
- sed 正则 ! 取反
!符号表示取反,x,y!表示匹配不在x和y行号范围内的行,利用sed命令用于的阿银不在2-7之间的行 [111 sed]$ cat input [111 sed]$ sed -n '2,7!p' in ...
- 【剑指offer】【python】面试题2~5
使用python实现<剑指offer>面试题ヾ(◍°∇°◍)ノ゙,以此记录. 2_实现Singleton模式 题目:实现单例模式 单例模式,是一种常用的软件设计模式.在它的核心结构中只包含 ...
- Python学习笔记十
守护进程 p.daemon=True 必须在p.start()之前设置. 守护进程内不能再开子进程. 在主进程中开启守护进程(就是一个子进程) 什么时候应该把子进程设置为守护进程? 开子进程的目的:就 ...
- Python学习笔记五
一. 递归 递归函数: def a (): print ("from b") b() def b(): print("from a ") a() a() 递推和 ...