美文网首页
Mysql必知必会笔记——下

Mysql必知必会笔记——下

作者: 丑角的晨歌 | 来源:发表于2018-08-14 20:38 被阅读0次

    操作表

    视图

    视图是虚拟的表。使用视图可以重用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必知必会笔记——下

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