MySQL視圖和索引專篇精講
數(shù)據(jù)庫版本:mysql8。0.27
如果以下代碼執(zhí)行有問題歡迎一起探討
視圖View
什么是視圖?
視圖是一個虛擬表,是sql語句的查詢結(jié)果,其內(nèi)容由查詢定義。同真實的表一樣,視圖包含一系列帶有名稱的列和行數(shù)據(jù),在使用視圖時動態(tài)生成。視圖的數(shù)據(jù)變化會影響到基表,基表的數(shù)據(jù)變化也會影響到視圖[insertupdate delete ] ; 創(chuàng)建視圖需要create view 權(quán)限,并且對于查詢涉及的列有select權(quán)限;使用create or replace 或者 alter修改視圖,那么還需要改視圖的drop權(quán)限。
代碼實現(xiàn):
學生成績表
建立視圖
-- v_a是視圖名 create view v_a as select id,name,score,dept from s1;
查詢視圖
-- 查詢視圖v_a select*FROM v_a; -- 查詢視圖時可以增加條件 select*FROM v_a where id=4; -- 查詢數(shù)據(jù)庫中的全部視圖 select `TABLE_NAME` from `INFORMATION_SCHEMA`.`TABLES` where `TABLE_SCHEMA` = 'test' and `TABLE_TYPE` = 'view';
刪除視圖
drop view v_a
索引index
- MySQL索引的建立對于MySQL的高效運行是很重要的,索引可以大大提高MySQL的檢索速度。
- 打個比方,如果合理的設計且使用索引的MySQL是一輛蘭博基尼的話,那么沒有設計和使用索引的MySQL就是一個人力三輪車。
- 拿漢語字典的目錄頁(索引)打比方,我們可以按拼音、筆畫、偏旁部首等排序的目錄(索引)快速查找到需要的字。
- 索引分單列索引和組合索引。單列索引,即一個索引只包含單個列,一個表可以有多個單列索引,但這不是組合索引。組合索引,即一個索引包含多個列。
- 創(chuàng)建索引時,你需要確保該索引是應用在 SQL 查詢語句的條件(一般作為 WHERE 子句的條 件)。
- 實際上,索引也是一張表,該表保存了主鍵與索引字段,并指向?qū)嶓w表的記錄。
- 上面都在說使用索引的好處,但過多的使用索引將會造成濫用。因此索引也會有它的缺點:雖然索引大大提高了查詢速度,同時卻會降低更新表的速度,如對表進行INSERT、UPDATE和DELETE。因為更新表時,MySQL不僅要保存數(shù)據(jù),還要保存一下索引文件。
- 建立索引會占用磁盤空間的索引文件。
建立索引
創(chuàng)建表時建立
-- 第一種方式 create table t1 ( t varchar(20), KEY(t desc) ) -- 第二種方式 create table t1 ( t varchar(20), index aa(t(20)) )
修改表時建立索引
-- 該語句添加一個主鍵,這意 味著索引值必須是唯一的,且不能為NULL。 ALTER TABLE tbl_name ADD PRIMARY KEY (column_list); -- 這條語句創(chuàng)建索引的 值必須是唯一的(除了NULL外,NULL可能會出現(xiàn)多次)。 ALTER TABLE tbl_name ADD UNIQUE index_name (column_list); -- 添加普通索引,索引 值可出現(xiàn)多次。 ALTER TABLE tbl_name ADD INDEX index_name (column_list); -- 該語句指定了索引 為 FULLTEXT ,用于全文索引。 ALTER TABLE tbl_name ADD FULLTEXT index_name (column_list);
刪除索引
drop index t on t;
到此這篇關于MySQL視圖和索引專篇精講的文章就介紹到這了,更多相關MySQL視圖和索引內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
MySQL left join操作中on和where放置條件的區(qū)別介紹
這篇文章主要給大家介紹了關于MySQL left join操作中on和where放置條件的區(qū)別的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧2019-01-01MySQL:explain結(jié)果中Extra:Impossible?WHERE?noticed?after?rea
這篇文章主要介紹了MySQL:explain結(jié)果中Extra:Impossible?WHERE?noticed?after?reading?const?tables問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12CentOS7下MySQL5.7安裝配置方法圖文教程(YUM)
這篇文章主要為大家詳細介紹了CentOS7下MySQL5.7安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-01-01mysql格式化小數(shù)保留小數(shù)點后兩位(小數(shù)點格式化)
今天遇到一個問題,格式化浮點數(shù)的問題,用format(col,2)保留兩位小數(shù)點,出現(xiàn)一個問題,例如下面的語句,后面我們給出解決方法2013-12-12MySQL slave_net_timeout參數(shù)解決的一個集群問題案例
這篇文章主要介紹了MySQL slave_net_timeout參數(shù)解決的一個集群問題案例,問題日志請見正文,本文使用slave_net_timeout參數(shù)解決了這個問題,需要的朋友可以參考下2015-05-05