四、pymysql模块、索引和慢查询
目录
一、pymysql模块
(一)如何使用
- fetchall():获取所有数据,返回的是列表套字典
- fetchone():获取一条数据,返回的是字典
- fetchmany(size):获取size条数据,返回的是列表套字典
- commit:当sql中有参数时,必须要使用conn.commit()
- executemany:新增多条数据
import pymysql
conn = pymysql.connect(host='localhost',user='root',password='wickyo',database 'test',charset='utf8') # 连接数据库
# 创建一个游标对象cursor
# cursor = conn.cursor() # 默认返回的值是元组类型
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor) # 返回的是字典对象
# 1. 查
sql = 'select * from userinfo'
cursor.execute(sql)
res = cursor.fetchall() # 获取所有的数据,返回的是列表套字典
res = cursor.fetchone() # 获取一条数据,返回的是字典类型
res = cursor.fetchmany(12) # 获取12条数据,返回的是列表套字典
print(res)
# 2. 增
## (1)新增一条数据
sql = "insert into user (name, password) values (%s, %s)"
cursor.execute(sql, ('xxx', 'qwe')) ###
## (2)新增多条数据 executemany
data = [
('zekai1', 'qwe'),
('zekai2', 'qwe1'),
('zekai3', 'qwe2'),
('zekai4', 'qwe3'),
]
cursor.executemany(sql, data)
conn.commit() # 必须要加这一句
print(cursor.lastrowid) # 打印最后一行id
# 3. 修
sql = "update user set name=%s where id=%s"
cursor.execute(sql, ('dgsahdsa', 2))
conn.commit()
# 4. 删
sql = "delete from user where id=%s"
cursor.execute(sql, ('dgsahdsa', 2))
conn.commit()
cursor.close() # 关闭cursor对象
conn.close() #关闭数据库里对象
(二)sql注入问题
利用mysql的#会注释的漏洞,避开密码验证
当输入的用户名为
xxx' or 1=1 #
时,下面的例子中sql会变成'select * from user where name = xxx' or 1=1 # and password=%s'
,#后面的内容会被注释掉,会导致sql注入问题原因
没有做任何检验限制
解决办法
将参数传给execute,利用模块本身进行一个校验
import pymysql
user = input('请输入用户名:')
password = input('请输入密码:')
conn = pymysql.connect(host='localhost',user='root',password='wickyo',databse= 'test',charst='utf8')
cursor=conn.cursor(cursor=pymysql.cursors.DictCursor)
# sql1 = "select * from user where name='%s' and password='%s'" % (user, pwd)
# cursor.execute(sql1)
sql2 = 'select * from user where name = %s and password=%s'
cursor.execute(sql2,(user,pwd))
res = cursor.fetchall()
print(res)
cursor.close()
conn.close()
if res:
print('登陆成功')
else:
print('登录失败')
二、索引
优缺点:
优点:加快查询速度
缺点:占用大量磁盘空间
索引的本质:是一个特殊的文件
索引的底层原理:B+树
(一)主键索引
- 加速查找
- 不能重复
- 不能为空
(1)增
# 1. 创建时
create table xxx(
id int auto_increment,
primary(id)
)
# 2. 通过modify修改字段
alter table xxx modify id int auto_increment primary key;
# 3. 通过add修改字段
alter table xxx add primary key(id);
(2)删
alter table t1 drop primary key
(二)唯一索引
unique(字段名)
- 加速查找
- 不能重复
(1)增
# 1. 创建表时
craete table t2(
id int auto_increment primary key,
name varchar(32) not null default'',
unique u_name(name)
)charset utf8;
# 2.创建表结构
create unique index 索引名 on 表名 (字段名;)
# 例子
create unique index ix_name on t2(name);
# 3. 修改表结构
alter table 表名 add unique index 唯一索引名(字段名)
#例子
alter table t2 add unique index ix_name (name)
(2)删
alter table 表名 drop index 唯一索引名;
# 例子
alter table t2 drop index u_name;
(三)普通索引
index(字段名)
,加速查找
(1)增
# 1. 创建表时
create table t3 (
id int auto_incremnt primary key,
name varchar (32) not null default '',
index u_name (name))
# 2. 创建表结构
create index ix_name on t3(name);
# 3. 修改表结构
alter table t3 add index ix_name (name)
(2)删
alter table t3 drop index ix_name;
(四)联合索引
联合主键索引
primary key (id,name)
联合唯一索引
unique(id,name)
联合普通索引
index(id,name)
(五)不会命中索引的情况
四则运算
不能在SQL语句中,进行四则运算,会降低SQLd的查询效率
使用函数
select * from t1 where reverse(email)= 'wick';
类型不一致
如果列是字符串类型,传入条件必须用引号括起来
select * from t1 where email = 999;
order by
select name from s1 order by email;
当根据索引排序时,如果select查询的字段不是索引,效率也较低
- 如果对主键排序,速度还是很快
select * from t1 order by id ;
- 如果对主键排序,速度还是很快
count
count(*)
相较于count(列名)
或count(1)
,结果一昂,前者效率低组合索引最左前缀
select * from user where name = 'wick'and email = 'wick@qq.com';
上述场景想要添加索引加快速度,错误中做法:
index ix_name(name)
index ix_email(email)
正确的做法:
index ix_name_email(name,email)
where name = 'wick' and email= 'wick@11.com'
此种情况索引命中where name='wick'
此种情况也命中where email = 'wick@qq.com'
此种情况未命中
注意:
index (a,b,c,d) where a=2 and b=3 and c=1 and d=1; #命中 where a=2 and c=3 and d=4 # 命中 where b =2 and c= 3 and d=3 # 未命中
(六)explain
explain select * from user where name = 'wick' and email = 'wick@qq.com'\G
# id: 1
# select_type: SIMPLE
# table: user
# partitions: NULL
# type: ref 索引指向 all
# possible_keys: ix_name_email 可能用到的索引
# key: ix_name_email 确实用到的索引
# key_len: 214 索引长度
# ref: const,const
# rows: 1 扫描的长度
# filtered: 100.00
# Extra: Using index 使用到了索引
(七)索引覆盖
被查询的列,数据能从索引中取得,而不用通过行定位符 row-locator 再到 row 上获取,即“被查询列要被所建的索引覆盖”,这能够加速查询速度。
select id from t1 where id = 2000;
三、慢查询日志
# 1. 查看慢SQL的相关变量
show variables like '%slow%';
# 2. 查看long相关的变量
show variables like '%long%';
# 3. 配置慢相关的的变量
# set global 变量名=值
# 设置慢查询日志开关
set global slow_query_log = on;
# 设置慢查询日志存储地址
set global slow_query_log_file= 'D:/mysql/data/myslow.log';
# 设置慢查询匹配时间
set global long_query_time = 1
四、pymysql模块、索引和慢查询的更多相关文章
- mysql python pymysql模块 增删改查 查询 fetchone
import pymysql mysql_host = '192.168.0.106' port = 3306 mysql_user = 'root' mysql_pwd = ' encoding = ...
- mysql python pymysql模块 增删改查 查询 字典游标显示
我们看到取得结果是一个元祖,但是不知道是哪个字段的,如果字段多的时候,就比较麻烦 ''' (1, 'mike', '123') (2, 'jack', '456') ''' 用字典显示查询的结果,也可 ...
- mysql python pymysql模块 增删改查 查询 fetchmany fetchall函数
查询的fetchmany fetchall函数 import pymysql mysql_host = '192.168.0.106' port = 3306 mysql_user = 'root' ...
- pymysql 模块 使用目录
mysql python pymysql模块 基本使用 mysql python pymysql模块 增删改查 插入数据 介绍 commit() execute() executemany() 函数 ...
- 第八章| 3. MyAQL数据库|Navicat工具与pymysql模块 | 内置功能 | 索引原理
1.Navicat工具与pymysql模块 在生产环境中操作MySQL数据库还是推荐使用命令行工具mysql,但在我们自己开发测试时,可以使用可视化工具Navicat,以图形界面的形式操作MySQL数 ...
- 多表查询、可视化工具、pymysql模块
create table dep( id int primary key auto_increment, name varchar(16), work varchar(16) ); create ta ...
- python 全栈开发,Day63(子查询,MySQl创建用户和授权,可视化工具Navicat的使用,pymysql模块的使用)
昨日内容回顾 外键的变种三种关系: 多对一: 左表的多 对右表一 成立 左边的一 对右表多 不成立 foreign key(从表的id) refreences 主表的(id) 多对多 建立第三张表(f ...
- MySQL:记录的增删改查、单表查询、约束条件、多表查询、连表、子查询、pymysql模块、MySQL内置功能
数据操作 插入数据(记录): 用insert: 补充:插入查询结果: insert into 表名(字段1,字段2,...字段n) select (字段1,字段2,...字段n) where ...; ...
- MySQL多表查询,Navicat使用,pymysql模块,sql注入问题
一.多表查询 #建表 create table dep( id int, name varchar(20) ); create table emp( id int primary key auto_i ...
随机推荐
- 网站开发过程中的URL写法
在开发网页和服务器时发现,在很多地方需要写超链接 那么可以将超链接的使用者分为服务器和浏览器,以区分不同的写法 地址可能使用的情况: 1.跳转 2.转发 3.服务器资源地址 4.浏览器超链接 impo ...
- 黑苹果之DELL台式机安装Mac OS X 10.13.6版本操作系统
由于本人所在的公司一般都是DELL的品牌台式机,所以以DELL台式机做小白鼠.记得在2012年的时候,在当时的那家公司为了学习自学IOS开发的Objective-C开发语言的时候,由于囊中羞涩买不起m ...
- 两个变量交换数字 不用第三个变量的情况下 int a = 5,b = 6
今天可是涨见识额 记录一下 第一种方法: a=a+bb=a-ba=a-b 第二种: b= a+(a=b)*0 一句话搞定
- Spring MVC-从零开始-view-ViewResolver
主要ViewResolver简介 InternalResourceViewResolver 将逻辑视图名解析为一个路径 BeanNameViewResolver 将逻辑视图名解析为bean的name属 ...
- Spring 梳理 - filter、interceptor、aop实现与区别 -第二篇
spring mvc中的Interceptor可以理解为是Spring MVC框架对AOP的一种实现方式.一般简单的功能又是通用的,每个请求都要去处理的,比如判断token是否失效可以使用spring ...
- java使用POI操作excel文件,实现批量导出,和导入
一.POI的定义 JAVA中操作Excel的有两种比较主流的工具包: JXL 和 POI .jxl 只能操作Excel 95, 97, 2000也即以.xls为后缀的excel.而poi可以操作Exc ...
- 主流视觉SLAM、激光SLAM总结
SLAM预备知识 SLAM for Dummies 全文总结 视觉里程计 卡尔曼滤波推导 MonoSLAM MonoSLAM:Real-Time Single Camera SLAM全文总结 PTAM ...
- 针对永久不过期的key 批量设置过期时间
问题需求: redis内存暴增,后来发现有很多设置永久不过期. 解决:查找出来之后针对前缀批量设置过期时间 (过期时间与开发沟通 保证服务不受影响) 来源于网上杨一的代码 正好解决了我遇到的问题 在这 ...
- ELK 学习笔记之 elasticsearch环境搭建
ELK概述: ElasticSearch是个开源分布式搜索引擎,它的特点有:分布式,零配置,自动发现,索引自动分片,索引副本机制,restful风格接口,多数据源,自动搜索负载等 Logstash是一 ...
- 【Java基础】让编码不再让你困惑
目录 1. ASCII编码 2. Unicode编码 3. UTF-8编码 4. UTF8.UTF16和UTF32之间的区别 5. GBK.GB2312和GB18030之间的区别 6. Java中的编 ...