标签:params 格式 组合索引 分隔符 空值 nod 语法 date mail
MySQL官方对索引的定义为:索引(index)是帮助mysql搞笑获取数据的数据结构(有序)。在数据之外,数据库系统还维护者满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构上实现高级查找算法,这种歌数据结构就是索引。
左边是数据表,一共两列七条记录,最左边的是数据记录的物理地址(注意逻辑上相邻的记录在磁盘上并不是一定物理相邻的)。为了加快Col2的查找,可以维护一个右边所示的二叉查找树,每个节点包含索引键值和一个指向对应数据记录物理地址的指针,这样就可以运用二叉查找快速获取到响应数据。
一般来说索引本身也很大,不可能全部存储在内存中,因此索引往往以索引文件的形式存储在磁盘上。索引是数据库中用来提高性能的最常用的工具。
优势:
劣势:
索引是在MySQL的存储引擎层中实现的,而不是在服务器层实现的。所以每种存储引擎的索引都不一定完全相同, 也不是所有的存储引擎都支持所有的索引类型的。MySQL目前提供了以下4种索引:
平常所说的索引,如果没有特别指明,都是指B+树(多路搜索树,并不一定是二叉的)结构组织的索引。其中聚集索引、复合索引、前缀索引、唯一索引默认都是使用B+tree索引,统称为索引
以5叉BTree为例,key的数量:公式推导[ceil(m/2)-1] <= n <= m-1。所以 2 <= n <=4 。当n>4时,中间节点分裂到 父节点,两边节点分裂。
B+Tree为BTree的变种,B+Tree与BTree的区别为:
由于B+Tree只有叶子节点保存key信息,查询任何key都要从root走到叶子。所以B+Tree的查询效率更加稳定。
MySql索引数据结构对经典的B+Tree进行了优化。在原B+Tree的基础上,增加一个指向相邻叶子节点的链表指针,就形成了带有顺序指针的B+Tree,提高区间访问的性能。
创建索引
create index index_name on table_name(index_col_name,...)
show index from table_name
drop index index_name on table_name
# 1、添加一个主键,这意味着索引值必须是唯一的,且不能为NULL alter table tb_name add primary key(column_list); # 2、这条语句创建索引的值必须是唯一的(除了NULL外,NULL可能会出现多次) alter table tb_name add unique index_name(column_list); # 3、添加普通索引, 索引值可以出现多次。 alter table tb_name add index index_name(column_list); # 4、该语句指定了索引为FULLTEXT, 用于全文索引 alter table tb_name add fulltext index_name(column_list);
索引的设计可以遵循一些已有的原则,创建索引的时候请尽量考虑符合这些原则,便于提升索引的使用效率,更高 效的使用索引。
利用最左前缀,N个列组合而成的组合索引,那么相当于是创建了N个索引,如果查询时where子句中使用了 组成该索引的前几个字段,那么这条查询SQL可以利用组合索引来提升查询效率。
# 创建复合索引: CREATE INDEX idx_name_email_status ON tb_seller(NAME,email,STATUS); # 就相当于对name 创建索引 ; # 对name,email 创建了索引 ; # 对name , email, status 创建了索引
视图(View)是一种虚拟存在的表。视图并不在数据库中实际存在,行和列数据来自定义视图的查询中使用的表, 并且是在使用视图时动态生成的。通俗的讲,视图就是一条SELECT语句执行后返回的结果集。所以我们在创建视图的时候,主要的工作就落在创建这条SQL查询语句上。
视图相对于普通的表的优势主要包括以下几项。
# 创建视图 create or replace view view_name as "select_statement"(select SQL语句) # 修改视图 alter view view_name as "select_statement"
从 MySQL 5.1 版本开始,使用 SHOW TABLES 命令的时候不仅显示表的名字,同时也会显示视图的名字,而不存在单独显示视图的 SHOW VIEWS 命令。
同样,在使用 SHOW TABLE STATUS 命令的时候,不但可以显示表的信息,同时也可以显示视图的信息。
如果需要查询某个视图的定义,可以使用 SHOW CREATE VIEW 命令进行查看
存储过程和函数是 事先经过编译并存储在数据库中的一段 SQL 语句的集合,调用存储过程和函数可以简化应用开 发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的。
存储过程和函数的区别在于函数必须有返回值,而存储过程没有。
delimeter:
- 该关键字用来声明SQL语句的分隔符 , 告诉 MySQL 解释器,该段命令是否已经结束了,mysql是否可以执行了。 默认情况下,delimiter是分号;。在命令行客户端中,如果有一行命令以分号结束,那么回车后,mysql将会执行该 命令。
调用存储过程
call procedure_name()
-- 查询db_name数据库中的所有的存储过程 select name from mysql.proc where db=‘db_name‘; -- 查询存储过程的状态信息 show procedure status; -- 查询某个存储过程的定义 show create procedure test.pro_test1\G;
语法结构:
调用存储函数:
select function_name()
触发器是与表有关的数据库对象,指在 insert/update/delete 之前或之后,触发并执行触发器中定义的SQL语句集合。触发器的这种特性可以协助应用在数据库端确保数据的完整性 , 日志记录 , 数据校验等操作 。
使用别名 OLD 和 NEW 来引用触发器中发生变化的记录内容,这与其他的数据库是相似的。现在触发器还只支持 行级触发,不支持语句级触发。
触发器类型 | new和old的使用 |
insert型触发器 | new表示将要或者已经新增的数据 |
update型触发器 | old表示修改之前的数据,new表示将要或已经修改后的数据 |
delete型触发器 | old表示将要或者已经删除的数据 |
create trigger trigger_name before/after insert/update/delete on table_name -- 指定表 on each row -- 行级触发器 begin trigger_stmt; end;
例如:insert型触发器,完成插入数据时的日志记录
create trigger emp_logs_insert_trigger after insert on emp for each row begin insert into emp_logs (id,operation,operate_time,operate_id,operate_params) values(null,‘insert‘,now(),new.id,concat(‘插入后(id:‘,new.id,‘, name:‘,new.name,‘, age:‘,new.age,‘, salary:‘,new.salary,‘)‘)); end $
show triggers;
标签:params 格式 组合索引 分隔符 空值 nod 语法 date mail
原文地址:https://www.cnblogs.com/yycnblog/p/13907068.html