搜尋
首頁資料庫mysql教程Oracle 学习笔记 11

Oracle 学习笔记 11

Jun 07, 2016 pm 03:37 PM
oracle學習概念筆記

本次必须学习一个全新的概念-- 视图 (VIEW)。在前面的笔记中曾提到过,数据对象包括:表、视图、序列、索引和同义 词。前面的笔记都是对表的想剖析,那么本次笔记就对视图的世界进行深入的剖析。 视图是通过对一个表或者是多个表查询得到的,是从表中抽出的

本次必须学习一个全新的概念-- 视图 (VIEW)。在前面的笔记中曾提到过,数据对象包括:表、视图、序列、索引和同义词。前面的笔记都是对表的想剖析,那么本次笔记就对视图的世界进行深入的剖析。

      视图是通过对一个表或者是多个表查询得到的,是从表中抽出的逻辑上相关的数据集合。但是视图是一种虚表,它建立在已经存在表的基础之上,也可以理解为表中导出的“表”。视图定义所依据的表称为基表,有点类似与JAVA中的父类(基类)。

     利用视图可以控制对数据的访问,简化查询,可以避免直接对数据库中真实存在的表进行直接访问,提高数据库的安全性。


创建视图


 创建视图语法格式:    


CREATE [OR ERPLACE ]  VIEW   view_name   

as  子查询 [WITH READ ONLY] | [WITH CHECK OPTION];

子查询可以是复杂的语句,如多个表之间的连接,子查询可以使用单行函数。可以通过给子查询中的列定义别名

来为视图的列定义成想要的名字。


例:创建视图,依赖emp表。

SQL> create view emp_view 
  2  as select empno ,ename ,sal from emp ;
 
View created

在用soctt用户执行上述语句的时候,可能会提示,没有创建视图的权限。可用下面的操作解决。

Oracle - OraClient10g_home1 --> Oracle EnterPrise Manager Console -->连接身份DBA

-->安全性-->用户-->scott --> 双击-->系统 --> 添加create any view 权限-->确定


现在对视图进行查询。

SQL> select * from  emp_view ;
 
EMPNO ENAME            SAL
----- ---------- ---------
 7369 SMITH         800.00
 7499 ALLEN        1600.00
 7521 WARD         1250.00
 7566 JONES        2975.00
 7654 MARTIN       1250.00
 7698 BLAKE        2850.00
 7782 CLARK        2450.00
 7788 SCOTT        3000.00
 7839 KING         5000.00
 7844 TURNER       1500.00
 7876 ADAMS        1100.00
 7900 JAMES         950.00
 7902 FORD         3000.00
 7934 MILLER       1300.00
 
14 rows selected

emp_view视图定义之后,在此创建emp_view 视图时,会提示名称已经由现有对象使用,说明视图的名称不

允许重复。如果想依然使用emp_view视图,可以使用 :

create or replace view emp_view as select empno ,ename ,sal from emp 。虽然已经创

了emp_view语句,仍然可以创建成功。系统会删除emp_view视图,在创建一个新的视图。对视图仍然可以

行相关的插入更新操作,对视图的操作都会返回到基表中,和直接对表的操作效果一样。

例:对视图进行插入删除操作。将ename为JAMES的工资改为2000 ,插入一条新的数据。

SQL> update emp_view set sal = 2000 where ename = 'JAMES' ;

SQL> insert into emp_view values(7935 , 'zhangsan' , 5000);

下面看一下操作结果:

SQL> select * from emp_view where ename = 'JAMES' ;
 
EMPNO ENAME            SAL
----- ---------- ---------
 7900 JAMES        2000.00
 
SQL> select * from emp  where ename = 'JAMES' ;
 
EMPNO ENAME      JOB         MGR HIREDATE          SAL      COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
 7900 JAMES      CLERK      7698 1981/12/3     2000.00               30


SQL> select * from emp_view  where ename='zhangsan' ; 
 
EMPNO ENAME            SAL
----- ---------- ---------
 7935 zhangsan     5000.00
 
SQL> select * from emp where ename='zhangsan';
 
EMPNO ENAME      JOB         MGR HIREDATE          SAL      COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
 7935 zhangsan                                 5000.00           

上面使用DML语句进行了插入和更新操作。但是视图使用DML时还有一些特别的规定:

当视图定义中包含以下元素时,不能使用delete:

组函数、GROUP BY 、DISTINST 和 ROWNUM 伪列。

当视图定义中包含以下元素时,不能使用update:

组函数、GROUP BY 、DISTINST 、 ROWNUM 伪列和列的定义表达式。

