好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > MySQL如何創建視圖

MySQL如何創建視圖

熱門標簽:地圖標注客戶付款 申請400電話電話價格 許昌外呼增值業務線路 咸陽防封電銷卡 臨沂做地圖標注 新鄉智能外呼系統好處 石家莊400電話辦理公司 廣東400企業電話申請流程 宜賓全自動外呼系統廠家

基本語法

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

語法格式如下:

CREATE VIEW 視圖名> AS SELECT語句>

語法說明如下。

  • 視圖名>:指定視圖的名稱。該名稱在數據庫中必須是唯一的,不能與其他表或視圖同名。
  • 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> 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> CREATE VIEW view_students_info
  -> AS SELECT * FROM tb_students_info;
Query OK, 0 rows affected (0.00 sec)
mysql> 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> CREATE VIEW v_students_info
  -> (s_id,s_name,d_id,s_age,s_sex,s_height,s_date)
  -> AS SELECT id,name,dept_id,age,sex,height,login_date
  -> FROM tb_students_info;
Query OK, 0 rows affected (0.06 sec)
mysql> 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> CREATE VIEW v_students_info
  -> (s_id,s_name,d_id,s_age,s_sex,s_height,s_date)
  -> AS SELECT id,name,dept_id,age,sex,height,login_date
  -> FROM tb_students_info;
Query OK, 0 rows affected (0.06 sec)
mysql> 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 字段。

查詢視圖

視圖一經定義之后,就可以如同查詢數據表一樣,使用 SELECT 語句查詢視圖中的數據,語法和查詢基礎表的數據一樣。

視圖用于查詢主要應用在以下幾個方面:

  • 使用視圖重新格式化檢索出的數據。
  • 使用視圖簡化復雜的表連接。
  • 使用視圖過濾數據。

DESCRIBE 可以用來查看視圖,語法如下:

DESCRIBE 視圖名;

【實例 4】

通過 DESCRIBE 語句查看視圖 v_students_info 的定義,輸入的 SQL 語句和執行結果如下所示。

mysql> DESCRIBE v_students_info;
+----------+---------------+------+-----+------------+-------+
| Field  | Type     | Null | Key | Default  | Extra |
+----------+---------------+------+-----+------------+-------+
| s_id   | int(11)    | NO  |   | 0     |    |
| s_name  | varchar(45)  | YES |   | NULL    |    |
| d_id   | int(11)    | YES |   | NULL    |    |
| s_age  | int(11)    | YES |   | NULL    |    |
| s_sex  | enum('M','F') | YES |   | NULL    |    |
| s_height | int(11)    | YES |   | NULL    |    |
| s_date  | date     | YES |   | 2016-10-22 |    |
+----------+---------------+------+-----+------------+-------+
7 rows in set (0.04 sec)

注意:DESCRIBE 一般情況下可以簡寫成 DESC,輸入這個命令的執行結果和輸入 DESCRIBE 是一樣的。

以上就是MySQL如何創建視圖的詳細內容,更多關于MySQL創建視圖的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • mysql視圖之創建視圖(CREATE VIEW)和使用限制實例詳解
  • 詳細分析mysql視圖的原理及使用方法
  • MySQL的視圖和索引用法與區別詳解
  • 淺談MySql 視圖、觸發器以及存儲過程
  • MySql視圖觸發器存儲過程詳解
  • mysql視圖原理與用法實例詳解
  • mysql視圖之管理視圖實例詳解【增刪改查操作】
  • mysql視圖之創建可更新視圖的方法詳解
  • MySQL中Update、select聯用操作單表、多表,及視圖與臨時表的區別
  • mysql三張表連接建立視圖
  • MySQL 視圖(View)原理解析

標簽:臺灣 北京 鎮江 合肥 阜新 日照 貴州 鷹潭

巨人網絡通訊聲明:本文標題《MySQL如何創建視圖》,本文關鍵詞  MySQL,如何,創建,視圖,MySQL,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL如何創建視圖》相關的同類信息!
  • 本頁收集關于MySQL如何創建視圖的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 久久精品欧美一区二区三区不卡| 香蕉依依精品视频在线播放| 免费无码又爽又黄A片软件| 久久99精品久久久久久无毒不卡| 4444kk在线看片| 性视频在线看| 欧美xxxx做受欧美88xx| 蹭蹭?好紧?H校园| 99re6热在线精品视频播放| 深夜福利国产| 亚洲国产精品久久久久日本竹山梨| 朝鲜女人白嫩大肥臀ass| 河马的秘密河祺鑫肉车| 成年人毛片视频| 无码区免费看一级毛片A片| 男的干女的| 国产精品无码一区二区在线欢| 又黄又爽的成人免费视频播放| 秘密教学韩漫免费无付费无遮| Free Japan XXXXHDsex| 姧熟妇人妻午夜精品| 夜间福利电影| 边做边爱mp3在线播放视频| 成在线人免费视频一区二区三区| 淫男乱女在线| 一级国产交换配乱淫| 国产精品亚洲一区二区三区在线观看| 一级全黄男女免费大片| 国产又黄又爽又色的视频 | 国产剧情一区| 二次元美女脱裤子让男人桶爽| 肉肉肉+定期按摩(h)| 91对白在线| 亚色影库| 欧美zzo| 日韩一级片免费在线观看| 国产AV精品国语对白河南小伙| 日本我和子的乱视频| 挺进大幂幂的滋润花| 因为初恋是第一次2| 在线AV天堂亚洲AV天堂|