一.
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. 大家都知道fastclick能解决300ms延迟,现在我们来看一下,使用方法

    1.在终端输入以下命令进行安装 npm install fastclick -S 2.在你用脚手架搭建好的项目中,找到mian.js这个入口文件,打开 3.在其中加入: import FastClic ...

  2. 激活函数——sigmoid函数(理解)

    0 - 定义 $Sigmoid$函数是一个在生物学中常见的S型函数,也称为$S$型生长曲线.在信息科学中,由于其单增以及反函数单增等性质,$Sigmoid$函数常被用作神经网络的阈值函数,将变量映射到 ...

  3. mysql-8.0.11安装步骤

    1.下载好安装包:mysql-8.0.11-winx64.zip 2.解压到合适的目录,例如:C:\XQ\Soft\mysql-8.0.11-winx64 3.在目录下创建my.ini文件,配置bas ...

  4. linux tomcat单机部署多应用

    1.修改/etc/profile 增加tomcat环境变量

  5. 题解-AtCoder Code-Festival2017 Final-J Tree MST

    Problem \(\mathrm{Code~Festival~2017~Final~J}\) 题意概要:一棵 \(n\) 个节点有点权边权的树.构建一张完全图,对于任意一对点 \((x,y)\),连 ...

  6. WPF 之 调用线程必须为 STA,因为许多 UI 组件都需要

    WPF中,代码中准备控制控件内容时,有时会报错:“ 调用线程必须为 STA,因为许多 UI 组件都需要 ”. 如在winform下面,使用多线程时,控件的值读取是可以的,但如果要更改,那么就必须进行一 ...

  7. uni-app调用原生的文件系统管理器(可选取附件上传)

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

  8. this:当前调用的对象

  9. 为什么用Flow

    Flow 是 facebook 出品的 JavaScript 静态类型检查工具.Vue.js 的源码利用了 Flow 做了静态类型检查,所以了解 Flow 有助于我们阅读源码. flow的工作方式? ...

  10. 金蝶k/3 K3密码对照破解源码

    金蝶k/3 K3密码对照破解源码 通过密码对照表进行密码破解 以下是源码: VERSION 5.00 Object = "{0ECD9B60-23AA-11D0-B351-00A0C9055 ...