mysql如何創建視圖?創建語句是什么?

mysql中,可以使用“CREATE VIEW”語句來創建視圖,語法格式為“CREATE VIEW AS ”;其中“”不能包含FROM子句中的子查詢,不能引用預處理語句參數。

mysql如何創建視圖?創建語句是什么?

(推薦教程:mysql視頻教程

創建視圖是指在已經存在的 MySQL 數據庫表上建立視圖。視圖可以建立在一張表中,也可以建立在多張表中。

基本語法

可以使用 CREATE VIEW 語句來創建視圖。

語法格式如下:

CREATE?VIEW??AS?<select></select>

語法說明如下。

  • :指定視圖的名稱。該名稱在數據庫中必須是唯一的,不能與其他表或視圖同名。

對于創建視圖中的 SELECT 語句的指定存在以下限制:

  • 用戶除了擁有 CREATE VIEW 權限外,還具有操作中涉及的基礎表和其他視圖的相關權限。

  • SELECT 語句不能引用系統或用戶變量。

  • SELECT 語句不能包含 FROM 子句中的子查詢。

  • SELECT 語句不能引用預處理語句參數。

視圖定義中引用的表或視圖必須存在。但是,創建完視圖后,可以刪除定義引用的表或視圖。可使用 CHECK TABLE 語句檢查視圖定義是否存在這類問題。

視圖定義中允許使用 ORDER BY 語句,但是若從特定視圖進行選擇,而該視圖使用了自己的 ORDER BY 語句,則視圖定義中的 ORDER BY 將被忽略。

視圖定義中不能引用 TEMPORARY 表(臨時表),不能創建 TEMPORARY 視圖。

WITH CHECK OPTION 的意思是,修改視圖時,檢查插入的數據是否符合 WHERE 設置的條件。

創建基于單表的視圖

MySQL 可以在單個數據表上創建視圖。

查看 test_db 數據庫中的 tb_students_info 表的數據,如下所示。

mysql&gt;?SELECT?*?FROM?tb_students_info; +----+--------+---------+------+------+--------+------------+ |?id?|?name???|?dept_id?|?age??|?sex??|?height?|?login_date?| +----+--------+---------+------+------+--------+------------+ |??1?|?Dany???|???????1?|???25?|?F????|????160?|?2015-09-10?| |??2?|?Green??|???????3?|???23?|?F????|????158?|?2016-10-22?| |??3?|?Henry??|???????2?|???23?|?M????|????185?|?2015-05-31?| |??4?|?Jane???|???????1?|???22?|?F????|????162?|?2016-12-20?| |??5?|?Jim????|???????1?|???24?|?M????|????175?|?2016-01-15?| |??6?|?John???|???????2?|???21?|?M????|????172?|?2015-11-11?| |??7?|?Lily???|???????6?|???22?|?F????|????165?|?2016-02-26?| |??8?|?Susan??|???????4?|???23?|?F????|????170?|?2015-10-01?| |??9?|?Thomas?|???????3?|???22?|?M????|????178?|?2016-06-07?| |?10?|?Tom????|???????4?|???23?|?M????|????165?|?2016-08-05?| +----+--------+---------+------+------+--------+------------+ 10?rows?in?set?(0.00?sec)

【實例 1】在 tb_students_info 表上創建一個名為 view_students_info 的視圖,輸入的 SQL 語句和執行結果如下所示。

mysql&gt;?CREATE?VIEW?view_students_info ????-&gt;?AS?SELECT?*?FROM?tb_students_info; Query?OK,?0?rows?affected?(0.00?sec) mysql&gt;?SELECT?*?FROM?view_students_info; +----+--------+---------+------+------+--------+------------+ |?id?|?name???|?dept_id?|?age??|?sex??|?height?|?login_date?| +----+--------+---------+------+------+--------+------------+ |??1?|?Dany???|???????1?|???25?|?F????|????160?|?2015-09-10?| |??2?|?Green??|???????3?|???23?|?F????|????158?|?2016-10-22?| |??3?|?Henry??|???????2?|???23?|?M????|????185?|?2015-05-31?| |??4?|?Jane???|???????1?|???22?|?F????|????162?|?2016-12-20?| |??5?|?Jim????|???????1?|???24?|?M????|????175?|?2016-01-15?| |??6?|?John???|???????2?|???21?|?M????|????172?|?2015-11-11?| |??7?|?Lily???|???????6?|???22?|?F????|????165?|?2016-02-26?| |??8?|?Susan??|???????4?|???23?|?F????|????170?|?2015-10-01?| |??9?|?Thomas?|???????3?|???22?|?M????|????178?|?2016-06-07?| |?10?|?Tom????|???????4?|???23?|?M????|????165?|?2016-08-05?| +----+--------+---------+------+------+--------+------------+ 10?rows?in?set?(0.04?sec)

默認情況下,創建的視圖和基本表的字段是一樣的,也可以通過指定視圖字段的名稱來創建視圖。

【實例 2】在 tb_students_info 表上創建一個名為 v_students_info 的視圖,輸入的 SQL 語句和執行結果如下所示。

mysql&gt;?CREATE?VIEW?v_students_info ????-&gt;?(s_id,s_name,d_id,s_age,s_sex,s_height,s_date) ????-&gt;?AS?SELECT?id,name,dept_id,age,sex,height,login_date ????-&gt;?FROM?tb_students_info; Query?OK,?0?rows?affected?(0.06?sec) mysql&gt;?SELECT?*?FROM?v_students_info; +------+--------+------+-------+-------+----------+------------+ |?s_id?|?s_name?|?d_id?|?s_age?|?s_sex?|?s_height?|?s_date?????| +------+--------+------+-------+-------+----------+------------+ |????1?|?Dany???|????1?|????24?|?F?????|??????160?|?2015-09-10?| |????2?|?Green??|????3?|????23?|?F?????|??????158?|?2016-10-22?| |????3?|?Henry??|????2?|????23?|?M?????|??????185?|?2015-05-31?| |????4?|?Jane???|????1?|????22?|?F?????|??????162?|?2016-12-20?| |????5?|?Jim????|????1?|????24?|?M?????|??????175?|?2016-01-15?| |????6?|?John???|????2?|????21?|?M?????|??????172?|?2015-11-11?| |????7?|?Lily???|????6?|????22?|?F?????|??????165?|?2016-02-26?| |????8?|?Susan??|????4?|????23?|?F?????|??????170?|?2015-10-01?| |????9?|?Thomas?|????3?|????22?|?M?????|??????178?|?2016-06-07?| |???10?|?Tom????|????4?|????23?|?M?????|??????165?|?2016-08-05?| +------+--------+------+-------+-------+----------+------------+ 10?rows?in?set?(0.01?sec)

可以看到,view_students_info 和 v_students_info 兩個視圖中的字段名稱不同,但是數據卻相同。因此,在使用視圖時,可能用戶不需要了解基本表的結構,更接觸不到實際表中的數據,從而保證了數據庫的安全。

創建基于多表的視圖

MySQL 中也可以在兩個以上的表中創建視圖,使用 CREATE VIEW 語句創建。

【實例 3】在表 tb_student_info 和表 tb_departments 上創建視圖 v_students_info,輸入的 SQL 語句和執行結果如下所示。

mysql&gt;?CREATE?VIEW?v_students_info ????-&gt;?(s_id,s_name,d_id,s_age,s_sex,s_height,s_date) ????-&gt;?AS?SELECT?id,name,dept_id,age,sex,height,login_date ????-&gt;?FROM?tb_students_info; Query?OK,?0?rows?affected?(0.06?sec) mysql&gt;?SELECT?*?FROM?v_students_info; +------+--------+------+-------+-------+----------+------------+ |?s_id?|?s_name?|?d_id?|?s_age?|?s_sex?|?s_height?|?s_date?????| +------+--------+------+-------+-------+----------+------------+ |????1?|?Dany???|????1?|????24?|?F?????|??????160?|?2015-09-10?| |????2?|?Green??|????3?|????23?|?F?????|??????158?|?2016-10-22?| |????3?|?Henry??|????2?|????23?|?M?????|??????185?|?2015-05-31?| |????4?|?Jane???|????1?|????22?|?F?????|??????162?|?2016-12-20?| |????5?|?Jim????|????1?|????24?|?M?????|??????175?|?2016-01-15?| |????6?|?John???|????2?|????21?|?M?????|??????172?|?2015-11-11?| |????7?|?Lily???|????6?|????22?|?F?????|??????165?|?2016-02-26?| |????8?|?Susan??|????4?|????23?|?F?????|??????170?|?2015-10-01?| |????9?|?Thomas?|????3?|????22?|?M?????|??????178?|?2016-06-07?| |???10?|?Tom????|????4?|????23?|?M?????|??????165?|?2016-08-05?| +------+--------+------+-------+-------+----------+------------+ 10?rows?in?set?(0.01?sec)

通過這個視圖可以很好地保護基本表中的數據。視圖中包含 s_id、s_name 和 dept_name,s_id 字段對應 tb_students_info 表中的 id 字段,s_name 字段對應 tb_students_info 表中的 name 字段,dept_name 字段對應 tb_departments 表中的 dept_name 字段。

以上就是

? 版權聲明
THE END
喜歡就支持一下吧
點贊8 分享