1、索引:

字典得目录,便于数据查找。

原理:将列信息存储在其相关的文件,这些信息使用便于检索的方式如B-tree、哈希来存储

索引的分类:

普通所有:name,只能帮助查找

唯一索引:name,帮助查找,约束内容不能重复,null,

也可做联合唯一索引

主键索引:与唯一索引类似,但不允许null,一张表只能有一个主键

支持联合主键

组合索引:多列公共组成索引

普通多列索引(name,email):用处不大

联合唯一索引(name,email):有用

全文索引:类似对长的字段做了一个分词的操作,对中文支持不好。

常用:solr  ,lucence,sphix来做全文搜索

2、创建索引:

*普通索引:加快查找速度

验证:使用命令explain   若type 是all表示全表搜索,若为ref 表示通过索引搜索

*唯一索引:关键词unique

type =const   ,查找效率高

*联合索引:索引最左原则,

单独使用右边的并不启用索引

3、正确的使用索引:

@*like  ‘%xx’ 不走索引 like  ‘xx%’走索引

@*使用函数  :  select coun(1) from tb2 where reverse(name) = 'xxx' 不走索引,select coun(1) from tb2 where name =  reverse('xxx') 走索引

@*or  : select * from tb1 where nid = 1 or email = 'xxxx'  ,nid email都有索引才走索引

@*类型不一致:select * from tb1 where name = 'xxxx' 会走索引,select * from tb1 where name = 111 不走索引

@*!=   和 > :   不走索引,特殊的 若该列为主键则走索引,否则不走索引;;;;;其他比较的走索引

@*orderby: select email from tb1 order by name desc  不走索引; select name form tb1 order by name desc   走索引

@*组合索引最左侧走索引,eg(name,email)   name and email  走索引,name 走索引,email 不走索引

覆盖索引:所有数据都拿到叫做覆盖索引

索引合并:2个单个索引一起使用叫做索引合并

组合索引:2列做成一个索引

4、小知识:在加上limit后可在没有索引的时候可能会快速的完成查询

5、mysql 使用注意实现:

• 避免使用select *

• count(1) or count(列) 代替count(*)

• 创建表时尽量使用char代替varchar

• 表得字段顺序固定长度的字段优先

• 组合索引代替多个单列索引(经查使用多个条件查询时)

• 尽量使用短索引(否则会导致产生超大索引文件,方法在创建索引时列名标长度)

• 使用连接(join)来代替子查询(sub-Quries)

• 连表时注意条件类型要一致

• 索引散列值(重复少)不做索引,例:性别不适合

• 适度创建索引,不要过度创建

• 大批量导入导出数据时可先删除索引而后在添加索引以提高效率

6、分页的最佳方案:

select * from tb limit 200000,5;

第一种优化方案:

select * from tb1 where nid > (select nid from tb1 limit 200000,1 )  limit 5

此方案效率不高

第二种优化方案:

每页显示10条数据,供1000条

a. 上一页,下一页(使用应用传过来的nid值)

select * from tb1 where nid <9989 order by nid desc  limit 10;

b. 上一页,100 99 98 97 96 95 94 下一页

select * from tb1 where nid <9989 order by nid desc limit 10;

#9989  ...  9959

select nid form (select nid from tb1 where nid < 9989  order by nid desc limit 40) as A order by nid asc  limit 1 ;

select * from tb1 where nid < 动态最新id  order by nid desc limit 10;

7、执行计划:

语法:explain + 查询SQL

id 表示查询个数 ,id大的先执行

8、慢查询:
*配置文件(win):win my-default.ini
slow_query_log = off
long_query_time = 2
slow_query_log_file = /xxxxx/log
log_queries_not_using_indexes = off -- 记录没有使用索引的查询
查看当前配置信息:
show GLOBAL VARIABLES like '%query%'
设置:
set global slow_query_log = on;
set global long_query_time =1 ;
set global log_queries_not_using_indexes = on
*查看mysql慢日志
eg: mysqldumpslow

-s  at 需要我们关注

r  反序  a 显示全部值  g 匹配符合正则的结果  l 总时间不显示锁定时间

