pymsql的使用

初识pymysql模块

先在数据库中创建一个用户信息表,里面包含用户的ID、用户名、密码

create table userinfo(
uid int not null auto_increment primary key,
username varchar(32),
pwd varchar(32)
)engine = innodb default charset=utf8;

增加一个用户的信息:

insert into userinfo(username,pwd) values('jxson','a123');

用pymysql模块从数据库拿到用户信息模拟登陆效果:

import pymysql
user = input('username:') #输入用户的名字
pwd = input('password:') #输入用户的密码
conn = pymysql.connect(host ='localhost',user = 'root',password = '',database = 'db1') #连接数据库
cursor = conn.cursor() #cursor是一个游标 去帮我们获取数据
sql_search = "select * from userinfo where username='%s' and pwd='%s'" %(user,pwd,) #SQL语句
cursor.execute(sql_search) #执行SQL语句
get_one = cursor.fetchone() #拿一组数据
cursor.close() #关闭游标
conn.close() #关闭连接
if get_one: #判断是否有拿到数据
print("登陆成功!")
print(get_one)
else:
print("登陆失败!")

执行结果:

username:jxson
password:a123
登陆成功!
(1, 'jxson', 'a123')

防止SQL注入的改进方法

1.

sql_search = "select * from userinfo where username=%s and pwd=%s"
cursor.execute(sql_search,user,pwd)

2.列表的表示方式

sql_search = "select * from userinfo where username=%s and pwd=%s"
cursor.execute(sql_search,[user,pwd])

3.字典的表示方式

sql_search = "select * from userinfo where username=%(u)s and pwd=%(p)s"
cursor.execute(sql_search,{'u' : user,'p' : pwd})

 增、删、改、查

增、删、改:

增、删、改都需要commit(),以增为举例

增加单个

import pymysql
conn = pymysql.connect(host ='localhost',user = 'root',password = '',database = 'db1')
cursor = conn.cursor()
sql_insert = "insert into userinfo(username,pwd) values('abc','666')"
cursor.execute(sql_insert)
conn.commit()
cursor.close()
conn.close()

增加多个:

import pymysql
conn = pymysql.connect(host ='localhost',user = 'root',password = '',database = 'db1')
cursor = conn.cursor()
sql_insert = "insert into userinfo(username,pwd) values(%s,%s)"
cursor.executemany(sql_insert,[('hylisang','a123'),('HSI15','47a8'),('asw2','')])
conn.commit()
cursor.close()
conn.close()

output:

查:

1.fetchone()

import pymysql
conn = pymysql.connect(host ='localhost',user = 'root',password = '',database = 'db1')
cursor = conn.cursor()
sql = "select * from userinfo"
cursor.execute(sql)
result1 = cursor.fetchone()
print(result1)
result2 = cursor.fetchone()
print(result2)
cursor.close()
conn.close()

执行结果:

(1, 'jxson', 'a123')
(6, 'abc', '')

2.fetchmany(n),一次取n条数据

import pymysql
conn = pymysql.connect(host ='localhost',user = 'root',password = '',database = 'db1')
cursor = conn.cursor()
sql = "select * from userinfo"
cursor.execute(sql)
result1 = cursor.fetchmany(3)
print(result1)
cursor.close()
conn.close()

执行结果:

((1, 'jxson', 'a123'), (6, 'abc', ''), (7, 'hylisang', 'a123'))

3.fetchall(),一次取全部SQL语句查到的数据

import pymysql
conn = pymysql.connect(host ='localhost',user = 'root',password = '',database = 'db1')
cursor = conn.cursor()
sql = "select * from userinfo"
cursor.execute(sql)
result1 = cursor.fetchall()
print(result1)
cursor.close()
conn.close()

执行结果:

((1, 'jxson', 'a123'), (6, 'abc', ''), (7, 'hylisang', 'a123'), (8, 'HSI15', '47a8'), (9, 'asw2', ''))

把结果转化为字典的格式:

import pymysql
conn = pymysql.connect(host ='localhost',user = 'root',password = '',database = 'db1')
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
sql = "select * from userinfo"
cursor.execute(sql)
result1 = cursor.fetchall()
print(result1)
cursor.close()
conn.close()

执行结果:

[{'uid': 1, 'username': 'jxson', 'pwd': 'a123'}, {'uid': 6, 'username': 'abc', 'pwd': ''}, {'uid': 7, 'username': 'hylisang', 'pwd': 'a123'},
{'uid': 8, 'username': 'HSI15', 'pwd': '47a8'}, {'uid': 9, 'username': 'asw2', 'pwd': ''}]

4.控制游标来获取数据

cursor.scroll(1,mode='relative')                                #根据当前位置相对位移
cursor.scroll(2,mode='absolute')                             #绝对位置移动

查看新插入数据的自增ID

如果添加多笔数据再去查询,那查到的ID是最后一条

import pymysql
conn = pymysql.connect(host ='localhost',user = 'root',password = '',database = 'db1')
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
sql_insert = "insert into userinfo(username,pwd) values('abc','666')"
cursor.execute(sql_insert)
print(cursor.lastrowid)
conn.commit()
cursor.close()
conn.close()

