MySQL(二)

來源:互聯網
上載者:User

標籤:傳回值   lex   log   alt   handle   刪除   部落格   web   call   

上一篇文章講的是mysql的基本操作,這一篇會有一點難以理解,本節主要內容mysql視圖,預存程序,函數,事務,觸發器,以及動態執行sql

視圖view

視圖是一個虛擬表,其內容由查詢定義。同真實的表一樣,視圖包含一系列帶有名稱的列和行資料。但是,視圖並不在資料庫中以儲存的資料值集形式存在。行和列資料來自由定義視圖的查詢所引用的表,並且在引用視圖時動態產生。對其中所引用的基礎資料表來說,視圖的作用類似於篩選。定義視圖的篩選可以來自當前或其它資料庫的一個或多個表,或者其它視圖。通過視圖進行查詢沒有任何限制,通過它們進行資料修改時的限制也很少。視圖是儲存在資料庫中的查詢的SQL 陳述式,它主要出於兩種原因:安全原因, 視圖可以隱藏一些資料。

1、建立視圖

--格式:CREATE VIEW 視圖名稱 AS  SQL語句CREATE VIEW v1 AS SELET nid, name FROM tab1 WHERE nid > 4

2、刪除視圖

--格式:DROP VIEW 視圖名稱DROP VIEW v1

3、修改視圖

-- 格式:ALTER VIEW 視圖名稱 AS SQL語句ALTER VIEW v1 ASSELET A.nid,B. NAME FROM tab1LEFT JOIN B ON A.id = B.nidLEFT JOIN C ON A.id = C.nidWHERE tab1.id > 2

也就只是改了把create改成alter,中間的語句更換了。

4、使用視圖

使用視圖時,將其當作表進行操作即可,由於視圖是虛擬表,所以無法使用其對真實表進行建立、更新和刪除操作,僅能做查詢用。

select * from v1
預存程序procedure

1、我們為什麼要用預存程序呢 ?

我們都知道應用程式分為兩種,一種是基於web,一種是基於案頭,他們都和資料庫進行互動來完成資料的存取工作。假設現在有一種應用程式套件組合含了這兩 種,現在要修改其中的一個查詢sql語句,那麼我們可能要同時修改他們中對應的查詢sql語句,當我們的應用程式很龐大很複雜的時候問題就出現這,不易維 護!另外把sql查詢語句放在我們的web程式或案頭中很容易遭到sql注入的破壞。而儲存常式正好可以幫我們解決這些問題。

2、建立預存程序

建立預存程序這塊主要有兩種,一種是帶參數的,一種是不帶參數的,先講不帶參數的再說不帶參數的

不帶參數案例:

-- 建立預存程序delimiter //        --自訂語句結尾符號,因為這裡要執行好多句sql語句,所以就得自訂,以防止出錯create procedure p1()BEGIN    select * from tab1;END//delimiter ;         --自訂局域結尾符號結束-- 執行預存程序call p1()

帶參數案例這塊主要有三個類

  • in          僅用於傳入參數用
  • out        僅用於傳回值用
  • inout     既可以傳入又可以當作傳回值
-- 建立預存程序delimiter \create procedure p1(    in i1 int,                        -- 傳入參數i1    in i2 int,                        -- 傳入參數i2    inout i3 int,                     -- 即傳入又能得到傳回值    out r1 int                        -- 得到傳回值)BEGIN    DECLARE temp1 int;    DECLARE temp2 int default 0;      set temp1 = 1;    set r1 = i1 + i2 + temp1 + temp2;     set i3 = i3 + 100;end\delimiter ;-- 執行預存程序DECLARE @t1 INT default 3;           --  設定變數預設值為3DECLARE @t2 INT;                     --  設定變數CALL p1 (1, 2 ,@t1, @t2);            --  執行預存程序,並傳入參數,t2自動取消SELECT @t1,@t2;                      --  查看預存程序輸出結果

2、刪除預存程序

drop procedure p1;

3、python用pymysql模組調用預存程序,因為我們學習這些就是為了語言調用

#!/usr/bin/env python# -*- coding:utf-8 -*-import pymysqlconn = pymysql.connect(host=‘127.0.0.1‘, port=3306, user=‘root‘, passwd=‘‘, db=‘day39b_‘)cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)# 執行預存程序row = cursor.callproc(‘p1‘,(1,2,3))# 預存程序的查詢結果selc = cursor.fetchall()print(selc)# 擷取預存程序返回effect_row = cursor.execute(‘select @_p1_0,@_p1_1,@_p1_2‘)# 曲預存程序的傳回值ret = cursor.fetchone()print(ret)# 提交,不然無法儲存建立或者修改的資料conn.commit()# 關閉遊標cursor.close()# 關閉串連conn.close()
函數function

 在mysql中有很多內建函數,比如我們經常用的求平均值,求和,個數,各式各樣,先給大家來一部門內建函數,然後再說說自訂函數吧,函數也可以傳參數,也可以接收傳回值,但是函數沒辦法得到執行語句得到的結果,預存程序可以。

 內建函數

