UPDATE worker_view4 SET name='hi';
10年積累的網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站經(jīng)驗(yàn),可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站策劃后付款的網(wǎng)站建設(shè)流程,更有鄆城免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
ERROR............The target table worker_view4 of the UPDATE is not updatable.
(4)視圖中的SELECT中包含子查詢。
CREATE VIEW worker_view5(name)
AS SELECT (SELECT name FROM worker);
UPDATE worker_view5 SET name = '劉佳';
該視圖中包含了子查詢,因此也是不能更新的。
(5)由不可更新的視圖導(dǎo)出的視圖。
CREATE VIEW worker_view6
AS SELECT * FROM worker_view5;
UPDATE worker_view6 SET name = '王仔';
因?yàn)閣orker_view6是不可更新的視圖,所以worker_view6也不可以更新的視圖。使用UPDATE語句更新時(shí),會(huì)出現(xiàn)系統(tǒng)報(bào)錯(cuò)。
(6)創(chuàng)建視圖時(shí),ALGORITHM為TEMPTABLE類型。
CREATE ALGORITHM=TEMPTABLE
VIEW worker_view7
AS SELECT * FROM worker;
UPDATE worker_view7 SET name = '王仔';
因?yàn)樵撘晥DALGORITHM為TEMPTABLE類型,所以worker_view7不可以更新的視圖。TEMPTABLE類型就是臨時(shí)表類型。系統(tǒng)默認(rèn)臨時(shí)表是不能更新的。
(7)視圖對應(yīng)的表上存在沒有默認(rèn)值的列,而且該列沒有包含在視圖里。例如,表中包含的name字段沒有默認(rèn)值,但是視圖中不包含該字段。那么這個(gè)視圖是不能更新的。因?yàn)?,在更新視圖時(shí),這個(gè)沒有默認(rèn)值的記錄將沒有值插入,也沒有NULL值插入。數(shù)據(jù)庫系統(tǒng)是不會(huì)允許這樣的情況出現(xiàn)的,數(shù)據(jù)庫系統(tǒng)將會(huì)阻止這個(gè)視圖更新。
注意:視圖中雖然可以更新數(shù)據(jù),但是有很多的限制。一般情況下,最好將視圖作為查詢數(shù)據(jù)的虛擬表,而不要通過視圖來更新數(shù)據(jù)。因?yàn)?,使用視圖更新數(shù)據(jù)時(shí),如果沒有全面考慮在視圖中更新數(shù)據(jù)的限制,可能會(huì)造成數(shù)據(jù)更新失敗。
除了上述條件不能更新視圖以外,WITH[CASCADED|LOCAL]CHECK OPTION也將決定視圖能否更新。"LOCAL"參數(shù)表示更新視圖時(shí)要滿足該視圖本身的定義的條件即可;
8.6 刪除視圖
刪除視圖是指刪除數(shù)據(jù)庫中已經(jīng)存在的視圖。刪除視圖時(shí),只能刪除視圖的定義,不會(huì)刪除數(shù)據(jù)。MYSQL中,使用DROP VIEW語句來刪除視圖,不會(huì)刪除數(shù)據(jù)。MySQL中,使用DROP VIEW語句來刪除視圖。但是,用戶必須擁有DROP權(quán)限。
DROP VIEW[IF EXISTS] 視圖名列表 [RESTRICT|CASCADE]
實(shí)例一:
SELECT Drop_priv
FROM mysql.user
WHERE user='root';
CREATE VIEW worker_view_del1
AS SELECT * FROM worker;
CREATE VIEW worker_view_del2
AS SELECT * FROM worker;
CREATE VIEW worker_view_del3
AS SELECT * FROM worker;
DROP VIEW IF EXISTS worker_view_del2, worker_view_del3;
8.7 本章實(shí)例
在test數(shù)據(jù)庫中work_info表上進(jìn)行視圖操作。
1. 在test數(shù)據(jù)庫中work_info表
2. 插入記錄
3. 創(chuàng)建視圖info_view
4. 查看視圖info_view的基本結(jié)構(gòu)和詳細(xì)結(jié)構(gòu)
5. 查看視圖info_view的所有記錄
6. 修改視圖info_view
7. 更新視圖
8. 刪除視圖
work_info表的結(jié)構(gòu)
字段名 字段描述 數(shù)據(jù)類型 主鍵 外鍵 非空 唯一 自增
id 編號(hào) INT(10) 是 否 是 是 否
name 姓名 VARCHAR(20) 否 否 是 否 否
gender 姓別 VARCHAR(4) 否 否 是 否 否
age 年齡 INT(5) 否 否 否 否 否
address 家庭住址 VARCHAR(50) 否 否 否 否 否
tel 電話號(hào)碼 VARCHAR(20) 否 否 否 否 否
work_info表中的內(nèi)容
id name gender age address tel
1 張三 M 18 北市市海淀區(qū) 01-155151
2 李四 M 22 北京市昌平區(qū) 01-215151
3 王五 F 17 湖南省永州市 025-545845
4 趙六 F 25 遼寧省阜新市 0625-514545
(1) 創(chuàng)建work_info表
USE test;
CREATE TABLE IF NOT EXISTS work_info (
id INT(10) NOT NULL UNIQUE PRIMARY KEY,
name VARCHAR(20) NOT NULL,
gender VARCHAR(4) NOT NULL,
age INT(5),
address VARCHAR(50),
tel VARCHAR(20)
) DEFAULT CHARSET=utf8;
(2)向work_info表中插入幾條記錄。
INSERT INTO work_info VALUES
(1, '張三', 'M', 18, '北市市海淀區(qū)','01-155151'),
(2,'李四', 'M', 22, '北京市昌平區(qū)', '01-215151'),
(3,'王五','F',17,'湖南省永州市','025-545845'),
(4,'趙六','F',25,'遼寧省阜新市','0625-514545');
(3) 創(chuàng)建視圖info_view。從work_info表中選出age20的記錄來創(chuàng)建視圖。視圖的字段包括id、name、gender和address。ALGORITHM設(shè)置為MERGE類型。加上WITH LOCAL CHECK OPTION條件。
CREATE ALGORITHM=MERGE
VIEW info_view(id, name, gender, address)
AS SELECT id, name, gender, address
FROM work_info
WHERE age20
WITH LOCAL CHECK OPTION;
(4)查看視圖info_view的基本結(jié)構(gòu)和詳細(xì)結(jié)構(gòu)。
SHOW CREATE VIEW info_view \G
(5)查看視圖info_view的所有記錄。
SELECT * FROM info_view;
(6)修改視圖info_view,使其顯示age20的信息,其他條件不變。
ALTER ALGORITHM=MERGE
VIEW info_view(id, name, gender, address)
AS SELECT id, name, gender, address
FROM work_info
WHERE age20
WITH LOCAL CHECK OPTION;
(7)更新視圖,將id為3的記錄進(jìn)行更新。設(shè)置其gender為M。
UPDATE info_view SET gender='M' WHERE id=3;
(8)刪除視圖。
DROP VIEW info_view;
8.8 上機(jī)實(shí)踐
題目要求:
(1)在數(shù)據(jù)庫example下創(chuàng)建college表。
(2)在college表上創(chuàng)建視圖college_view。視圖的字段包括student_num、student_name、student_age和department。ALGORITHM設(shè)置為UNDEFINED類型。加上WITH LOCAL CHECK OPTION條件。
(3)查看視圖college_view的詳細(xì)結(jié)構(gòu)。
(4)更新視圖。向視圖中插入三條記錄。
(5)修改視圖,使其顯示專業(yè)為"計(jì)算機(jī)"的信息,其他條件不變。
(6)刪除視圖college_view。
college表的結(jié)構(gòu)
字段名 字段描述 數(shù)據(jù)類型 主鍵 外鍵 非空 唯一 自增
number 學(xué)號(hào) INT(10) 是 否 是 是 否
name 姓名 VARCHAR(20) 否 否 是 否 否
major 專業(yè) VARCHAR(20) 否 否 是 否 否
age 年齡 INT(5) 否 否 否 否 否
college_view表的內(nèi)容
student_num student_name student_age department
0901 張三 20 外語
0902 李四 22 計(jì)算機(jī)
0903 王五 19 計(jì)算機(jī)
USE example;
CREATE TABLE college(
number INT(10) NOT NULL UNIQUE PRIMARY KEY,
name VARCHAR(20) NOT NULL,
major VARCHAR(20) NOT NULL,
age TINYINT(3)
) DEFAULT CHARSET=utf8;
CREATE ALGORITHM=UNDEFINED
VIEW college_view(student_num, student_name, student_age, department)
AS SELECT number, name, age, major
FROM college
WITH LOCAL CHECK OPTION;
SHOW CREATE VIEW college_view \G
INSERT INTO college_view VALUES
(0901, '張三', 20, '外語'),
(0902, '李四', 22, '計(jì)算機(jī)'),
(0903, '王五', 19, '計(jì)算機(jī)');
CREATE OR REPLACE ALGORITHM=UNDEFINED
VIEW college_view(student_num, student_name, student_age, department)
AS SELECT number, name, age, major
FROM college
WHERE major='計(jì)算機(jī)'
WITH LOCAL CHECK OPTION;
最近,有很多學(xué)員留言讓我整理一下“零基礎(chǔ)如何mysql學(xué)習(xí)?”.今天青島電腦培訓(xùn)就整理一下學(xué)習(xí)MySQL你需要掌握的知識(shí)點(diǎn)以及送給新手學(xué)習(xí)的建議,希望對大家能夠有所幫助!給新手的學(xué)習(xí)建議:1.在學(xué)習(xí)新的東西的時(shí)候,我們至少從三個(gè)問題開始。
What?why?how?2.學(xué)習(xí)需要堅(jiān)持,如果還沒準(zhǔn)備好堅(jiān)持半年比較枯燥的MySQL之旅,那么就別開始。
3.學(xué)習(xí)東西不在多,在精,市面上有非常多的MySQL教程,不要瞎學(xué),今天這里學(xué)一點(diǎn),明天那里學(xué)一點(diǎn),這樣你學(xué)的都只是知識(shí)點(diǎn),無法形成一個(gè)知識(shí)面,知識(shí)網(wǎng)絡(luò)。
4.在學(xué)習(xí)過程中充滿好奇,使用google進(jìn)行問題搜索,千萬不要使用度娘了,質(zhì)量不高。
至于怎么用Google,請自行搜索。
5.學(xué)習(xí)的目的在于使用,因此,不要僅僅看書,看一遍,看兩遍,你可能還是沒什么感覺。
因此學(xué)習(xí)一開始,就要?jiǎng)邮志毩?xí),把資料上的情況,模擬一下。
6.請不要在windows上安裝mysql進(jìn)行學(xué)習(xí),因?yàn)楣ぷ髦卸际莑inux系統(tǒng)。
我們需要從一開始就是實(shí)戰(zhàn),就是生產(chǎn)環(huán)境。
7.保持好心態(tài),一步一個(gè)腳印的前進(jìn)。
學(xué)習(xí)MySQL你需要掌握的知識(shí)點(diǎn):1.系統(tǒng),當(dāng)然windos基本的要會(huì)。
然后就是Linux系統(tǒng),現(xiàn)在做MySQLDBA的系統(tǒng)多數(shù)都是Linux系統(tǒng),而生產(chǎn)環(huán)境大多又是RedHat,Centos。
其他的Linux和Unix系統(tǒng)可以只做了解。
2.Linux基礎(chǔ),網(wǎng)絡(luò),IO,內(nèi)存,磁盤,CPU。
包括不限于安裝,啟動(dòng)過程,目錄結(jié)構(gòu),遠(yuǎn)程登錄,文件屬性與管理,用戶與用戶權(quán)限,LAMP結(jié)構(gòu)vim,yum等shell命令,dns,ftp,以及一些常用工具。
3.MySQL基礎(chǔ):MySQL安裝、MySQL體系結(jié)構(gòu),SQL,MySQL管理維護(hù)。
4.數(shù)據(jù)備份與恢復(fù),常用的引擎:MyISAM、Innodb、NDB等。
5.數(shù)據(jù)庫設(shè)計(jì)優(yōu)化,一個(gè)好的MySQL系統(tǒng),往往從設(shè)計(jì)開始。
6.SQL優(yōu)化,參數(shù)優(yōu)化,監(jiān)控,安全等。
7.MySQL負(fù)載均衡,讀寫分離,MHA,MMM高可用架構(gòu),以及分布式架構(gòu):mycat、maxscale、galeracluster、MySQLGroupReplication等。
8.mysql5.6,mysql5.7新特性,mariadb、percona分支的差異和特點(diǎn)。
9.MySQLJSON、MySQLmemcached。
10.常見MySQL搭配的緩存系統(tǒng),redis,memcached,以及NOSQL、NEWSQL。
以上,就是小編為大家整理的mysql學(xué)習(xí)你需要掌握的知識(shí)點(diǎn)以及送給新手學(xué)習(xí)的建議,希望能夠幫助到大家!
首先,學(xué)習(xí)基本的SQL語法。完成這個(gè)后,你就可以編寫SQL語句了。這一步推薦:W3Schools的 SQL 教程。
其次,學(xué)習(xí)數(shù)據(jù)庫的主要功能和使用方法,比如用戶相關(guān)或者權(quán)限相關(guān)等等。
我推薦兩本書:
一、《MySQL必知必會(huì)》 這本書講的非常全,從基本概念,到查詢到插入新建表,用戶的管理,都有具體的例子,非常適合沒有任何基礎(chǔ)的同學(xué)來學(xué)習(xí)Mysql,總之這本書學(xué)習(xí)的方法就是:1、十分鐘了解下數(shù)據(jù)庫的基本概念 2、找到練手的數(shù)據(jù)庫 3、對照著上面的內(nèi)容去敲。本書里也有大量的內(nèi)容是講sql的,可以結(jié)合w3c的sql教程一起,有取舍地看。
二、《數(shù)據(jù)庫系統(tǒng)概念》這本書是dba必看的??赐赀@些并且實(shí)踐+思考之后,可以算入門了。接下來對于希望深入學(xué)習(xí)的童鞋我推薦幾本書(很多大神都這么推薦),《高性能MySQL(第3版)》、 《MySQL技術(shù)內(nèi)幕(第4版)》,《MySQL技術(shù)內(nèi)幕 InnoDB存儲(chǔ)引擎》,《深入理解MySQL》還有Mysql的官網(wǎng)。讀完這些東西,再加些豐富的經(jīng)驗(yàn),理論上來講就具備DBA的水平了。十分推薦閱讀Planet MySQL上匯總的博客,特別是Percona's MySQL InnoDB performance and scalability blog但是,正如我開頭所言的。
面對問題的時(shí)候一定要積極思考!比如:我問你,面對一個(gè)并發(fā)量比較高的場景,如何配置mysql的連接數(shù)?你可能會(huì)回答:“哦,就是調(diào)高max_connection的數(shù)值吧。”那,你有沒有思考過調(diào)到多少是最合適的呢?為什么這樣設(shè)置就最合適呢?也許你會(huì)回答:“恩我知道,可以看系統(tǒng)之前的max_used_connection的數(shù)值,然后來設(shè)置。也可以調(diào)高back_log的值。”那你有沒有思考過,max_connection連接數(shù)太高會(huì)有什么不好的影響呢?back_log設(shè)置的太高有什么不好的地方呢?max_connect的上限其實(shí)是取決于mysql能獲得的文件描述符的數(shù)量,也就是說你就算設(shè)置成10000,最后也是沒用的,系統(tǒng)會(huì)根據(jù)機(jī)器的情況自動(dòng)調(diào)低。也許你會(huì)回答:“恩我知道,設(shè)置太高,會(huì)有系統(tǒng)開銷...”那你有沒有思考過,這些開銷具體是什么呢?是什么工作導(dǎo)致了需要這些內(nèi)存開銷?也許你還會(huì)回答,在連接創(chuàng)建的時(shí)候,會(huì)立刻為它分配連接緩沖區(qū)以及查詢緩沖區(qū),這些都會(huì)吃內(nèi)存。那你有沒有思考過,占據(jù)的資源具體是多少呢?取決于哪些因素呢?好了,我們先結(jié)束這個(gè)問題。回到知乎的問題上來,其實(shí)我說了這么多,就是表達(dá)要如何自學(xué)mysql。所以的所以,你必須不斷思考,才能在工作中面對具體場景的時(shí)候,非常淡定地推斷:“哦,一定是這里出了問題。應(yīng)該怎么怎么做?!泵鎸栴},拿出打破砂鍋問到底的精神,先思考一番,給出自己的假設(shè),不要著急地去找度娘,谷歌。思考過后,帶著你的推斷或者答案,大膽地去搜索吧!去看看別人的見解,去看看官方的描述!這才是一個(gè)工程師應(yīng)有的態(tài)度。最后我想給出一些有價(jià)值的學(xué)習(xí)資料??梢允∪ヒ恍r(shí)間。-電子書:我認(rèn)為多看書還是有好處的。有些書值得反復(fù)看許多遍,有時(shí)候只看一遍無法深刻理解吸收,思考也不夠充分
看你基礎(chǔ)如何了.
你要是 什么都不知道的. 那么可能需要先掌握 基本的 SQL 語言, 然后再在 MYSQL 里面慢慢實(shí)踐。
你要是 僅僅知道基本的 SQL 語言的語法, 那么就可以直接 在 MySQL 里面做一些基本的實(shí)踐, 然后慢慢的多看一些 別人的例子。然后了解一些 MySQL 的函數(shù)之類的。
你要是 已經(jīng)對 SQL Server 或者 Oracle 比較熟練了,那么就可以直接 看看 MySQL 與 其他數(shù)據(jù)庫之間的差異?;旧暇涂梢粤?。不必從零開始了。