国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

MySQL數(shù)據(jù)庫(kù)——MySQL創(chuàng)建視圖(CREATE VIEW)

這篇具有很好參考價(jià)值的文章主要介紹了MySQL數(shù)據(jù)庫(kù)——MySQL創(chuàng)建視圖(CREATE VIEW)。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問(wèn)。

創(chuàng)建視圖是指在已經(jīng)存在的 MySQL 數(shù)據(jù)庫(kù)表上建立視圖。視圖可以建立在一張表中,也可以建立在多張表中。

基本語(yǔ)法

可以使用 CREATE VIEW 語(yǔ)句來(lái)創(chuàng)建視圖。

語(yǔ)法格式如下:

CREATE VIEW <視圖名> AS <SELECT語(yǔ)句>

語(yǔ)法說(shuō)明如下。

  • <視圖名>指定視圖的名稱。該名稱在數(shù)據(jù)庫(kù)中必須是唯一的,不能與其他表或視圖同名。
  • <SELECT語(yǔ)句>指定創(chuàng)建視圖的 SELECT 語(yǔ)句,可用于查詢多個(gè)基礎(chǔ)表或源視圖。

對(duì)于創(chuàng)建視圖中的 SELECT 語(yǔ)句的指定存在以下限制:

  • 用戶除了擁有 CREATE VIEW 權(quán)限外,還具有操作中涉及的基礎(chǔ)表和其他視圖的相關(guān)權(quán)限。
  • SELECT 語(yǔ)句不能引用系統(tǒng)或用戶變量。
  • SELECT 語(yǔ)句不能包含 FROM 子句中的子查詢。
  • SELECT 語(yǔ)句不能引用預(yù)處理語(yǔ)句參數(shù)。

視圖定義中引用的表或視圖必須存在。但是,創(chuàng)建完視圖后,可以刪除定義引用的表或視圖??墒褂?CHECK TABLE 語(yǔ)句檢查視圖定義是否存在這類問(wèn)題。

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

視圖定義中不能引用 TEMPORARY 表(臨時(shí)表),不能創(chuàng)建 TEMPORARY 視圖。

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

創(chuàng)建基于單表的視圖

MySQL 可以在單個(gè)數(shù)據(jù)表上創(chuàng)建視圖。

查看 test_db 數(shù)據(jù)庫(kù)中的 tb_students_info 表的數(shù)據(jù),如下所示:

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)

【實(shí)例 1】在 tb_students_info 表上創(chuàng)建一個(gè)名為 view_students_info 的視圖,輸入的 SQL 語(yǔ)句和執(zhí)行結(jié)果如下所示:

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)

默認(rèn)情況下,創(chuàng)建的視圖和基本表的字段是一樣的,也可以通過(guò)指定視圖字段的名稱來(lái)創(chuàng)建視圖。

【實(shí)例 2】在 tb_students_info 表上創(chuàng)建一個(gè)名為 v_students_info 的視圖,輸入的 SQL 語(yǔ)句和執(zhí)行結(jié)果如下所示:

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 兩個(gè)視圖中的字段名稱不同,但是數(shù)據(jù)卻相同。因此,在使用視圖時(shí),可能用戶不需要了解基本表的結(jié)構(gòu),更接觸不到實(shí)際表中的數(shù)據(jù),從而保證了數(shù)據(jù)庫(kù)的安全。

創(chuàng)建基于多表的視圖

MySQL 中也可以在兩個(gè)以上的表中創(chuàng)建視圖,使用 CREATE VIEW 語(yǔ)句創(chuàng)建。

【實(shí)例 3】在表 tb_student_info 和表 tb_departments 上創(chuàng)建視圖 v_students_info,輸入的 SQL 語(yǔ)句和執(zhí)行結(jié)果如下所示:

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)

通過(guò)這個(gè)視圖可以很好地保護(hù)基本表中的數(shù)據(jù)。視圖中包含 s_id、s_name 和 dept_name,s_id 字段對(duì)應(yīng) tb_students_info 表中的 id 字段,s_name 字段對(duì)應(yīng) tb_students_info 表中的 name 字段,dept_name 字段對(duì)應(yīng) tb_departments 表中的 dept_name 字段。

查詢視圖

視圖一經(jīng)定義之后,就可以如同查詢數(shù)據(jù)表一樣,使用 SELECT 語(yǔ)句查詢視圖中的數(shù)據(jù),語(yǔ)法和查詢基礎(chǔ)表的數(shù)據(jù)一樣。

視圖用于查詢主要應(yīng)用在以下幾個(gè)方面:

  • 使用視圖重新格式化檢索出的數(shù)據(jù)。
  • 使用視圖簡(jiǎn)化復(fù)雜的表連接。
  • 使用視圖過(guò)濾數(shù)據(jù)。

DESCRIBE 可以用來(lái)查看視圖,語(yǔ)法如下:

