初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

202 篇文章 8 订阅
11 篇文章 0 订阅

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

初识MySQL

MySQL是一个开放源代码的数据库管理系统(DBMS), 它是由MySQL AB公司开发、发布并支持的。MySQL是一个跨平台的开源关系型数据库管理系统,广泛地应用在Internet上的中小型网站开发中。本章主要介绍数据库的基础知识,通过本章的学习,读者可以了解数据库的基本概念、数据库的构成和MySQL的基本知识。

一、数据库基础

数据库由一批数据构成有序的集合,这些数据被存放在结构化的数据表里。数据表之间相互关联,反映了客观事物间的本质联系。数据库系统提供对数据的安全控制和完整性控制。本即将介绍数据库中的一 些基本概念,包括:数据库的定义、数据表的定义和数据类型等。

1.1什么是数据库

数据库的概念诞生于60年前,随着信息技术和市场的快速发展,数据库技术层出不穷,随着应用的拓展和深入,数据库的数量和规模越来越大,其诞生和发展给计算机信息管理带来了一场巨大的革命。

数据库的发展大致划分为如下几个阶段:人工管理阶段、文件系统阶段、数据库系统阶段、高级数据库阶段。其种类大概有3种:层次式数据库、网络式数据库和关系式数据库。不同种类的数据库按不同的数据结构来联系和组织。

对于数据库的概念,没有一个完全固定的定义,随着数据库历史的发展,定义的内容也有很大的差异,其中- -种比较普遍的观点认为,数据库(DataBase, DB)是一一个长期存储在计算机内的、有组织的、有共享的、统- -管理的数据集合。它是一个按数据结构来存储和管理数据的计算机软件系统,即数据库包含两层含义:保管数据的“仓库"”,以及数据管理的方法和技术。

数据库的特点包括:实现数据共享,减少数据冗余;采用特定的数据类型;具有较高的数据独立性;具有统一的数据控制功能。

1.2表

在关系数据库中,数据库表是--系列二维数组的集合,用来存储数据和操作数据的逻辑结构。它由纵向的列和横向的行组成,行被称为记录,是组织数据的单位;列被称为字段,每一列表示记录的-一个属性,都有相应的描述信息,如数据类型、数据宽度等。

例如-一个有关作者信息的名为authors的表中,每个列包含所有作者的某个特定类型的信息,比如“姓名”,而每行则包含了某个特定作者的所有信息:编号、姓名、性别、专业,如下图所示。

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

authors表的结构与记录

1.3数据类型

数据类型决定了数据在计算机中的存储格式,代表不同的信息类型。常用的数据类型有:整数数据类型、浮点数数据类型、精确小数类型、二进制数据类型、日期/时间数据类型、字符串数据类型。

表中的每一一个字 段就是某种指定数据类型,比如上图中“编号”字段为整数数据,“性别”字段为字符型数据。

1.4主键

主键(Primary Key)又称主码,用于唯一的标识表中的每一 条记录。 可以定义表中的一-列或多列为主键,主键列上不能有两行相同的值,也不能为空值。假如,定义authors表,该表给每一-个作 者分配-一个“作者编号”,该编号作为数据表的主键,如果出现相同的值,将提示错误,系统不能确定查询的究竟是哪一条记录; 如果把作者的“姓名”作为主键,则不能出现重复的名字,这与现实中的情况不相符合,因此“姓名”字段不适合作为主键。

二、MySQL触发器

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

MySQL的触发器和存储过程一样,都是嵌入到MySQL的一段程序。 触发器是由事件来触发某个操作,这些事件包括INSERT、UPDATAE和DELETE语句。如果定义了触发程序,当数据库执行这些语句的时候就会激发触发器执行相应的操作,触发程序是与表有关的命名数据库对象,当表上出现特定事件时,将激活该对象。本章通过实例来介绍触发器的含义、如何创建触发器、查看触发器、触发器的使用方法以及如何删除触发器。

2.1创建触发器

触发器(trigger)是个特殊的存储过程,不同的是,执行存储过程要使用CALL语句来调用,而触发器的执行不需要使用CALL语句来调用,也不需要手工启动,只要当一个预定义的事件发生的时候,就会被MySQL自动调用。比如当对fruits表进行操作(INSERT. DELETE或UPDATE)时就会激活它执行。

触发器可以查询其他表,而且可以包含复杂的SQL语句。它们主要用于满足复杂的业务规则或要求。例如:可以根据客户当前的账户状态,控制是否允许插入新订单。本节将介绍如何创建触发器。

