UPDATE worker_view4 SET name='hi';
秀嶼ssl適用于網站、小程序/APP、API接口等需要進行數據傳輸應用場景,ssl證書未來市場廣闊!成為成都創新互聯的ssl證書銷售渠道,可以享受市場價格4-6折優惠!如果有意向歡迎電話聯系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!
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)由不可更新的視圖導出的視圖。
CREATE VIEW worker_view6
AS SELECT * FROM worker_view5;
UPDATE worker_view6 SET name = '王仔';
因為worker_view6是不可更新的視圖,所以worker_view6也不可以更新的視圖。使用UPDATE語句更新時,會出現系統報錯。
(6)創建視圖時,ALGORITHM為TEMPTABLE類型。
CREATE ALGORITHM=TEMPTABLE
VIEW worker_view7
AS SELECT * FROM worker;
UPDATE worker_view7 SET name = '王仔';
因為該視圖ALGORITHM為TEMPTABLE類型,所以worker_view7不可以更新的視圖。TEMPTABLE類型就是臨時表類型。系統默認臨時表是不能更新的。
(7)視圖對應的表上存在沒有默認值的列,而且該列沒有包含在視圖里。例如,表中包含的name字段沒有默認值,但是視圖中不包含該字段。那么這個視圖是不能更新的。因為,在更新視圖時,這個沒有默認值的記錄將沒有值插入,也沒有NULL值插入。數據庫系統是不會允許這樣的情況出現的,數據庫系統將會阻止這個視圖更新。
注意:視圖中雖然可以更新數據,但是有很多的限制。一般情況下,最好將視圖作為查詢數據的虛擬表,而不要通過視圖來更新數據。因為,使用視圖更新數據時,如果沒有全面考慮在視圖中更新數據的限制,可能會造成數據更新失敗。
除了上述條件不能更新視圖以外,WITH[CASCADED|LOCAL]CHECK OPTION也將決定視圖能否更新。"LOCAL"參數表示更新視圖時要滿足該視圖本身的定義的條件即可;
8.6 刪除視圖
刪除視圖是指刪除數據庫中已經存在的視圖。刪除視圖時,只能刪除視圖的定義,不會刪除數據。MYSQL中,使用DROP VIEW語句來刪除視圖,不會刪除數據。MySQL中,使用DROP VIEW語句來刪除視圖。但是,用戶必須擁有DROP權限。
DROP VIEW[IF EXISTS] 視圖名列表 [RESTRICT|CASCADE]
實例一:
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 本章實例
在test數據庫中work_info表上進行視圖操作。
1. 在test數據庫中work_info表
2. 插入記錄
3. 創建視圖info_view
4. 查看視圖info_view的基本結構和詳細結構
5. 查看視圖info_view的所有記錄
6. 修改視圖info_view
7. 更新視圖
8. 刪除視圖
work_info表的結構
字段名 字段描述 數據類型 主鍵 外鍵 非空 唯一 自增
id 編號 INT(10) 是 否 是 是 否
name 姓名 VARCHAR(20) 否 否 是 否 否
gender 姓別 VARCHAR(4) 否 否 是 否 否
age 年齡 INT(5) 否 否 否 否 否
address 家庭住址 VARCHAR(50) 否 否 否 否 否
tel 電話號碼 VARCHAR(20) 否 否 否 否 否
work_info表中的內容
id name gender age address tel
1 張三 M 18 北市市海淀區 01-155151
2 李四 M 22 北京市昌平區 01-215151
3 王五 F 17 湖南省永州市 025-545845
4 趙六 F 25 遼寧省阜新市 0625-514545
(1) 創建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, '北市市海淀區','01-155151'),
(2,'李四', 'M', 22, '北京市昌平區', '01-215151'),
(3,'王五','F',17,'湖南省永州市','025-545845'),
(4,'趙六','F',25,'遼寧省阜新市','0625-514545');
(3) 創建視圖info_view。從work_info表中選出age20的記錄來創建視圖。視圖的字段包括id、name、gender和address。ALGORITHM設置為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的基本結構和詳細結構。
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的記錄進行更新。設置其gender為M。
UPDATE info_view SET gender='M' WHERE id=3;
(8)刪除視圖。
DROP VIEW info_view;
8.8 上機實踐
題目要求:
(1)在數據庫example下創建college表。
(2)在college表上創建視圖college_view。視圖的字段包括student_num、student_name、student_age和department。ALGORITHM設置為UNDEFINED類型。加上WITH LOCAL CHECK OPTION條件。
(3)查看視圖college_view的詳細結構。
(4)更新視圖。向視圖中插入三條記錄。
(5)修改視圖,使其顯示專業為"計算機"的信息,其他條件不變。
(6)刪除視圖college_view。
college表的結構
字段名 字段描述 數據類型 主鍵 外鍵 非空 唯一 自增
number 學號 INT(10) 是 否 是 是 否
name 姓名 VARCHAR(20) 否 否 是 否 否
major 專業 VARCHAR(20) 否 否 是 否 否
age 年齡 INT(5) 否 否 否 否 否
college_view表的內容
student_num student_name student_age department
0901 張三 20 外語
0902 李四 22 計算機
0903 王五 19 計算機
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, '計算機'),
(0903, '王五', 19, '計算機');
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='計算機'
WITH LOCAL CHECK OPTION;
先給出我的核心觀點:
學習,無論你是學什么,也無論你有沒有基礎。思考永遠是第一位的,有些知識你沒接觸過不要緊,用不著害怕,也沒必要害怕。重要的是一秒鐘也不要停止思考,問題要想透徹,正所謂磨刀不誤砍柴工。尤其是作為工程師,要有打破砂鍋問到底的精神,否則你怎么學都沒用。
首先,學習基本的SQL語法。完成這個后,你就可以編寫SQL語句了。這一步推薦:W3Schools的 SQL 教程。
其次,學習數據庫的主要功能和使用方法,比如用戶相關或者權限相關等等。
我推薦兩本書:
一、《MySQL必知必會》 這本書講的非常全,從基本概念,到查詢到插入新建表,用戶的管理,都有具體的例子,非常適合沒有任何基礎的同學來學習Mysql,總之這本書學習的方法就是:1、十分鐘了解下數據庫的基本概念 2、找到練手的數據庫 3、對照著上面的內容去敲。本書里也有大量的內容是講sql的,可以結合w3c的sql教程一起,有取舍地看。
二、《數據庫系統概念》這本書是dba必看的。看完這些并且實踐+思考之后,可以算入門了。接下來對于希望深入學習的童鞋我推薦幾本書(很多大神都這么推薦),《高性能MySQL(第3版)》、 《MySQL技術內幕(第4版)》,《MySQL技術內幕 InnoDB存儲引擎》,《深入理解MySQL》還有Mysql的官網。讀完這些東西,再加些豐富的經驗,理論上來講就具備DBA的水平了。十分推薦閱讀Planet MySQL上匯總的博客,特別是Percona's MySQL InnoDB performance and scalability blog但是,正如我開頭所言的。
面對問題的時候一定要積極思考!比如:我問你,面對一個并發量比較高的場景,如何配置mysql的連接數?你可能會回答:“哦,就是調高max_connection的數值吧。”那,你有沒有思考過調到多少是最合適的呢?為什么這樣設置就最合適呢?也許你會回答:“恩我知道,可以看系統之前的max_used_connection的數值,然后來設置。也可以調高back_log的值。”那你有沒有思考過,max_connection連接數太高會有什么不好的影響呢?back_log設置的太高有什么不好的地方呢?max_connect的上限其實是取決于mysql能獲得的文件描述符的數量,也就是說你就算設置成10000,最后也是沒用的,系統會根據機器的情況自動調低。也許你會回答:“恩我知道,設置太高,會有系統開銷...”那你有沒有思考過,這些開銷具體是什么呢?是什么工作導致了需要這些內存開銷?也許你還會回答,在連接創建的時候,會立刻為它分配連接緩沖區以及查詢緩沖區,這些都會吃內存。那你有沒有思考過,占據的資源具體是多少呢?取決于哪些因素呢?好了,我們先結束這個問題。回到知乎的問題上來,其實我說了這么多,就是表達要如何自學mysql。所以的所以,你必須不斷思考,才能在工作中面對具體場景的時候,非常淡定地推斷:“哦,一定是這里出了問題。應該怎么怎么做。”面對問題,拿出打破砂鍋問到底的精神,先思考一番,給出自己的假設,不要著急地去找度娘,谷歌。思考過后,帶著你的推斷或者答案,大膽地去搜索吧!去看看別人的見解,去看看官方的描述!這才是一個工程師應有的態度。最后我想給出一些有價值的學習資料。可以省去一些時間。-電子書:我認為多看書還是有好處的。有些書值得反復看許多遍,有時候只看一遍無法深刻理解吸收,思考也不夠充分
對于非計算機出身的我,大學只會hello word和跑馬燈,期間過程確實非常曲折,分享下我的自學過程:
1、 自己在windows和linux上安裝了mysql,自學linux的基礎知識,學習mysql的最基礎的知識,即怎么寫sql,存儲過程,表的設計等,從0到熟悉大概花了3個月 ,推薦《mysql入門很簡單》。
2、系統地較為深入地學習mysql的sql優化,備份和恢復,參數優化,架構優化,硬件層面的優化,高可用方案,復制技術等等,這段時間你不一定能實際接觸到這些,就像我當初那樣,肯定沒什么公司招一個小白。 我選擇自己看書,推薦《高性能mysql》,里面所有的章節都需要看一遍,以現在的水平肯定看不懂,但需要知道大概怎么回事,為后續的找mysql初級dba的工作打一個鋪墊,這個過程大概也需要3個月。
3、 紙上得來終覺淺,完成以上兩步,我開始準備找一份mysql相關的工作,而不是天天用著excel表格做著select * from table_sb這樣的工作。 當然我這么猥瑣的人肯定不會裸辭,該畫的電路板也一樣畫,業余時間開始投初級mysql dba的工作,并且不間斷地學習,網上各種找mysql面試的相關題目(實際上我當時完全沒有任何實戰經驗),陸續收到一些面試,憑借之前自學的mysql知識,開始胡亂吹牛逼,先混進去再說。 你不做mysql實際相關的工作,永遠也不知道自己之前認知的db知識有多幼稚。 友情提示一點,一般公司都沒有專職dba的,所以面試的時候一定要自信,其實你學了這么多,雖然毫無實戰經驗,理論知識很大概率比面試你的人牛逼,所以各種吹,我就這樣真正進入初級dba的圈子(由于這時對linux還處于cd ls的水平,所以之前也根本沒做過運維),這個邊工作邊找工作的過程又持續了2個月。
4、真正進入互聯網,接觸生產環境后,這是我進步最大的時候。 第一步需要將之前所學真正地應用起來,并且應用的過程中,再回頭看之前的書籍,這時候需要真正去理解,而不是似是而非,一知半解。 這時再推薦《高性能mysql 第三版》,全本再看一遍,這時需要全部看懂,另外還有《mysql技術內幕:innodb存儲引擎》等等。 總之這段時間就需要開始關注mysql一些細節了,比如db故障處理,高可用,負載均衡等等的具體實現了。 另外,linux的知識同步也要深入去學習,至少會寫shell腳本,常見的linux知識等,我在這花了1年多;
5、 dba的工作一般是非常輕閑的,畢竟不是大公司,技術能力有限,該學的也學得差不多了,接觸不到海量數據,高并發等比較鍛煉人的場合,于是我又準備跳了。 于是來了公有云,現在每天運維萬多個db實例,平均每天處理5+個緊急db故障,幾乎mysql會遇到的問題,感覺都遇到了,能感覺到技術實力和經驗也在每天都在積累,在進步。 但是感覺還是欠缺了很多,下一步就看你選擇了,是再去研究源代碼,底層原理的東西多點,還是數據庫運維和應用多一點,就比如業界姜承堯,何登成與葉金榮的區別。 由于我的歷史原因,對c++等幾乎不懂,平時也用不到,所以看代碼等事實際太累,于是我再去學mongodb,接了公司mongodb運維的活,算是在廣度上的一個擴展,萬一哪天mysql不行了呢
6、 總之,對于db小白來說,最重要的一點就是,學習的過程不能斷。 PS 上面的方法比較野路子,適合沒什么基礎的童鞋,如果本來就是DBA,比如從oracle轉到mysql,那么建議直接看mysql官方文檔,而官方文檔是db達到一定水平后必看,出問題時必查的權威文檔。
最近,有很多學員留言讓我整理一下“零基礎如何mysql學習?”.今天青島電腦培訓就整理一下學習MySQL你需要掌握的知識點以及送給新手學習的建議,希望對大家能夠有所幫助!給新手的學習建議:1.在學習新的東西的時候,我們至少從三個問題開始。
What?why?how?2.學習需要堅持,如果還沒準備好堅持半年比較枯燥的MySQL之旅,那么就別開始。
3.學習東西不在多,在精,市面上有非常多的MySQL教程,不要瞎學,今天這里學一點,明天那里學一點,這樣你學的都只是知識點,無法形成一個知識面,知識網絡。
4.在學習過程中充滿好奇,使用google進行問題搜索,千萬不要使用度娘了,質量不高。
至于怎么用Google,請自行搜索。
5.學習的目的在于使用,因此,不要僅僅看書,看一遍,看兩遍,你可能還是沒什么感覺。
因此學習一開始,就要動手練習,把資料上的情況,模擬一下。
6.請不要在windows上安裝mysql進行學習,因為工作中都是linux系統。
我們需要從一開始就是實戰,就是生產環境。
7.保持好心態,一步一個腳印的前進。
學習MySQL你需要掌握的知識點:1.系統,當然windos基本的要會。
然后就是Linux系統,現在做MySQLDBA的系統多數都是Linux系統,而生產環境大多又是RedHat,Centos。
其他的Linux和Unix系統可以只做了解。
2.Linux基礎,網絡,IO,內存,磁盤,CPU。
包括不限于安裝,啟動過程,目錄結構,遠程登錄,文件屬性與管理,用戶與用戶權限,LAMP結構vim,yum等shell命令,dns,ftp,以及一些常用工具。
3.MySQL基礎:MySQL安裝、MySQL體系結構,SQL,MySQL管理維護。
4.數據備份與恢復,常用的引擎:MyISAM、Innodb、NDB等。
5.數據庫設計優化,一個好的MySQL系統,往往從設計開始。
6.SQL優化,參數優化,監控,安全等。
7.MySQL負載均衡,讀寫分離,MHA,MMM高可用架構,以及分布式架構:mycat、maxscale、galeracluster、MySQLGroupReplication等。
8.mysql5.6,mysql5.7新特性,mariadb、percona分支的差異和特點。
9.MySQLJSON、MySQLmemcached。
10.常見MySQL搭配的緩存系統,redis,memcached,以及NOSQL、NEWSQL。
以上,就是小編為大家整理的mysql學習你需要掌握的知識點以及送給新手學習的建議,希望能夠幫助到大家!
自學:
1:b站上有很多mysql的學習視頻,都是各個培訓機構往期的培訓視頻
2、淘寶上搜mysql,有很多店主整理好的培訓視頻,大概三五塊錢就有很多
3、51cto,慕課網,csdn之類的網站,上邊也有很多培訓視頻,有需要會員的,也有免費的
需要注意下視頻的培訓日期以及數據庫版本,最好是選最近兩年的培訓視頻,51cto風哥的視頻就挺詳細的,就是有點貴
培訓機構:
有很多線下的和線上的培訓機構,例如晟數學苑,老男孩等等,培訓的機構海了去了,自己了解下哪個機構比較好,報名就是了,就是需要花不少的錢
如果想以此就業的話,也可以去考慮去考下mysql的認證,mysql ocp也就一千來塊錢
如果你沒有 MySQL 的基礎,建議可以看看以下書籍:
《MySQL 必知必會》:主要講 SQL 的寫法
《深入淺出 MySQL》:比較全面的講解了 MySQL 的基礎知識,也涉及了一些優化。
如果已經對 MySQL 比較熟悉了,可以看下面的書籍:
《高性能 MySQL》:里面講了很多 MySQL 優化技巧。
《MySQL 技術內幕》:講解了很多 MySQL 原理,強力推薦給想深入學習 MySQL 的同學。
《MySQL 內核:InnoDB 存儲引擎》:想深入研究 MySQL 內核及原理的可以看看。
《MySQL 運維內參》:對 MySQL 源碼感興趣,可以入手。
《MySQL Internals Manual》
《MySQL 5.7 Reference Manual》
網頁標題:mysql數據庫怎么學習 mysql數據庫學什么
文章位置:http://m.kartarina.com/article32/dodespc.html
成都網站建設公司_創新互聯,為您提供網站內鏈、營銷型網站建設、手機網站建設、App設計、全網營銷推廣、域名注冊
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