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 ...
随机推荐
- $m$ 整除 $10^k$ 的一个充分条件
若 (1) 既约分数 $\cfrac{n}{m}$ 满足 $0<\cfrac{n}{m}<1$; (2) 分数 $\cfrac{n}{m}$ 可以化为小数部分的一个循环节有 $k$ 位数字 ...
- 给一个Unix域套接字bind一个路径名
#include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <strings.h& ...
- Oracle 关键字、高级函数的使用
1.序列.唯一标识 查询时,可以添加递增序列 rownum 表的数据每一行都有一个唯一的标识 rowid 2.函数 单行:查询多条数据 如:to_date() 多行:查询总结数据,一般用于group ...
- MapReduce输出文件名更改
默认情况下生成的文件名是part-r-00000格式,想要自定义生成输出文件名可以使用org.apache.hadoop.mapreduce.lib.output.MultipleOutputs类用来 ...
- Django模型层-多表操作
多表操作 一.创建模型 实例:我们来假定下面这些概念,字段和关系 作者模型:一个作者有姓名和年龄. 作者详细模型:把作者的详情放到详情表,包含生日,手机号,家庭住址等信息.作者详情模型和作者模型之间是 ...
- RequireJS - 个人小入门
quirejs : http://www.requirejs.cn/ 叶小钗 : http://www.cnblogs.com/yexiaochai/p/3214926.html app.js 展示 ...
- windows下安装setuptools与pip
1.下载 setuptools与pip 下载地址如下: https://pypi.Python.org/pypi/setuptools https://pypi.Python.org/pypi/pip ...
- 用WKWebView 截取整个Html页面
以前使用UIWebview时,想截取整个页面,可以调整内部scrollView的frame,之后调用 scrollView的layer的 render 方法,很方便. 但是在WKWebView上,行不 ...
- 加密:HashUtils,RSAUtil,AESUtils
import java.security.MessageDigest; public class HashUtils { public static String getMD5(String sour ...
- java基础学习总结——面向对象1
目录 一.面向过程的思想和面向对象的思想 二.简单理解面向对象 三.面向对象的设计思想 四.对象和类的概念 五.如何抽象出一个类? 六.类(对象)之间的关系 七.Java与面向对象 八.为什么使用面向 ...