9、SQLAlchemy 
SQLAlchemy 是python 下的一个ORM框架

SQLAlchemy 本身无法操作数据库,必须依靠pymysql等第三插件,Dialect拥有和数据api进行交流,依据配置文件得不同调用不同得数据api从而实现对数据库得操作。
1)底层处理

eg:

MySQL-Python

    mysql+mysqldb://<user>:<password>@<host>[:<port>]/<dbname>
   
pymysql
    mysql+pymysql://<username>:<password>@<host>/<dbname>[?<options>]
   
MySQL-Connector
    mysql+mysqlconnector://<user>:<password>@<host>[:<port>]/<dbname>
   
cx_Oracle
    oracle+cx_oracle://user:pass@host:port/dbname[?key=value&key=value...]
   
更多详见:http://docs.sqlalchemy.org/en/latest/dialects/index.html
#!/usr/bin/env python
# -*- coding:utf-8 -*-
import pymysql # 创建连接
conn = pymysql.connect(host='10.10.8.12', port=3306, user='sysadmin', passwd='password01!', db='q2')
# 创建游标
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor) # 执行SQL,并返回收影响行数
# effect_row = cursor.execute("UPDATE users set name = 'john1'") effect_row = cursor.execute("insert into users(name,password) VALUES ('john33','123.123')")
conn.commit()
#cursor.lastrowid 可获取自增列的id
print(cursor.lastrowid) # u = input("pls input username>>>>")
# p = input("pls input passwd>>>>>>")
# effect_row = cursor.execute("insert into users(name,password) VALUES (%s,%s)",(u,p)) #批量插入数据:
# effect_row = cursor.executemany("insert into users(name,password) VALUES (%s,%s)",
# [('john3','john3333'),('john5','john555')])
# print(effect_row)
# 提交,不然无法保存新建或者修改的数据
# conn.commit() #查询数据
# # effect_row = cursor.execute("select * from users")
# effect_row = cursor.execute('select * from users where nid > %s ORDER BY nid DESC ',(5,))
# #fetchall--- 拿到所有的数据, fetchone 第一次执行拿到第一个数据,第二次执行拿到第二个数据,
# #cursor.scroll(2, mode='relative')可用来移动游标
#
# # result = cursor.fetchall()
# # print(result)
# result = cursor.fetchone()
# print(result)
# result = cursor.fetchone()
# print(result)
# #游标的移动,mode="relative"相对移动,mode='absolute'绝对移动
# # cursor.scroll(-1, mode='relative')
# # cursor.scroll(2, mode='relative')
# cursor.scroll(0, mode='absolute')
# result = cursor.fetchone()
# print(result)
# 关闭游标
cursor.close()
# 关闭连接
conn.close()

coding demo