DESCRIBE 視圖名;

【實(shí)例 4】通過(guò) DESCRIBE 語(yǔ)句查看視圖 v_students_info 的定義,輸入的 SQL 語(yǔ)句和執(zhí)行結(jié)果如下所示:

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 一般情況下可以簡(jiǎn)寫成 DESC,輸入這個(gè)命令的執(zhí)行結(jié)果和輸入 DESCRIBE 是一樣的。

黑馬程序員 MySQL數(shù)據(jù)庫(kù)入門到精通,從mysql安裝到mysql高級(jí)、mysql優(yōu)化全囊括文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-432747.html

到了這里,關(guān)于MySQL數(shù)據(jù)庫(kù)——MySQL創(chuàng)建視圖(CREATE VIEW)的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來(lái)自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 數(shù)據(jù)庫(kù)sql語(yǔ)句(視圖的創(chuàng)建)

    數(shù)據(jù)庫(kù)sql語(yǔ)句(視圖的創(chuàng)建)

    例題:? 建表:要注意各表之間的索引聯(lián)系,建表先后順序很重要,不然建不了,例如先建dept,在建其他表,先在dept插入數(shù)據(jù),再在其他表插入數(shù)據(jù) (1) (2)? (3)? (4) (5)? ? 插入數(shù)據(jù)如下圖 sql語(yǔ)句: 在 Student 表中加入屬性 SAGE(INT 型 ) ?將 Student 表中的屬性 SA

    2024年02月04日
    瀏覽(93)
  • 【MySQL 數(shù)據(jù)庫(kù)】8、視圖

    【MySQL 數(shù)據(jù)庫(kù)】8、視圖

    視圖(View)是一種虛擬存在的表 視圖中的數(shù)據(jù)并不在數(shù)據(jù)庫(kù)中真實(shí)存在 行和列數(shù)據(jù)來(lái)自 定義視圖的查詢中使用的表 ,并且是在使用視圖時(shí)動(dòng)態(tài)生成的 當(dāng)使用 WITH CHECK OPTION 子句創(chuàng)建視圖時(shí),MySQL 會(huì)通過(guò)視圖檢查正在更改的每個(gè)行,例如 插入,更新,刪除 ,以使其符合視圖

    2024年02月08日
    瀏覽(30)
  • openGauss學(xué)習(xí)筆記-74 openGauss 數(shù)據(jù)庫(kù)管理-創(chuàng)建和管理視圖

    openGauss學(xué)習(xí)筆記-74 openGauss 數(shù)據(jù)庫(kù)管理-創(chuàng)建和管理視圖

    74.1 背景信息 當(dāng)用戶對(duì)數(shù)據(jù)庫(kù)中的一張或者多張表的某些字段的組合感興趣,而又不想每次鍵入這些查詢時(shí),用戶就可以定義一個(gè)視圖,以便解決這個(gè)問(wèn)題。 視圖與基本表不同,不是物理上實(shí)際存在的,是一個(gè)虛表。數(shù)據(jù)庫(kù)中僅存放視圖的定義,而不存放視圖對(duì)應(yīng)的數(shù)據(jù),這

    2024年02月07日
    瀏覽(50)
  • 玩轉(zhuǎn)MYSQL數(shù)據(jù)庫(kù)之--視圖詳解

    玩轉(zhuǎn)MYSQL數(shù)據(jù)庫(kù)之--視圖詳解

    從今天開(kāi)始本系列文章就帶各位小伙伴學(xué)習(xí)數(shù)據(jù)庫(kù)技術(shù)。 數(shù)據(jù)庫(kù)技術(shù)是Java開(kāi)發(fā)中必不可少的一部分知識(shí)內(nèi)容。也是非常重要的技術(shù)。本系列教程由淺入深,?全面講解數(shù)據(jù)庫(kù)體系。?非常適合零基礎(chǔ)的小伙伴來(lái)學(xué)習(xí)。 全文大約 【1297】字 ,不說(shuō)廢話,只講可以讓你學(xué)到技術(shù)、

    2024年02月05日
    瀏覽(27)
  • mysql數(shù)據(jù)庫(kù)實(shí)驗(yàn)實(shí)訓(xùn)6,數(shù)據(jù)視圖(詳細(xì))

    mysql數(shù)據(jù)庫(kù)實(shí)驗(yàn)實(shí)訓(xùn)6,數(shù)據(jù)視圖(詳細(xì))

    1、掌握視圖功能和作用 2、掌握視圖創(chuàng)建和管理辦法 對(duì)YGGL數(shù)據(jù)庫(kù)完成以下視圖操作: 1、在員工管理數(shù)據(jù)庫(kù)YGGL中創(chuàng)建視圖Emp_view1,包含所有男員工的員工編號(hào)、姓名、工作年限和學(xué)歷: 代碼: mysql create or replace view Emp_view1 - as select 員工編號(hào),姓名,工作年限,學(xué)歷 - from employee

    2024年02月07日
    瀏覽(25)
  • 【MySQL數(shù)據(jù)庫(kù)】看完還有誰(shuí)學(xué)不會(huì) MySQL 中的視圖?

    【MySQL數(shù)據(jù)庫(kù)】看完還有誰(shuí)學(xué)不會(huì) MySQL 中的視圖?

    在MySQL中,視圖是一種虛擬表,它是由一個(gè)或多個(gè)基本表的行或列組成的。視圖并不實(shí)際存儲(chǔ)數(shù)據(jù),而是根據(jù)定義的查詢語(yǔ)句動(dòng)態(tài)生成結(jié)果集。視圖可以簡(jiǎn)化復(fù)雜的查詢操作,提高查詢效率,同時(shí)也可以保護(hù)數(shù)據(jù)的安全性,隱藏敏感數(shù)據(jù)。 視圖是一種虛擬表,它是由一個(gè)或多

    2024年02月10日
    瀏覽(19)
  • MySQL中的表與視圖:解密數(shù)據(jù)庫(kù)世界的基石

    MySQL中的表與視圖:解密數(shù)據(jù)庫(kù)世界的基石

    ??作者簡(jiǎn)介,黑夜開(kāi)發(fā)者,CSDN領(lǐng)軍人物,全棧領(lǐng)域優(yōu)質(zhì)創(chuàng)作者?,CSDN博客專家,阿里云社區(qū)專家博主,2023年6月CSDN上海賽道top4。 ??數(shù)年電商行業(yè)從業(yè)經(jīng)驗(yàn),歷任核心研發(fā)工程師,項(xiàng)目技術(shù)負(fù)責(zé)人。 ??本文已收錄于PHP專欄:MySQL的100個(gè)知識(shí)點(diǎn)。 ??歡迎 ??點(diǎn)贊?評(píng)論?收

    2024年02月10日
    瀏覽(24)
  • Day04 03-MySQL數(shù)據(jù)庫(kù)的DCL(用戶|權(quán)限|視圖)

    第十二章 DCL 12.1 DCL的作用 DCL語(yǔ)句主要用來(lái)做用戶的創(chuàng)建、管理,權(quán)限的授予、撤銷等操作的。 12.2 管理用戶 創(chuàng)建、刪除用戶的操作,必須要使用root用戶才可以完成! 12.3 權(quán)限管理 如果在授權(quán)遠(yuǎn)程登錄的時(shí)候,出現(xiàn)如下問(wèn)題: Unable to load authentication plugin ‘caching_sha2_password’

    2024年02月07日
    瀏覽(18)
  • 【MySQL 】MySQL 創(chuàng)建數(shù)據(jù)庫(kù), MySQL 刪除數(shù)據(jù)庫(kù),MySQL 選擇數(shù)據(jù)庫(kù)

    【MySQL 】MySQL 創(chuàng)建數(shù)據(jù)庫(kù), MySQL 刪除數(shù)據(jù)庫(kù),MySQL 選擇數(shù)據(jù)庫(kù)

    作者簡(jiǎn)介: 辭七七,目前大一,正在學(xué)習(xí)C/C++,Java,Python等 作者主頁(yè): 七七的個(gè)人主頁(yè) 文章收錄專欄: 七七的閑談 歡迎大家點(diǎn)贊 ?? 收藏 ? 加關(guān)注哦!???? 我們可以在登陸 MySQL 服務(wù)后,使用 create 命令創(chuàng)建數(shù)據(jù)庫(kù),語(yǔ)法如下: 以下命令簡(jiǎn)單的演示了創(chuàng)建數(shù)據(jù)庫(kù)的過(guò)程,

    2024年02月13日
    瀏覽(115)
  • MySQL(1)
MySQL創(chuàng)建數(shù)據(jù)庫(kù)和創(chuàng)建數(shù)據(jù)表

    MySQL(1) MySQL創(chuàng)建數(shù)據(jù)庫(kù)和創(chuàng)建數(shù)據(jù)表

    創(chuàng)建數(shù)據(jù)庫(kù) 1. 連接 MySQL? ? ? mysql -u root -p? 2. 查看當(dāng)前的數(shù)據(jù)庫(kù)? show databases; 3. 創(chuàng)建數(shù)據(jù)庫(kù)? create database 數(shù)據(jù)庫(kù)名; 創(chuàng)建數(shù)據(jù)庫(kù) 4. 創(chuàng)建數(shù)據(jù)庫(kù)時(shí)設(shè)置字符編碼??create database 數(shù)據(jù)庫(kù)名 character set utf8;? 5. 查看和顯示數(shù)據(jù)庫(kù)的編碼方式? show create database 數(shù)據(jù)庫(kù)名; 顯示數(shù)據(jù)庫(kù)的

    2024年02月14日
    瀏覽(120)

覺(jué)得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包