美文网首页
数据库之索引,视图,存储过程(函数)和触发器

数据库之索引,视图,存储过程(函数)和触发器

作者: Apple_Boy | 来源:发表于2019-07-05 15:22 被阅读0次

索引

定义:索引是由数据库表中一列或者多列组合而成,其作用是提高对表中数据的查询速度;

类似于图书的目录,方便快速定位,寻找指定的内容;

分类:

1,普通索引:这类索引可以创建在任何数据类型中;

2,唯一性索引:使用 UNIQUE 参数可以设置,在创建唯一性索引时,限制该索引的值必须是唯一的;

3,全文索引:使用 FULLTEXT 参数可以设置,全文索引只能创建在 CHAR,VARCHAR,TEXT 类型的字段上。主要作用就是提高查询较大字符串类型的速度;只有 MyISAM 引擎支持该索引,Mysql 默认引擎不支持;

4,单列索引:在表中可以给单个字段创建索引,单列索引可以是普通索引,也可以是唯一性索引,还可以是全文索引;

5,多列索引:多列索引是在表的多个字段上创建一个索引;

6,空间索引:使用 SPATIAL 参数可以设置空间索引。空间索引只能建立在空间数据类型上,这样可以提高系统获取空间数据的效率;只有 MyISAM 引擎支持该索引,Mysql 默认引擎不支持;

目的:就是为了提高数据的检索速度。

数据库的索引类似于书籍的索引。在书籍中,索引允许用户不必翻阅完整个书就能迅速地找到所需要的信息。在数据库中,索引也允许数据库程序迅速地找到表中的数据,而不必扫描整个数据库.

索引的优点:1.创建唯一性索引,保证数据库表中每一行数据的唯一性  2.大大加快数据的检索速度,这也是创建索引的最主要的原因  3.减少磁盘IO(向字典一样可以直接定位)

索引的缺点:1.创建索引和维护索引要耗费时间,这种时间随着数据量的增加而增加  2.索引需要占用额外的物理空间  3.当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,降低了数据的维护速度

视图

1,视图是一种虚拟的表,是从数据库中一个或者多个表中导出来的表。

2,数据库中只存放了视图的定义,而并没有存放视图中的数据,这些数据存放在原来的表中。删除视图是指删除数据库中已存在的视图。删除视图时,只能删除视图的定义,不会删除数据;

3,使用视图查询数据时,数据库系统会从原来的表中取出对应的数据。

作用:

1,使操作简便化;

2,增加数据的安全性;

3,提高表的逻辑独立性;

提供了另外一种级别的表安全性:隐藏了一些关键的字段;简化的用户的SQL命令;隔离基表结构的改变

存储过程(函数)

可以包含逻辑判断的sql语句集合。是经过预编译,存在于数据库中。通过调用指定存储过程的名字(可有参,可无参)来执行。

存储过程和函数是在数据库中定义一些 SQL 语句的集合,然后直接调用这些存储过程和函数来执行已经定义好的 SQL 语句。存储过程和函数可以避免开发人员重复的编写相同的 SQL 语句。而且,存储过程和函数是在 MySQL服务器中存储和执行的,可以减少客户端和服务器端的数据传输;

优点:

简化了复杂的业务逻辑,根据需要可重复使用;

屏蔽了底层细节,不暴露表信息即可完成操作;

降低网络的通信量,多条语句可以封装成一个存储过程来执行;

设置访问权限来提高安全性;

提高执行效率,因为它是预编译以及存储在数据库中。

缺点:

可移植性差,相同的存储过程并不能跨多个数据库进行操作;

大量使用存储过程后,首先会使服务器压力增大,而且维护难度逐渐增加。

触发器

触发器(TRIGGER)是由事件来触发某个操作。这些事件包括 INSERT 语句、UPDATE 语句和 DELETE 语句。

当数据库系统执行这些事件时,就会激活触发器执行相应的操作。

具体举例:

1、 在一个表中定义的语句级的触发器,当这个表被删除时,程序就会自动执行触发器里面定义的操作过程。这个就是删除表的操作就是触发器执行的条件了。

2、 在一个表中定义了行级的触发器,那当这个表中一行数据发生变化的时候,比如删除了一行记录,那触发器也会被自动执行了。

如:在发表日志成功后自动推送到好友的朋友圈

相关文章

  • 数据库索引、触发器、存储过程、视图

    1 索引2 触发器3 存储过程和函数4 视图5 基本的数据库建表语句练习 1 索引 (1)基本概念 https:/...

  • Oracle学习笔记(六)

    数据库对象:表、视图、索引、序列、同义词、存储过程、存储函数、包头、包体。 存储过程和存储函数是指在数据库中提供所...

  • MySQL 视图和存储程序

    MySQL 视图和存储程序 存储程序:存储函数、存储过程、触发器和事件的总称。 存储例程:存储函数+存储过程。 触...

  • MySql存储引擎

    数据库对象 ​ 存储,管理和使用数据的不同结构形式,如:表、视图、存储过程、函数、触发器、事件等。 数...

  • 数据库对象之视图,存储过程,触发器

    数据库对象就是数据库的组成部分,包括表,函数,视图,存储过程,触发器 等等。。。表和函数都好理解,就是数据库表和数...

  • SQL基础

    1.课程体系 基础阶段:增删改查,视图,触发器,函数,存储过程等 优化阶段:提高数据库效率,如索引,分表等 部署阶...

  • 创建和维护表

    数据库对象:表,视图,约束,索引,同义词,触发器,存储过程,函数等。 1.创建表 使用子查询语法创建表 2.修改表...

  • 创建和维护表

    数据库对象:表,视图,约束,索引,同义词,触发器,存储过程,函数等。 1.创建表 使用子查询语法创建表 2.修改表...

  • 2019-07-08

    数据库 MySQL数据库的基本操作(增删改查)高级操作视图备份和还原事务触发器函数存储过程 什么是数据库?数据库(...

  • PL/SQL之存储过程

    存储过程、存储函数和触发器 存储过程和存储函数定义:指存储在数据库中供所有用户程序调用的子程序叫存储过程或存储函数...

网友评论

      本文标题:数据库之索引,视图,存储过程(函数)和触发器

      本文链接:https://www.haomeiwen.com/subject/xnkehctx.html