更多參考請參考中文文檔http://doc.mysql.cn/mysql5/refman-5.1-zh.html-chapter/functions.html#encryption-functions

1、自訂建立函數

delimiter \create function f1(    i1 int,    i2 int)returns intBEGIN    declare num int;    set num = i1 + i2;    return(num);END \delimiter ;

2、刪除函數

drop function f1;

3、執行函數

# 擷取傳回值declare @i VARCHAR(32);select UPPER(‘alex‘) into @i;SELECT @i;# 在查詢中使用select f1(11,nid) ,name from tb2;
事務

 事務用於將某些操作的多個SQL作為原子性操作,一旦有某一個出現錯誤,即可復原到原來的狀態,從而保證資料庫資料完整性。例如:當兩張銀行卡之間進行轉賬,甲方錢轉出去了,突然光纜壞了,乙方還沒收到錢,錢跑哪裡去了,就為了防止這種情況,事務就出來了,事務可以防止這種事情發生。

應用事務執行個體:

delimiter \create PROCEDURE p1(    OUT p_return_code tinyint)BEGIN   DECLARE exit handler for sqlexception   BEGIN     -- ERROR     set p_return_code = 1;     rollback;   END;    DECLARE exit handler for sqlwarning   BEGIN     -- WARNING     set p_return_code = 2;     rollback;   END;    START TRANSACTION;     DELETE from tb1;                   -- sql語句都放在這個裡面    insert into tb2(name)values(‘seven‘);  COMMIT;    -- SUCCESS   set p_return_code = 0;    END\delimiter ;

執行預存程序:

DECLARE @i TINYINT;call p1(@i);select @i;
觸發器TRIGGER

 觸發器,簡單來說就是當你在執行這條語句之前或者之後觸發一次增刪改查,觸發器用於定製使用者對錶的行進行【增/刪/改】前後的行為。

1、基本文法

# 插入前CREATE TRIGGER tri_before_insert_tb1 BEFORE INSERT ON tb1 FOR EACH ROWBEGIN    ...END# 插入後CREATE TRIGGER tri_after_insert_tb1 AFTER INSERT ON tb1 FOR EACH ROWBEGIN    ...END# 刪除前CREATE TRIGGER tri_before_delete_tb1 BEFORE DELETE ON tb1 FOR EACH ROWBEGIN    ...END# 刪除後CREATE TRIGGER tri_after_delete_tb1 AFTER DELETE ON tb1 FOR EACH ROWBEGIN    ...END# 更新前CREATE TRIGGER tri_before_update_tb1 BEFORE UPDATE ON tb1 FOR EACH ROWBEGIN    ...END# 更新後CREATE TRIGGER tri_after_update_tb1 AFTER UPDATE ON tb1 FOR EACH ROWBEGIN    ...END

案例一插入前:

-- 在往tab1插入資料之前往tab2中插入一條name = 張岩林,當然是在判斷往tab1中插入的名字是不是等於aylindelimiter //CREATE TRIGGER tri_before_insert_tb1 BEFORE INSERT ON tb1 FOR EACH ROWBEGINIF NEW. NAME == ‘aylin‘ THEN    INSERT INTO tb2 (NAME)VALUES    (‘張岩林‘)ENDEND//delimiter ;

案例二插入後:

delimiter //CREATE TRIGGER tri_after_insert_tb1 AFTER INSERT ON tb1 FOR EACH ROWBEGIN    IF NEW. num = 666 THEN        INSERT INTO tb2 (NAME)        VALUES            (‘張岩林‘),            (‘很帥‘) ;    ELSEIF NEW. num = 555 THEN        INSERT INTO tb2 (NAME)        VALUES            (‘aylin‘),            (‘非常帥‘) ;    END IF;END//delimiter ;

同樣的刪,改,查都是同樣的道理

特別的:NEW表示即將插入的資料行,OLD表示即將刪除的資料行。

2、刪除觸發器

DROP TRIGGER tri_after_insert_tb1;

3、使用觸發器

觸發器無法由使用者直接調用,而知由於對錶的【增/刪/改】操作被動引發的。

insert into tb1(name) values(‘張岩林’)

下章給大家更新資料庫索引,這方面東西比較多,所以樓主決定把他從新寫一篇部落格,看完的記得點贊喲!!

-此文章轉載-轉載自:http://www.cnblogs.com/aylin/p/5746501.html

MySQL(二)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.