一.
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的更多相关文章

  1. Python回调函数用法实例详解

    本文实例讲述了Python回调函数用法.分享给大家供大家参考.具体分析如下: 一.百度百科上对回调函数的解释: 回调函数就是一个通过函数指针调用的函数.如果你把函数的指针(地址)作为参数传递给另一个函 ...

  2. day01-day04总结- Python 数据类型及其用法

    Python 数据类型及其用法: 本文总结一下Python中用到的各种数据类型,以及如何使用可以使得我们的代码变得简洁. 基本结构 我们首先要看的是几乎任何语言都具有的数据类型,包括字符串.整型.浮点 ...

  3. 【Python】关于Python有意思的用法

    开一篇文章,记录关于Python有意思的用法,不断更新 1.Python树的遍历 def sum(t): tmp=0 for k in t: if not isinstance(k,list): tm ...

  4. python中xrange用法分析

    本文实例讲述了python中xrange用法.分享给大家供大家参考.具体如下: 先来看如下示例: >>> x=xrange(0,8) >>> print x xra ...

  5. 浅谈Python在信息学竞赛中的运用及Python的基本用法

    浅谈Python在信息学竞赛中的运用及Python的基本用法 前言 众所周知,Python是一种非常实用的语言.但是由于其运算时的低效和解释型编译,在信息学竞赛中并不用于完成算法程序.但正如LRJ在& ...

  6. python scapy的用法之ARP主机扫描和ARP欺骗

    python scapy的用法之ARP主机扫描和ARP欺骗 目录: 1.scapy介绍 2.安装scapy 3.scapy常用 4.ARP主机扫描 5.ARP欺骗 一.scapy介绍 scapy是一个 ...

  7. python函数的用法

    python函数的用法 目录: 1.定义.使用函数 1.函数定义:def 2.函数调用:例:myprint() 3.函数可以当作一个值赋值给一个变量 例:a=myprint()    a() 4.写r ...

  8. python 中@ 的用法【转】

    这只是我的个人理解: 在Python的函数中偶尔会看到函数定义的上一行有@functionName的修饰,当解释器读到@的这样的修饰符之后,会先解析@后的内容,直接就把@下一行的函数或者类作为@后边的 ...

  9. Python Enum 枚举 用法汇总

    Python Enum 枚举 用法汇总 import os import sys if sys.version_info.major + sys.version_info.minor * 0.1 &l ...

随机推荐

  1. Groovy 设计模式 -- 保镖模式

    Bouncer Pattern http://groovy-lang.org/design-patterns.html#_bouncer_pattern 保镖模式主要负责对函数的输入参数的合法性检查, ...

  2. Highcharts开发图表

    1.折线图 显示一个静态的折线图,显示如下数据 星期 温度 周一 9~14 周二 4~10 周三 1~7 周四 4~9 周五 5~11 周六 8~13 周天 7~10 新建demo1.html < ...

  3. ssm心得

    dao层 mybatis mapper工厂spring接管后,直接拿到mapper接口就可以来实现方法 service层 注入dao层的mapper实现各种方法.. controller 层 注入se ...

  4. php7 + 新特性 部分

    三目运算符: 以前:$type = isset($_GET['type']) ? $_GET['type'] : '测试'; php7.0: $type = $_GET['type'] ?? '测试' ...

  5. C#学习笔记-XML的读写(一)

    需要解析的配置XML <?xml version="1.0" encoding="utf-8" ?> <configurations> ...

  6. JQuery Advanced

    1.Jquery Utility <1> Type & Function & setTimeOut <!DOCTYPE html> <html lang= ...

  7. 第一周——数据分析之表示 —— Numpy入门

    数据的维度 从一个数据到一组数据 一个数据:表达一个含义 一组数据:表达一个或者多个含义 维度:一组数据的组织形式 一维数据 由对等关系的有序或者无序数据构成,采用线性方式组织,对应列表.数组和集合等 ...

  8. 如何使用 Lucene 做网站高亮搜索功能?

    现在基本上所有网站都支持搜索功能,现在搜索的工具有很多,比如Solr.Elasticsearch,它们都是基于 Lucene 实现的,各有各的使用场景.Lucene 比较灵活,中小型项目中使用的比较多 ...

  9. 10分钟理解JS引擎的执行机制

    首先,请牢记2点: (1) JS是单线程语言 (2) JS的Event Loop是JS的执行机制.深入了解JS的执行,就等于深入了解JS里的event loop 1.灵魂三问 (1) JS为什么是单线 ...

  10. echarts4.0折线图让某个点闪烁

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...