Mysql必知必会笔记——下

操作表

视图

视图是虚拟的表。使用视图可以重用SQL语句,简化复杂的SQL操作,更改数据格式和表示等;创建视图后可以用与表基本相同的方式使用之,可以SELECT,过滤,排序,联结,甚至添加和更新数据(添加与更新存在某些限制)。
视图本身不包含数据,它们返回的数据是从其他表中检索出来的,在添加或更改源数据时视图将返回改变过的数据。
部署使用大量视图的应用前应该进行性能测试。

  • 与表一样,视图必须唯一命名
  • 对于可以创建的视图数目没有限制
  • 创建视图必须有足够的访问权限
  • 视图可以嵌套,可以利用从其他视图中检索数据的查询来创建视图
  • ORDER BY可以用在视图中,如果检索视图时也用了ORDER BY则会将视图中的ORDER BY覆盖
  • 视图不能索引,也不能有关联的触发器或默认值
  • 视力可以和表一起使用,比如SELECT时联结表和视图
// 创建一个名为productcustomers的视图,隐藏了一个复杂的多表查询
CREATE VIEW productcustomers AS
SELECT cust_name, cust_contact, prod_id
FROM customers, orders, orderitems
WHERE customers.cust_id = orders.cust_id
  AND orderitems.order_num = orders.order_num;

// 从视图中检索数据
SELECT cust_name, cust_contact
FROM productcustomers
WHERE prod_id = 'TNT2';

存储过程

存储过程就是为了方便以后使用而保存的一条或多条SQL语句的集合,可视为批处理,虽然它们的作用不仅限于批处理。
使用存储过程的理由:简单、安全、高性能:

//创建
CREATE PROCEDURE productpricing() 
BEGIN
  SELECT Avg(prod_price) AS priceaverage FROM products;
END;
//调用
CALL productpricing(); 
//删除
DROP PROCEDURE productpricing;

使用命令行时,如果存储过程内含有;字符,可以使用 DELIMITER临时更改语句分隔符。
存储过程可以接受参数;可以使用DECLARE语句声明变量,结合IF等实现更高级、更强的功能;
使用SHOW CREATE PROCEDURE或SHOW PROCEDURE STATUS获取存储过程的信息;

游标

触发器

触发器是Mysql在响应以下语句时自动执行的一条MySQL语句(或位于BEGIN与END之间的一组语句):DELETE、INSERT、UPDATE;
创建时应给出:1、唯一的触发器名;2、关联的表;3、应该响应的语句;4、在处理之前还是之后执行。
每个表最多支持6个触发器;单一触发器不能与多个事件或多个表关联;
触发器不能更新或覆盖,只能先删除再重新创建;
如果BEFORE触发器失败,则请求的操作不会被执行;如果BEFORE触发器或语句本身失败,AFTER触发器将不会得到执行;

CREATE TRIGGER neworder AFTER INSERT ON orders
FOR EACH ROW SELECT NEW.order_num

DROP TRIGGER newproduct;

INSERT触发器

  • INSERT触发器代码内可引用一个名为NEW的虚拟表访问被插入的行
  • BEFORE INSERT触发器中可以更新NEW中的值
  • AUTO_INCREMENT列,NEW在INSERT之前包含0,INSET后包含新的自动生成值
    DELETE触发器
  • DELETE触发器代码内可以一个名为OLD的虚拟表访问被删除的行
  • OLD中的值全为只读,不能更新
    UPDATE触发器
  • UPDATE触发器的代码内可以引用OLD访问旧的值,引用NEW访问新更新的值
  • BEFORE UPDATE触发器中,NEW中的值可以更新
  • OLD中的值全为只读,不能更新
    总结
    1、通常before用于数据的验证和净化(为了保证插入表中的数据确实是需要的数据) 也适用于update触发器。
    2、与其他DBMS相比,MySQL 5中支持的触发器相当初级,未来的MySQL版本中估计会存在一些改进和增强触发器的支持。
    3、创建触发器可能需要特殊的安全访问权限,但是触发器的执行时自动的,如果insert,update,或者delete语句能够执行,则相关的触发器也能执行。
    4、用触发器来保证数据的一致性(大小写,格式等)。在触发器中执行这种类型的处理的优点就是它总是进行这种处理,而且透明的进行,与客户机应用无关。
    5、触发器的一种非常有意义的使用就是创建审计跟踪。使用触发器,把更改(如果需要,甚至还有之前和之后的状态)记录到另外一个表是非常容易的。
    6、MySQL触发器不支持call语句,无法从触发器内调用存储过程。

事务

保证成批的SQL操作要么完全执行,要么完全不执行;
MyISAM不支持事务,InnoDB支持;
START TRANSACTION开始一个事务;
ROLLBACK回滚事务;
COMMIT提交事务;
SAVEPOINT创建保留点,可以回滚到该处:ROLLBACK TO ...
默认的MySQL行为是自动提交所有更改,可以使MySQL不自动提交更改(针对每个连接,而不是服务器):SET autocommit = 0;

你可能感兴趣的:(Mysql必知必会笔记——下)