MySQL原生语句个人补漏
# insert插入
insert into table_name (field1,field2...fieldn) **values** (value1,value2...valuen);所有列需添加可不写列名。
多条插入:insert into table_name (field1,field2...fieldn) **values** (value1,value2...valuen), (valuea,valueb...valuen), (valueA,valueB...valueN);
# where子句
select * from table_name where **BINARY** field = 'php / PHP';where子句字符串比较不区分大小写,要求区分时引入BINARY关键字。
# update更新
update table_name set field1 = new value1, field2 = new value2, ... (+ where);
update table_name set field1 = **REPLACE**(field1, 'old_string', 'new_string')(+ where);替换字段中的字符。
# delete删除
delete from table_name where field = value;不加where,表数据全灭。
# union组合结果集
select value from table_name1(+ where) union all / distinct(default) select value from table_name2(+ where) orderby value;union组合两个以上的结果集输出新集,关键字默认distinct去重,为空不写,关键字all取全部数据包括重复。
# where,having
某种程度where与having作用相同,区别where筛选表字段;having对筛选字段进行再筛选,且常与聚合函数出没。
# join连接
inner join返回字段匹配的结果集(交集);left join返回左表所有记录和字段匹配的结果集;right join返回右表所有记录和字段匹配的结果集。
# sql执行顺序
写:select[distinct] - from - join - on - where - group by - having - union - order by - limit[offset]
执行:from - on - join - where - group by - having - select[distinct] - union - order by
# NULL
select * from table_name where field IS NULL; IS NOT NULL非null值。
# 索引
常用类型;primary key,unique,index,fulltext index,组合索引;
创建:create index indexname on table_name(field); alter table table_name add index indexname(field);
删除:drop index indexname on table_name; alter table table_name drop index indexname;
# and,or连接
and,or执行等级并列,多个or只执行首个,所以and出现在or之后一般不生效,二者同时应用时应写为“(or语句)”;
# explain执行分析
explain模拟执行SQL语句,分析查询语句和性能瓶颈;
## 执行计划包含信息:
- id:查询序列号,执行顺序由上到下;如果是子查询,id会递增,id值与执行优先级成正比;相同id遵循由上到下原则;
- select_type:
- --simple简单子查询,不含子查询或union;
- --primary包含复杂的子部分,外部被标记为primary;
- --subquery,select或where列表包含了子查询;
- --derived,from列表中的子查询标记为derived(衍生),结果存放临时表;
- --union,通过union连接多个结果,第二个select后的为union;
- table:当前执行表
- **type**:查询类型
- --**最佳到最差**:system - const - eq_ref - ref - range - index - all;一般至少达到range,最好达到ref,避免all;
- --system,表只有一行记录(等同于系统表,const类型特例,忽略不计);
- --const,通过索引一次找到;
- --eq_ref,唯一性索引扫描,对于每个索引键,表只有一条记录匹配(主键或唯一键索引);
- --ref,非唯一性索引,所有匹配索引值的行全部读取;
- --range,检索给定范围的行,使用一个索引选择行
- --index,与all相同(读全表),但index只遍历索引树,索引文件比数据文件小;
- --all,数据文件查全表;
- possible_keys:可能应用的索引;其中会出现已有索引并按优劣顺序排列,开发者编写测试sql的时候要注意,若是有效的索引应让这些索引(按顺序)尽量生效;
- **key**:引用的索引,没选择索引为NULL;
- key_len:索引长度,越短越好;
- ref:显示使用哪个列或常数与key一起执行;
- **rows**:得到结果集需查询的行数,越少越好(多行相乘可以估算要处理的行数);
- Extra:解决查询的详情;
- --**Using filesort**,mysql使用外部索引排序,而不是按照表内索引顺序读取;
- --**Using temporary**,使用了临时表保存中间结果,对查询结果排序时使用了临时表,常见order by,group by;
- --Using index,相应select操作使用了覆盖索引,避免了访问表的数据行,效率很高。如果同时出现using where表示索引被用来执行索引键值的查找,没出现using where表示读取动作;
- --Using where,使用where过滤;
- --Using join buffer,使用了连接缓存;
- --impossible where,where子句值为false,不能用来获取任何元组;
- --select tables optimized away,在没有GROUPBY子句的情况下,基于索引优化MIN/MAX操作或者对于MyISAM存储引擎优化COUNT(*)操作,不必等到执行阶段再进行计算,查询执行计划生成的阶段即完成优化;
- --distinct,优化distinct操作,找到第一匹配的元组后即停止查找同样值的动作;
MySQL原生语句个人补漏的更多相关文章
- mysql原生语句基础知识
要操作数据库,首先要登录mysql: *mysql -u root -p 密码 创建数据库: *create database Runoob(数据库名); 删除数据库: *drop database ...
- 手撸Mysql原生语句--增删改查
mysql数据库的增删改查有以下的几种的情况, 1.DDL语句 数据库定义语言: 数据库.表.视图.索引.存储过程,例如CREATE DROP ALTER SHOW 2.DML语句 数据库操纵语言: ...
- 手撸Mysql原生语句--多表
在开始之前,我们需要建立表,做建表和数据的准备的工作. 1.建表 create table department( id int, name varchar(20) ); create table e ...
- 终于不再在懵逼mysql原生语句,orm超级登场
import sqlalchemy from sqlalchemy.ext.declarative import declarative_base from sqlalchemy import cre ...
- 手撸Mysql原生语句--单表
select from where group by having order by limit 上面的所有操作是有执行的优先级的顺序的,我们将执行的过程可以总结为下面所示的七个步骤. 1.找到表:f ...
- Mysql存储之原生语句操作(pymysql)
Mysql存储之原生语句操作(pymysql) 关系型数据库是基于关系模型的数据库,而关系模型是通过二维表时实现的,于是构成了行列的表结构. 表可以看作是某个实体的集合,而实体之间存在联系,这个就需要 ...
- PHP数据库操作:从MySQL原生API到PDO
本文将举详细例子向大家展示PHP是如何使用MySQL原生API.MySQLi面向过程.MySQLi面向对象.PDO操作MySQL数据库的. 为了后面的测试,先建立数据库表test.包含表名user,s ...
- MySQL原生API、MySQLi面向过程、MySQLi面向对象、PDO操作MySQL
[转载]http://www.cnblogs.com/52fhy/p/5352304.html 本文将举详细例子向大家展示PHP是如何使用MySQL原生API.MySQLi面向过程.MySQLi面向对 ...
- [转]MySQL查询语句执行过程详解
Mysql查询语句执行原理 数据库查询语句如何执行?语法分析:首先进行语法分析,对使用sql表示的查询进行语法分析,生成查询语法分析树.语义检查:检查sql中所涉及的对象以及是否在数据库中存在,用户是 ...
随机推荐
- Android Fragment功能的例子
实现的功能很简单,也是最基本的,上下分别是两个Fragment,上面的Fragment中是一个listview,当点击item时,下面的Fragment显示对应的文字详细信息 具体的实现步骤如下:①创 ...
- redis 事务、Jedis事务处理流程
127.0.0.1:6379> multiOK127.0.0.1:6379> sadd myset a b cQUEUED ——>并没有执行,排队等待127.0.0.1:6379& ...
- web前端要学哪些?
本来是学java还有jsp这些东西的,后来毕业了就去找了个前端的工作:一开始就接触 nodejs+express+Angularjs+mongodb这些东西.不知道学了这些东西做前端够不够用.现在也就 ...
- Docker 监控之 SaaS 解决方案
过去的一年中,关于 Docker 的话题从未断过,而如今,从尝试 Docker 到最终决定使用 Docker 的转化率依然在逐步升高,关于 Docker 的讨论更是有增无减.另一方面,大家的注意力也渐 ...
- zabbix系列之七——安装后配置二Userparameters
1User parameters(用户自定义参数) 1.1配置 描述 详细 备注 简介 1执行zabbix中未预定义的agent check时使用 配置 1) zabbix agent的配置文件 ...
- 使用Membership,您的登录尝试不成功。请重试"的解决方法
提示信息是标准Login控件产生的,打开数据库,检查aspnet_Membership表,检查IsLockedOut字段的值是否为False, 如果为True,表示这个用户锁定了,把它改成False即 ...
- 转:spring 的控制反转
文章一,原文地址:http://blog.sina.com.cn/s/blog_63804f6f0100kfx0.html 控制反转: IoC(Inversion of Control,控 ...
- 制作 OS X El Capitan 启动盘
制作 OS X El Capitan 启动盘 1. 下载系统盘的dmg格式 2. 直到出现了 3. 在命令行中找到 Install OS X El Capitan.app 4. 格式化你的U盘(U盘名 ...
- UNIX高级环境编程(3)Files And Directories - stat函数,文件类型,和各种ID
在前面的两篇,我们了解了IO操作的一些基本操作函数,包括open.read和write. 在本篇我们来学习一下文件系统的其他特性和一个文件的属性,涉及的函数功能包括: 查看文件的所有属性: 改变文件所 ...
- IntelliJ IDEA2017/2018 激活方法 破解补丁激活(亲测可用)(注册码方法以和谐)
IntelliJ IDEA2017 激活方法(注册码方法以和谐): 搭建自己的授权服务器,对大佬来说也很简单,我作为菜鸟就不说了,网上有教程. 我主要说第二种,现在,直接写入注册码,是不能成功激活的( ...