Python学习日记(三十七) Mysql数据库篇 五的更多相关文章

  1. Python学习日记(三十三) Mysql数据库篇 一

    背景 Mysql是一个关系型数据库,由瑞典Mysql AB开发,目前属于Oracle旗下的产品.Mysql是目前最流行的关系型数据库管理系统之一,在WEB方面,Mysql是最好的RDBMS(Relat ...

  2. Python学习日记(四十) Mysql数据库篇 八

    Mysql存储过程 存储过程是保存在Mysql上的一个别名(就是一堆SQL语句),使用别名就可以查到结果不用再去写SQL语句.存储过程用于替代程序员写SQL语句. 创建存储过程 delimiter / ...

  3. Python学习日记(四十一) Mysql数据库篇 九

    前言 索引的主要作用是起到约束和加速查找,ORM框架(sqlalchemy)是用类和对象对数据库进行操作 索引的种类 按种类去分 1.普通索引:能够加速查找 2.主键索引:能够加速查找.不能为空.不能 ...

  4. Python学习日记(三十六) Mysql数据库篇 四

    MySQL作业分析 五张表的增删改查: 完成所有表的关系创建 创建教师表(tid为这张表教师ID,tname为这张表教师的姓名) create table teacherTable( tid int ...

  5. Python学习笔记9-Python 链接MySql数据库

    Python 链接MySql数据库,方法很简单: 首先需要先 安装一个MySql链接插件:MySQL-python-1.2.3.win-amd64-py2.7.exe 下载地址:http://dev. ...

  6. python学习笔记之——操作mysql数据库

    Python 标准数据库接口为 Python DB-API,Python DB-API为开发人员提供了数据库应用编程接口. Python 数据库接口支持非常多的数据库,你可以选择适合你项目的数据库: ...

  7. Python学习日记(三十八) Mysql数据库篇 六

    Mysql视图 假设执行100条SQL语句时,里面都存在一条相同的语句,那我们可以把这条语句单独拿出来变成一个'临时表',也就是视图可以用来查询. 创建视图: CREATE VIEW passtvie ...

  8. Python学习日记(三十九) Mysql数据库篇 七

    Mysql函数 高级函数 1.BIN(N) 返回N的二进制编码 ); 执行结果: 2.BINARY(str) 将字符串str转换为二进制字符串 select BINARY('ASCII'); 执行结果 ...

  9. Python学习日记(三十五) Mysql数据库篇 三

    使用Navicate 创建一个连接去使用Mysql的数据库,连接名可以取任意字符但是要有意义 新增一个数据库 填写新数据库名,设置它的字符集和排序规则 新建一个表 增加表中的信息 点击保存再去输入表名 ...

随机推荐

  1. ESP8266 LUA脚本语言开发: 测试下诱人的程序

    前言 这一节测试一下诱人的程序 实现的功能,APP通过SmartConfig给Wi-Fi模块配网并绑定设备,然后通过MQTT远程控制开发板的继电器, APP显示ESP8266采集的温湿度数据. 简而言 ...

  2. 请用正则实现String.trim()

    String.prototype.trim1=function(){ return this.replace(/(^\s*)|(\s*$)/g,""); }; 写一个functio ...

  3. Java集合详解6:这次,从头到尾带你解读Java中的红黑树

    <Java集合详解系列>是我在完成夯实Java基础篇的系列博客后准备开始写的新系列. 这些文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查 ...

  4. 非mvn项目转为mvn项目并构建mvn私服

    非mvn项目转为mvn项目并构建mvn私服 一.背景 公司里的系统是老系统,没有使用mvn,但是现在准备使用持续集成(CI),就要用到mvn,所以现在需要将老项目转为mvn项目,并且非mvn项目也是不 ...

  5. Linux文件和目录管理

    一.与文档相关的命令 1,命令head:用于显示文件前10行,后面直接跟文件名.如果加-n,则显示文件的前几行. 选项-n后有无空格均可也可以省略字母n,直接跟数字 2,命令tail:和命令head类 ...

  6. | C语言I作业02

    C语言I博客作业02 标签: 18软件2班 李煦亮 问题 答案 这个作业属于那个课程 C语言程序设计I 这个作业要求在哪里 https://edu.cnblogs.com/campus/zswxy/C ...

  7. Git flow 工作流与规范

    概述 简版图: PS. 可能用到的命令: 1.从指定 commit拉出新分支   git checkout commitId -b 本地新branchName git checkout 9fbc3d0 ...

  8. 命令(Command)模式

    命令模式又称为行动(Action)模式或者交易(Transaction)模式. 命令模式把一个请求或者操作封装到一个对象中.命令模式允许系统使用不同的请求把客户端参数化,对请求排队或者记录请求日志,可 ...

  9. OI之路

    由于各种因素 学习.初赛.时间... 我的oi可能会结束, 我也不甘于放弃, 所以 综合今后的表现, 我再决定 以后我尽量写博客.

  10. LR编写grammar中的问题和解决方法

    本文主要说明LR解析过程中关于BNF的典型冲突如何在LR中解决 冲突一般分为两种: shift/reduce错误 redure/redure错误 下面分别解释两种冲突 1. shift/reduce错 ...