创建只有一个执行语句的触发器

创建一个触发器的语法如下:

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

其中trigger_ name标识触发器名称,用户自行指定; trigger_ time 标识触发时机,可以指定为before或after; trigger_ event 标识触发事件包括INSERT UPDATE和DELETE; tbl_ name标识建立触发器的表名,即在哪张表上建立触发器; trigger_ stmt 是触发器执行语句。

创建一个单执行语句的触发器,代码如下:

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

首先创建一个account表,表中有两个字段,分别为: acct_ num 字段(定义为int类型),amount字段(定义成浮点类型) ;其次创建- -个名为ins_ sum的触发器,触发的条件是向数据表account插入数据之前,对新插入的amount字段值进行求和计算。

代码执行如下:

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

首先创建-一个account表,在向表account插入数据之前,计算所有新插入的account表的amount值之和,触发器的名称为ins_ sum, 条件是在向表插入数据之前触发。

创建有多个执行语句的触发器

创建多个执行语句的触发器的语法如下:

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

其中trigger_ _name 标识触发器的名称,用户自行指定; trigger_ time标识触发时机,可以指定为before或after; trigger_ event 标识触发事件,包括INSERT、UPDATE和DELETE;tbl_ name标识建立触发器的表名,即在哪张表上建立触发器;触发器程序可以使用BEGIN和

END作为开始和结束,中间包含多条语句。

创建一个包含多个执行语句的触发器,代码如下:

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

上面的代码是创建了-个名为testref 的触发器,这个触发器的触发条件是在向表testl插入数据前执行触发器的语句,具体执行的代码如下:

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

那么四个表中的数据如下

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

执行结果显示,在向表test1插入记录的时候,test2、 test3、 test4 都发生了变化。从这个例子看INSERT触发了触发器,向test2中插入了test1中的值,删除了test3 中相同的内容,同时更新了test4 中的b4,即与插入的值相同的个数。

2.2查看触发器

查看触发器是指查看数据库中已存在的触发器的定义、状态和语法信息等。可以通过命令来查看已经创建的触发器。本节将介绍两种查看触发器的方法,分别是: SHOW TRIGGERS 和在triggers表中查看触发器信息。

SHOW TRIGGERS语句查看触发器信息

通过SHOW TRIGGERS查看触发器的语句如下:

SHOW TRIGGERS;

通过SHOW TRIGGERS命令查看一个触发器,代码如下:

SHOW TRIGGERS;

创建一个简单的触发器,名称为trig_update,每次向account表更新数据之后都会向名称为myevent的数据表中插入一条记录,数据表myevent定义如下:

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

创建触发器的执行代码如下:

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

使用SHOW TRIGGERS命令查看触发器:

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

可以看到,信息显示比较混乱。如果在SHOW TRIGGERS命令的后面添加上‘\G’,显示信息会比较有条理,执行情况如下:

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

Trigger表示触发器的名称在这里两个触发器的名称分别为ins_ sum 和trig_ update; Event表示激活触发器的事件这里的两个触发事件为插入操作INSERT和更新操作UPDATE; Table表示激活触发器的操作对象表,这里都为account表; Timing 表示触发器触发的时间,分别为插入操作之前(BEFORE)和更新操作之后(AFTER) ; Statement 表示触发器执行的操作,还有一些其他信息,比如SQL的模式、触发器的定义账户和字符集等,这里不再一一介绍。

提示:SHOW TRIGGERS语句查看当前创建的所有触发器信息,在触发器较少的情况下,使用该语句会很方便。如果要查看特定触发器的信息,可以直接从informnation_ schema 数据库中的triggers表中查找。在下节内容中,将介绍这种方法。

在triggers表中查看触发器信息

在MySQL中所有触发器的定义都存在INFORMATION_ SCHEMA数据库的TRIGGERS表格中,可以通过查询命令SELECT来查看,具体的语法如下:

SELECT*EROM INFORMATION_SCHEMA. TRIGGERS WHERE condition;

通过SELECT命令查看触发器,代码如下:

SELECT*FROM INFORMATION_SCHEMA. TRIGGERS WHERE TRIGGER_ NAME= 'trig_ update'\G

上述的命令是通过WHERE来指定查看特定名称的触发器,下面是指定触发器名称的执行情况:

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

从上面的执行结果可以得到: TRIGGER_ SCHEMA表示触发器所在的数据库;TRIGGER_ NAME后面是触发器的名称; EVENT_ OBJECT _TABLE表示在哪个数据表上触发ACTION_ STATEMENT表示触发器触发的时候执行的具体操作ACTION_ ORIENTATION是ROW,表示在每条记录上都触发; ACTION_ TIMING表示触发的时刻是AFTER,剩下的是和系统相关的信息。