当视图定义中包含以下元素时,不能使用insert:

组函数、GROUP BY 、DISTINST 、 ROWNUM 伪列、列的定义表达式和表中非空的列在视图中未包括。

如果创建的视图只是为了让人浏览的内容而不能修改或者插入新的数据的话,那么需要在创建视图的时候添加限制(with read only) 只读的 。

create or replace view emp_view
as select empno ,ename ,sal from emp 
with read only

此时在执行update语句 update emp_view set sal = 2000 where ename = 'JAMES',会出现
ORA-01733: 此处不允许虚拟列提示 。


with check option :不能更新视图的创建条件。此处不在赘述。


前面在执行多表查询的时候,有这样的一条语句,将emp表和dept表进行联立。

select empno  ,ename , dname ,e.deptno
from emp e , dept d 
where d.deptno  = e.deptno 


EMPNO ENAME      DNAME          DEPTNO
----- ---------- -------------- ------
 7369 SMITH      RESEARCH           20
 7499 ALLEN      SALES              30
 7521 WARD       SALES              30
 7566 JONES      RESEARCH           20
 7654 MARTIN     SALES              30
 7698 BLAKE      SALES              30
 7782 CLARK      ACCOUNTING         10
 7788 SCOTT      RESEARCH           20
 7839 KING       ACCOUNTING         10
 7844 TURNER     SALES              30
 7876 ADAMS      RESEARCH           20
 7900 JAMES      SALES              30
 7902 FORD       RESEARCH           20
 7934 MILLER     ACCOUNTING         10
 
14 rows selected

如果在开发的过程中,要多次使用上面的多表连接的语句,那么肯定是非常麻烦的。所以此时可以将上面多表查

询的结果建立成一个试图。再次使用的时候就轻松多了 。

create view view_emp
as
select empno  ,ename , dname ,e.deptno
from emp e , dept d 
where d.deptno  = e.deptno 


当执行select * from view_emp ;语句时,与上面的多表查询的效果是一样的。使用试图可以简化操作。


删除视图

基本语法:

DROP VIEW view_name ;

删除视图只是删除用户自己创建的视图,不会对基表中的数据产生影响。

例:删除上面定义的视图emp_view 。

drop view emp_name ;

 

Rownum 伪列

    上面提到了一个新的知识点rownum 伪劣,下面进行具体的解释一下。rownum 有点类似与excel中的表示行

的序号。实际上这是一个列,伪劣,可以在每张表中出现。

例:查询表emp中的rownum 。

SQL> select rownum , empno from emp ;
 
    ROWNUM EMPNO
---------- -----
         1  7369
         2  7499
         3  7521
         4  7566
         5  7654
         6  7698
         7  7782
         8  7788
         9  7839
        10  7844
        11  7876
        12  7900
        13  7902
        14  7934
        15  7935
 
15 rows selected

如果现在想要查询工资从高到低的前五条的数据,那么

SQL> select rownum , empno,sal from emp where rownum  
    ROWNUM EMPNO       SAL
---------- ----- ---------
         1  7935   5000.00
         5  7566   2975.00
         3  7499   1600.00
         4  7521   1250.00
         2  7369    800.00

观察上面的数据,虽然是按照sal从高到低的排序,但是却不是我们想高的最高的五条数据的排序。其实rownum和empno之间有某种关系,想要打破这中关系,可以使用下面的语句。

select rownum , empno,sal
from(
   select rownum , empno,sal
    from emp order by sal desc
)
where rownum

 

    ROWNUM EMPNO       SAL
---------- ----- ---------
         1  7935   5000.00
         2  7839   5000.00
         3  7788   3000.00
         4  7902   3000.00
         5  7566   2975.00

上面的查询结果才是我们想要的结果。

如果我们想要查询3到8之间的数据呢 ?可以使用下面的数据

select rn ,empno ,sal from(
  select rownum rn , empno,sal
  from(
    select rownum , empno,sal
    from emp order by sal desc
  )
)
where rn >=3 and rn

 

 RN        EMPNO       SAL
------ ----- ---------
     3  7902   3000.00
     4  7788   3000.00
     5  7566   2975.00
     6  7698   2850.00
     7  7782   2450.00
     8  7900   2000.00
 
6 rows selected

              上面给rownum 起了一个别名,将这个伪劣化为了一个实实在在存在的列,便可以进行 where rn > = 3 和 rn

    操作了。

注意:

ROWNUM只能使用 而用=, >, >= 都将不能返回任何数据。

 

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
MySQL的位置:數據庫和編程MySQL的位置:數據庫和編程Apr 13, 2025 am 12:18 AM