day39---mysql基础三的更多相关文章

  1. 04 mysql 基础三 (进阶)

    mysql 基础三 阶段一 mysql 单表查询 1.查询所有记录 select * from department; ​ select * from student; ​ select * from ...

  2. mysql基础三(视图、触发器、函数、存储过程、事务、防注入)

    一.视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,并可以将其当作表来使用. 1.创建视图 -格式:CREATE ...

  3. mysql基础(三)——中级查询

    创建表 CREATE TABLE DEPT( DEPTNO ) PRIMARY KEY, DNAME ) , LOC ) ) ; ,'ACCOUNTING','NEW YORK'); ,'RESEAR ...

  4. MySQL 基础三 函数(聚合、字符串、时间、条件判断)

    1.聚合 其它:GROUP_CONCAT.avg.sum.count.max.min SELECT typeid,GROUP_CONCAT(goodsname) FROM `goods` GROUP ...

  5. Mysql基础(三)

    #DML语言 /* 数据操作语言 插入:insert insert into 表名(列名,...) values(值1,...); insert into 表名 set 列名=值, 列名=值,... ...

  6. MySQL基础(三)——约束

    MySQL基础(三)--约束 约束是在表上强制执行的数据校验规则,主要用于维护表中数据的完整性以及当数据之间有以来关系时,保护相关的数据不会被删除. 根据约束对列的限制,可以划分为:单列约束(只约束一 ...

  7. { MySQL基础数据类型}一 介绍 二 数值类型 三 日期类型 四 字符串类型 五 枚举类型与集合类型

    MySQL基础数据类型 阅读目录 一 介绍 二 数值类型 三 日期类型 四 字符串类型 五 枚举类型与集合类型 一 介绍 存储引擎决定了表的类型,而表内存放的数据也要有不同的类型,每种数据类型都有自己 ...

  8. Mysql基础(三):MySQL基础数据类型、完整性约束、sql_mode模式

    目录 2.MySQL基础数据类型.完整性约束.sql_mode模式 1. MySQL常用数据类型 2. 完整性约束 3. MySQL的sql_mode模式说明以及设置 2.MySQL基础数据类型.完整 ...

  9. MYSQL基础笔记(三)-表操作基础

    数据表的操作 表与字段是密不可分的. 新增数据表 Create table [if not exists] 表名( 字段名 数据类型, 字段名 数据类型, 字段n 数据类型 --最后一行不需要加逗号 ...

  10. Mysql基础代码(不断完善中)

    Mysql基础代码,不断完善中~ /* 启动MySQL */ net start mysql /* 连接与断开服务器 */ mysql -h 地址 -P 端口 -u 用户名 -p 密码 /* 跳过权限 ...

随机推荐

  1. 零基础逆向工程25_C++_02_类的成员权限_虚函数_模板

    1 类的成员权限 1.1 小结: 1.对外提供的函数或者变量,发布成public的 但不能随意改动. 2.可能会变动的函数或者变量,定义成private的 这样编译器会在使用的时候做检测. 3.只有结 ...

  2. Ubuntu 12.04搭建svn服务器【转】

    这是一个比较老旧的话题,毕竟大家现在都使用Git(http://git-scm.com/),Git在分支.代码存储.冲突.速度方面的机制都更优秀. 那我们难道还有使用svn的场景?当然,比如对Git很 ...

  3. 如何用WebIDE打开并运行CRM Fiori应用

    访问Web IDE url 在Web IDE里进行项目clone操作: https://:8080/#/admin/projects/fnf/customer/cus.crm.opportunity ...

  4. Android(java)学习笔记76:Handler用法总结 和 秒表案例

    一.Handler的定义: Handler主要接收子线程发送的数据, 并用此数据配合主线程更新UI,用来跟UI主线程交互用.比如可以用handler发送一个message,然后在handler的线程中 ...

  5. 【洛谷1337】[JSOI2004] 吊打XXX(模拟退火经典题)

    点此看题面 大致题意: 一个平面上有\(n\)个点,每个点有1个权值,现在要选择平面上的一个点,使这\(n\)个点的权值乘上到达选定点的距离之和最小. 模拟退火 我们可以用模拟退火来做这道题. 先将\ ...

  6. 【HDU4507】恨7不成妻(数位DP)

    点此看题面 大致题意: 让你求出一段区间内与\(7\)无关的数的平方和.与\(7\)无关的数指整数中任意一位不为\(7\).整数的每一位加起来的和不是\(7\)的整数倍.这个整数不是\(7\)的倍数. ...

  7. Count Numbers(矩阵快速幂)

    Count Numbers 时间限制: 8 Sec  内存限制: 128 MB提交: 43  解决: 19[提交] [状态] [讨论版] [命题人:admin] 题目描述 Now Alice want ...

  8. js转换时间戳成日期格式

    <script> function getLocalTime(nS) { return new Date(parseInt(nS) * 1000).toLocaleString().rep ...

  9. Oracle表连接学习笔记

    目录 一.表连接类型 1.1 内连接 1.2 外连接 二.表连接方法 2.1 表连接方法分类 2.2 表连接方法特性区别 @ 一.表连接类型 表连接类型可以分为:内连接.外连接,在看<收获,不止 ...

  10. C#的接口基础教程之五 实现接口

    1.显式实现接口成员 为了实现接口,类可以定义显式接口成员执行体(Explicit interface member implementations).显式接口成员执行体可以是一个方法.一个属性.一个 ...