也可以不指定触发器名称,这样将查看所有的触发器,命令如下:

SELECT*FROM INFORMATION_SCHEMA.TRIGGERS \G

这个命令会显示这个TRIGGERS表中所有的触发器信息。

2.3触发器的使用

触发程序是与表有关的命名数据库对象,当表上出现特定事件时,将激活该对象。在某些触发程序的用法中,可用于检查插入到表中的值,或对更新涉及的值进行计算。

触发程序与表相关,当对表执行INSERT. DELETE或UPDATE语句时,将激活触发程.序。可以将触发程序设置为在执行语句之前或之后激活。例如,可以在从表中删除每一-行之前,或在更新每--行之后激活触发程序。

创建一个在account表插入记录之后,更新myevent数据表的触发器,代码如下:

CREATE TRIGGER trig_ insert AFTER INSERT ON account
FOR EACH ROW INSERT INTO myevent VALUES (2, 'after insert') ;

上面的代码创建了一个trig_insert的触发器在向表account插入数据之后会向表myevent插入一组数据,代码执行如下:

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

从执行的结果来看,是创建了一个名称为trig insert 的触发器,它是在向account 插入记录之后进行触发,执行的操作是向表myevent插入一 条记录。

2.4删除触发器

使用DROP TRIGGER语句可以删除MySQL中已经定义的触发器,删除触发器语句基本语法格式如下:

DROP TRIGGER [schema_name. ]trigger_name

其中,schema_ name表示数据库名称,是可选的。如果省略了schema, 将从当前数据库中舍弃触发程序;trigger_name是要删除的触发器的名称。

删除一个触发器,代码如下:

DROP TRIGGER test. ins;

上面的代码中test是触发器所在的数据库,ins是一个触发器的名称。代码执行如下:

2.5综合案例——触发器的使用

本节介绍了MySQL数据库触发器的定义和作用、创建触发器、查看触发器、使用触发器和删除触发器等内容。创建触发器和使用触发器是本章的重点内容。在创建触发器的时候一定要弄清楚触发器的结构,在使用触发器的时候,要清楚触发器触发的时间(BEFORE或AFTER)和触发的条件(INSERT. DELETE或UPDATE)。在创建触发器后,要清楚怎么修改触发器。

1.案例目的

掌握触发器的创建和调用方法。

下面是创建触发器的实例,每更新一次persons表的num字段后,都要更新sales表对应的sum字段。

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

persons表结构

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

sales 表结构

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

persons 表内容

2.案例操作过程

步骤1:创建一个业务统计表persons

创建一个业务统计表persons,代码如下:

CREATE TABLE persons (name VARCHAR(40),num int) ;

步骤2:创建一个销售额表sales

创建一个销售额表sales,代码如下:

CREATE TABLE sales (name VARCHAR(40) ,sum int) ;

步骤3:创建一个触发器

创建一个触发器,在更新过persons表的num字段后,更新sales表的sum字段,代码如下:

CREATE TRIGGER num_ sum AFTER INSERT ON persons
FOR EACH ROW INSERT INTO sales VALUES (NEW. name, 7*NEW. num) ;

步骤4:向persons表中插入记录

插入新记录后,更新销售额表

INSERT INTO persons VALUES (' xiaoxiao',20) , ( 'xiaohua',69) ;

执行的过程如下:

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

初识数据库,零基础如何学习MySQL,MySQL触发器简介及使用

 

从执行的结果来看,在persons表插入记录之后,num_ sum触发器计算插入到persons表中的数据,并将结果插入到sales表中相应的位置。

解疑

疑问1 :使用触发器时须特别注意。

在使用触发器的时候需要注意,对于相同的表,相同的事件只能创建一个触发器,比如对表account创建了一个BEFORE INSERT触发器,那么如果对表account再次创建一个BEFOREINSERT触发器,MySQL将会报错,此时,只可以在表account.上创建AFTER INSERT或者BEFOREUPDATE类型的触发器。灵活地运用触发器将为操作省去很多麻烦。

疑问2 :及时删除不再需要的触发器。

触发器定义之后,每次执行触发事件,都会激活触发器并执行触发器中的语句。如果需求发生变化,而触发器没有进行相应的改变或者删除,则触发器仍然会执行旧的语句,从而会影响新的数据的完整性。因此,要将不再使用的触发器及时删除。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值