MySQL在數據庫和編程中的地位非常重要,它是一個開源的關係型數據庫管理系統,廣泛應用於各種應用場景。 1)MySQL提供高效的數據存儲、組織和檢索功能,支持Web、移動和企業級系統。 2)它使用客戶端-服務器架構,支持多種存儲引擎和索引優化。 3)基本用法包括創建表和插入數據,高級用法涉及多表JOIN和復雜查詢。 4)常見問題如SQL語法錯誤和性能問題可以通過EXPLAIN命令和慢查詢日誌調試。 5)性能優化方法包括合理使用索引、優化查詢和使用緩存,最佳實踐包括使用事務和PreparedStatemen

MySQL:從小型企業到大型企業MySQL:從小型企業到大型企業Apr 13, 2025 am 12:17 AM

MySQL適合小型和大型企業。 1)小型企業可使用MySQL進行基本數據管理,如存儲客戶信息。 2)大型企業可利用MySQL處理海量數據和復雜業務邏輯,優化查詢性能和事務處理。

幻影是什麼讀取的,InnoDB如何阻止它們(下一個鍵鎖定)?幻影是什麼讀取的,InnoDB如何阻止它們(下一個鍵鎖定)?Apr 13, 2025 am 12:16 AM

InnoDB通過Next-KeyLocking機制有效防止幻讀。 1)Next-KeyLocking結合行鎖和間隙鎖,鎖定記錄及其間隙,防止新記錄插入。 2)在實際應用中,通過優化查詢和調整隔離級別,可以減少鎖競爭,提高並發性能。

mysql:不是編程語言,而是...mysql:不是編程語言,而是...Apr 13, 2025 am 12:03 AM

MySQL不是一門編程語言,但其查詢語言SQL具備編程語言的特性:1.SQL支持條件判斷、循環和變量操作;2.通過存儲過程、觸發器和函數,用戶可以在數據庫中執行複雜邏輯操作。

MySQL:世界上最受歡迎的數據庫的簡介MySQL:世界上最受歡迎的數據庫的簡介Apr 12, 2025 am 12:18 AM

MySQL是一種開源的關係型數據庫管理系統,主要用於快速、可靠地存儲和檢索數據。其工作原理包括客戶端請求、查詢解析、執行查詢和返回結果。使用示例包括創建表、插入和查詢數據,以及高級功能如JOIN操作。常見錯誤涉及SQL語法、數據類型和權限問題,優化建議包括使用索引、優化查詢和分錶分區。

MySQL的重要性:數據存儲和管理MySQL的重要性:數據存儲和管理Apr 12, 2025 am 12:18 AM

MySQL是一個開源的關係型數據庫管理系統,適用於數據存儲、管理、查詢和安全。 1.它支持多種操作系統,廣泛應用於Web應用等領域。 2.通過客戶端-服務器架構和不同存儲引擎,MySQL高效處理數據。 3.基本用法包括創建數據庫和表,插入、查詢和更新數據。 4.高級用法涉及復雜查詢和存儲過程。 5.常見錯誤可通過EXPLAIN語句調試。 6.性能優化包括合理使用索引和優化查詢語句。

為什麼要使用mysql?利益和優勢為什麼要使用mysql?利益和優勢Apr 12, 2025 am 12:17 AM

選擇MySQL的原因是其性能、可靠性、易用性和社區支持。 1.MySQL提供高效的數據存儲和檢索功能,支持多種數據類型和高級查詢操作。 2.採用客戶端-服務器架構和多種存儲引擎,支持事務和查詢優化。 3.易於使用,支持多種操作系統和編程語言。 4.擁有強大的社區支持,提供豐富的資源和解決方案。

描述InnoDB鎖定機制(共享鎖,獨家鎖,意向鎖,記錄鎖,間隙鎖,下一鍵鎖)。描述InnoDB鎖定機制(共享鎖,獨家鎖,意向鎖,記錄鎖,間隙鎖,下一鍵鎖)。Apr 12, 2025 am 12:16 AM

InnoDB的鎖機制包括共享鎖、排他鎖、意向鎖、記錄鎖、間隙鎖和下一個鍵鎖。 1.共享鎖允許事務讀取數據而不阻止其他事務讀取。 2.排他鎖阻止其他事務讀取和修改數據。 3.意向鎖優化鎖效率。 4.記錄鎖鎖定索引記錄。 5.間隙鎖鎖定索引記錄間隙。 6.下一個鍵鎖是記錄鎖和間隙鎖的組合,確保數據一致性。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具