資料庫中view
❶ 試述關系資料庫系統中視圖的定義,引進view的概念有什麼意義
試述關系資料庫系統中視圖(VIEW)的定義,引進VIEW的概念有什麼優點。
答案 視圖是從一個或幾個基本表導出的表。視圖本身不獨立存儲在資料庫中,是一個虛表。即資料庫中只存放視圖的定義而不存放視圖對應的數據,這些數據仍存放在導出視圖的基本表中。視圖在概念上與基本表等同,用戶可以如同基本表那樣使用視圖,可以在視圖上再定義視圖。引進VIEW的優點有: (1)視圖能夠簡化用戶的操作。 (2)視圖使用戶能以多種角度看待同一數據。 (3)視圖對重構資料庫提供了一定程度的邏輯獨立性。 (4)視圖能夠對機密數據提供安全保護。
❷ 什麼是資料庫視圖
聯系:視圖(view)是在基本表之上建立的表,它的結構(即所定義的列)和內容(即所有數據行)都來自基本表,它依據基本表存在而存在。一個視圖可以對應一個基本表,也可以對應多個基本表。視圖是基本表的抽象和在邏輯意義上建立的新關系
區別:1、視圖是已經編譯好的sql語句。而表不是
2、視圖沒有實際的物理記錄。而表有。
3、表是內容,視圖是窗口
4、表只用物理空間而視圖不佔用物理空間,視圖只是邏輯概念的存在,表可以及時四對它進行修改,但視圖只能有創建的語句來修改
5、表是內模式,視圖是外模式
6、視圖是查看數據表的一種方法,可以查詢數據表中某些欄位構成的數據,只是一些sql語句的集合。從安全的角度說,視圖可以不給用戶接觸數據表,從而不知道表結構。
7、表屬於全局模式中的表,是實表;視圖屬於局部模式的表,是虛表。
8、視圖的建立和刪除隻影響視圖本身,不影響對應的基本表。
❸ 在SQL中table與view的區別
區別本質就是View(視圖)和Controller(控制器)的區別,其實用區別一詞來形容不太恰當,用關系一詞來形容會比較合理。
簡單來說,可以把TableView理解成一個UI控制項,這個控制項有自己的一些屬性,比如位置、高度、寬度、cell的數量等等,而TableViewController就是告訴TableView應該以什麼樣的形象出現在用戶的面前 !
❹ 資料庫中的視圖有什麼用,我們為什麼要用視圖
用來進行數據展示和分析。使用視圖可以定製用戶數據,聚焦特定的數據。
視圖是原始資料庫數據的一種變換,是查看錶中數據的另外一種方式。可以將視圖看成是一個移動的窗口,通過它可以看到感興趣的數據。
視圖是從一個或多個實際表中獲得的,這些表的數據存放在資料庫中。那些用於產生視圖的表叫做該視圖的基表。一個視圖也可以從另一個視圖中產生。
視圖的定義存在資料庫中,與此定義相關的數據並沒有再存一份於資料庫中。通過視圖看到的數據存放在基表中。
視圖可以在以下幾個方面使程序與數據獨立:
如果應用建立在資料庫表上,當資料庫表發生變化時,可以在表上建立視圖,通過視圖屏蔽表的變化,從而應用程序可以不動。
如果應用建立在資料庫表上,當應用發生變化時,可以在表上建立視圖,通過視圖屏蔽應用的變化,從而使資料庫表不動。
如果應用建立在視圖上,當資料庫表發生變化時,可以在表上修改視圖,通過視圖屏蔽表的變化,從而應用程序可以不動。
如果應用建立在視圖上,當應用發生變化時,可以在表上修改視圖,通過視圖屏蔽應用的變化,從而資料庫可以不動。
❺ 資料庫中的procere和view有什麼區別請問
Procere就像是執行子查詢表格,接受參數,你可以用where或者order by這樣的參數經行進一步的定義
Procere被定義出來之後,非常的方便,下次如果需要調用相同的命令,就直接把procere名字打上去就能顯示結果,通常為內部人員使用。
View本身就是顯示一個表格,View可以顯示出表格,但是VIEW本身並沒有包括任何數據,view也不接受參數,所以其實view就是一個虛擬的表格,而不是實際的,所以在需要參數的時候,需要提前在建立view的時候定義好。VIEW一般是給外部非專業IT人員使用,因為你可以隨意修改名稱並限定輸出的內容。
❻ 關於向資料庫中的view插入數據
有的VIEW可以插入數據,數據會保存在相應的表中,看建立的語句。
補充:
各類資料庫可能對VIEW的INSERT和UPDATE規定有區別,下面是MYSQL的規定:
關於可插入性(可用INSERT語句更新),如果它也滿足關於視圖列的下述額外要求,可更新的視圖也是可插入的:
·不得有重復的視圖列名稱。
·視圖必須包含沒有默認值的基表中的所有列。
·視圖列必須是簡單的列引用而不是導出列。導出列不是簡單的列引用,而是從表達式導出的。下面給出了一些導出列示例:
·3.14159
·col1+3
·UPPER(col2)
·col3/col4
·(subquery)
混合了簡單列引用和導出列的視圖是不可插入的,但是,如果僅更新非導出列,視圖是可更新的。考慮下述視圖:
CREATEVIEWvASSELECTcol1,1AScol2FROMt;
該視圖是不可插入的,這是因為col2是從表達式導出的。但是,如果更新時不更新col2,它是可更新的。這類更新是允許的:
UPDATEvSETcol1=0;
下述更新是不允許的,原因在於,它試圖更新導出列:
UPDATEvSETcol2=0;
❼ mysql中怎麼查看view中的內容
在Mysql中,infomation_schema資料庫下的views表裡存儲了所有視圖的定義,可以通過views表查詢視圖的詳細信息。
❽ 資料庫中表與視圖有什麼聯系與區別
區別
1、視圖是已經編譯好的sql語句,而表不是;
2、視圖沒有實際的物理記錄,而表有;
3、表是內容,視圖是窗口;
4、表佔用物理空間而視圖不佔用物理空間,視圖只是邏輯概念的存在,表可以及時對它進行修改,但視圖只能用創建的語句來修改;
5、表是內模式,試圖是外模式;
6、視圖是查看數據表的一種方法,可以查詢數據表中某些欄位構成的數據,只是一些SQL語句的集合,從安全的角度說,視圖可以不給用戶接觸數據表,從而不知道表結構;
7、表屬於全局模式中的表,是實表,視圖屬於局部模式的表,是虛表;
8、視圖的建立和刪除隻影響視圖本身,不影響對應的基本表;
9、不能對視圖進行update或者insert into操作。
聯系
1、視圖(view)是在基本表之上建立的表,它的結構(即所定義的列)和內容(即所有數據行)都來自基本表,它依據基本表存在而存在;
2、一個視圖可以對應一個基本表,也可以對應多個基本表;
3、視圖是基本表的抽象和在邏輯意義上建立的新關系。
總結:
視圖是一個子查詢,性能肯定會比直接查詢要低(盡管sql內部有優化),所以使用視圖時有一個必須要注意的,就是不要嵌套使用查詢,尤其是復雜查詢。
視圖有什麼用
1、當一個查詢需要頻頻的作為子查詢使用時,視圖可以簡化代碼,直接調用而不是每次都去重復寫這個東西。
2、系統的資料庫管理員需要給他人提供一張表的某兩列數據,而不希望他可以看到其他任何數據,這時可以建一個只有這兩列數據的視圖,然後把視圖公布給他。
性能損失解決方案
對視圖的查詢語句進行優化。
通常來說直接查詢和查詢視圖是沒有什麼區別的(sql 本身會進行優化),除非是視圖嵌套了視圖,或者子查詢很復雜要計算。
特別說明:
每次SELECT視圖的時候,視圖都會重新計算創建它的規則(sql演算法),如果演算法復雜,數據量大,就會比較慢,那樣每次就很慢了。
而且,表的索引對於視圖view來說是無效的,它是全表掃描的。
❾ 資料庫中的view有何作用
視圖是把現在有數據組合成新的形式展示出來,相當於一張虛擬的表,運行時用來呈現數據。 視圖和存儲過程的區別只能查。。。增刪改是不行的 好處是 不用存儲在資料庫里。。
❿ 資料庫的視圖(VIEW)增加一個列是用UPDATE 還是INSERT 具體如何實現,請舉個例子
您好,CREATE VIEW
創建一個虛擬表,該表以另一種方式表示一個或多個表中的數據。CREATE VIEW 必須是查詢批處理中的第一條語句。
語法
CREATE VIEW [ < database_name > .] [ < owner > .] view_name [ ( column [ ,...n ] ) ]
[ WITH < view_attribute > [ ,...n ] ]
AS
select_statement
[ WITH CHECK OPTION ]
< view_attribute > ::=
{ ENCRYPTION | SCHEMABINDING | VIEW_METADATA }
參數
view_name
是視圖的名稱。視圖名稱必須符合標識符規則。可以選擇是否指定視圖所有者名稱。
column
是視圖中的列名。只有在下列情況下,才必須命名 CREATE VIEW 中的列:當列是從算術表達式、函數或常量派生的,兩個或更多的列可能會具有相同的名稱(通常是因為聯接),視圖中的某列被賦予了不同於派生來源列的名稱。還可以在 SELECT 語句中指派列名。
如果未指定 column,則視圖列將獲得與 SELECT 語句中的列相同的名稱。
說明 在視圖的各列中,列名的許可權在 CREATE VIEW 或 ALTER VIEW 語句間均適用,與基礎數據源無關。例如,如果在 CREATE VIEW 語句中授予了 title_id 列上的許可權,則 ALTER VIEW 語句可以將 title_id 列改名(例如改為 qty),但許可權仍與使用 title_id 的視圖上的許可權相同。
n
是表示可以指定多列的佔位符。
AS
是視圖要執行的操作。
select_statement
是定義視圖的 SELECT 語句。該語句可以使用多個表或其它視圖。若要從創建視圖的 SELECT 子句所引用的對象中選擇,必須具有適當的許可權。
視圖不必是具體某個表的行和列的簡單子集。可以用具有任意復雜性的 SELECT 子句,使用多個表或其它視圖來創建視圖。
在索引視圖定義中,SELECT 語句必須是單個表的語句或帶有可選聚合的多表 JOIN。
對於視圖定義中的 SELECT 子句有幾個限制。CREATE VIEW 語句不能:
包含 COMPUTE 或 COMPUTE BY 子句。
包含 ORDER BY 子句,除非在 SELECT 語句的選擇列表中也有一個 TOP 子句。
包含 INTO 關鍵字。
引用臨時表或表變數。
因為 select_statement 使用 SELECT 語句,所以在 FROM 子句中指定 <join_hint> 和 <table_hint> 提示是有效的。有關更多信息,請參見 FROM 和 SELECT。
在 select_statement 中可以使用函數。
select_statement 可使用多個由 UNION 或 UNION ALL 分隔的 SELECT 語句。
WITH CHECK OPTION
強制視圖上執行的所有數據修改語句都必須符合由 select_statement 設置的准則。通過視圖修改行時,WITH CHECK OPTION 可確保提交修改後,仍可通過視圖看到修改的數據。
WITH ENCRYPTION
表示 SQL Server 加密包含 CREATE VIEW 語句文本的系統表列。使用 WITH ENCRYPTION 可防止將視圖作為 SQL Server 復制的一部分發布。
SCHEMABINDING
將視圖綁定到架構上。指定 SCHEMABINDING 時,select_statement 必須包含所引用的表、視圖或用戶定義函數的兩部分名稱 (owner.object)。
不能除去參與用架構綁定子句創建的視圖中的表或視圖,除非該視圖已被除去或更改,不再具有架構綁定。否則,SQL Server 會產生錯誤。另外,如果對參與具有架構綁定的視圖的表執行 ALTER TABLE 語句,而這些語句又會影響該架構綁定視圖的定義,則這些語句將會失敗。
VIEW_METADATA
指定為引用視圖的查詢請求瀏覽模式的元數據時,SQL Server 將向 DBLIB、ODBC 和 OLE DB API 返回有關視圖的元數據信息,而不是返回基表或表。瀏覽模式的元數據是由 SQL Server 向客戶端 DB-LIB、ODBC 和 OLE DB API 返回的附加元數據,它允許客戶端 API 實現可更新的客戶端游標。瀏覽模式的元數據包含有關結果集內的列所屬的基表信息。
對於用 VIEW_METADATA 選項創建的視圖,當描述結果集中視圖內的列時,瀏覽模式的元數據返回與基表名相對的視圖名。
當用 VIEW_METADATA 創建視圖時,如果該視圖具有 INSERT 或 UPDATE INSTEAD OF 觸發器,則視圖的所有列(timestamp 除外)都是可更新的。請參見本主題後面的"可更新視圖"。
注釋
只能在當前資料庫中創建視圖。視圖最多可以引用 1,024 列。
通過視圖進行查詢時,Microsoft® SQL Server™ 將檢查以確定語句中任意位置引用的所有資料庫對象是否都存在,這些對象在語句的上下文中是否有效,以及數據修改語句是否沒有違反任何數據完整性規則。如果檢查失敗,將返回錯誤信息。如果檢查成功,則將操作轉換成對基礎表的操作。
如果某個視圖依賴於已除去的表(或視圖),則當有人試圖使用該視圖時,SQL Server 將產生錯誤信息。如果創建了新表或視圖(該表的結構與以前的基表沒有不同之處)以替換除去的表或視圖,則視圖將再次可用。如果新表或視圖的結構發生更改,則必須除去並重新創建該視圖。