oracle+事务开始+结束,Oracle事务和对象上集(视图、索引)
一、Oracle事務
·事務的含義:事務是業(yè)務上的一個邏輯單元,為了保證數(shù)據(jù)的所有操作要么全部完成,要么全部失敗。
1、事務的開始是從一條SQL語句開始,結束于下面的幾種情況:
1)顯示提交:輸入commit指令,事務完成提交
2)顯示回滾:輸入rollback指令,未提交的事務丟掉,回滾到事務開始時的狀態(tài)。
3)DDL語句:即create、drop等語句,這些語句會使事務自動隱式提交
4)結束程序:輸入exit退出數(shù)據(jù)庫,則自動提交事務;或者意外終止、出現(xiàn)程序崩潰,則事務自動回滾。
2、事務的特點-ACID特性
1)原則性:要么同時成功,要么同時失敗的原則
2)一致性:如,a轉賬給b,最總結果a+b的金錢總數(shù)是不變的
3)隔離性:當出現(xiàn)多個事務出現(xiàn),它們之間是互相隔離、互不影響的
4)持久性:事務一旦提交,則數(shù)據(jù)永久修改。
3、關于事務的三個命令
commit :立即提交事務
rollback :回滾事務
set autocommit on/off :設置/關閉自動提交
二、索引
·索引是Oracle的一個對象,是與表關聯(lián)的可選結構,用于加快查詢速度,提高檢索性能。
1、特點
1)適當使用索引可以提高查詢速度、建立索引的數(shù)量無限制
2)可以對表的一列或者多列建立索引
3)索引是需要磁盤空間,可以指定表空間存儲索引。
4)是否使用索引有Oracle決定
2、索引的分類
B樹索引:從頂部為根,逐漸向下一級展開
唯一索引:定義索引的列沒有任何重復
非唯一索引:與唯一索引相反
反向鍵索引:對與數(shù)字列作用較大,會將1234生成4321進行查詢的索引
位圖索引:應用于數(shù)據(jù)倉庫和決策支持系統(tǒng)中。優(yōu)點是相對于b樹索引,可以減少響應時間;相對于其他索引,其空間占用少。
函數(shù)索引:使用函數(shù)涉及正在創(chuàng)建索引的列的索引
3、創(chuàng)建索引
操作時我們可以使用Oracle的scott用戶進行測試,首先解鎖,在改一個密碼,登陸進去就可以操作了
create [unique] index i_name on t_name(c_list) [tablespace ts_name];
注釋: create ... index ... on 創(chuàng)建索引
unique 唯一索引
i_name 創(chuàng)建的索引名稱
t_name 在哪個表創(chuàng)建
(c_list) 列名
ts_name 表空間名
舉例:
create index emp_ename_idx on emp(ename);
:b樹索引
create unique index emp_ename_unique_idx on emp(ename);
:唯一索引
create index emp_ename_reverse_idx on emp(ename) reverse;
:反向索引
create index emp_ename_upper_idx on emp(upper(ename));
:函數(shù)索引
4、創(chuàng)建索引的原則
1)頻繁檢索的列
2)經常排序、分組的列
3)主鍵/外鍵
4)大型索引使用nologing子句創(chuàng)建
5)需定期進行組織索引、碎片整理
5、維護索引的命令
1)重建索引
alter index i_table rebuild [tablespace ts_name];
2)合并索引碎片
alter index i_name coalesce;
3)刪除索引
drop index i_name;
4)查看索引(使用user_indexes、user_ind_columns字典)
select index_name,index_tyep,table_name,column_name from user_indexes;或者
select index_name,table_name,_column_name from user_ind_columns where
index_name like ‘emp%’;
三、視圖
·視圖是一個虛表,不占用物理空間,視圖本身的定義語句存放于字典里,可以由一個或者多個表中獲得數(shù)據(jù)。目的是為了方便查詢,而不需要在敲繁瑣的查詢語句。
1、視圖的作用
1)通過限制對表中預定的一組行和列進行查看,可以防止用戶看到無權限數(shù)據(jù),提供了安全性
2)簡化了用戶的命令、隱藏了數(shù)據(jù)的復雜性,方便操作
3)視圖可以對列進行重命名,提升了數(shù)據(jù)庫的靈活性和人性化
4)視圖將應用程序與基表定義的修改進行了隔離,表結構的修改不會影響視圖結構。
2、創(chuàng)建視圖
create [or replace] [force] view vname [(alias[,alias]...)] as SQL
[with check option] [with read only];
注釋: or replace :覆蓋
force :強制的;視圖中的基表是否存在,都會創(chuàng)建
vname :創(chuàng)建的視圖名稱
[(alias[,alias]...)] :可選項,視圖別名,可以由多個
SQL :SQL查詢語句
with check option :用于更改視圖時的約束
with read only :只讀
舉例:
create view vname as select from tname where ‘a=b’;
簡單的視圖
create view vname as select from tname where ‘a=b’ with read only;
只讀視圖
create force view vname as select from tname where ‘a=b’;
強制創(chuàng)建視圖,假如‘tname’表不存在,也強制創(chuàng)建,也就是錯誤視圖。
create table tname (a (char));
alter view vname compile;
查看錯誤視圖(使用字典)
show errors view;
show
創(chuàng)建tname表;然后編譯錯誤視圖,使其生效
3、在視圖中使用DML語句(insert、update、delete)的限制
1)DML語句只能修改視圖中的一個基表
2)如果修改違反了check option約束,則無法修改
3)如果視圖包括連接運算符、DISTINCT運算符、集合運算符、聚合函數(shù)和group by子句,則無法更新視圖
4)如果包含偽列、表達式,也無法更新視圖
4、維護視圖
1)刪除視圖
drop view vname;
2)查詢已有視圖(user_views字典)
select viewname from user_views;
5、物化視圖
·顧名思義,物化視圖就是將視圖物理化存到磁盤,它與基表實時同步。物化視圖可以避免order by子句或者多表連接查詢帶來的效率降低和時耗,但是會占用用磁盤空間。
1)物化視圖同步的刷新方式可分為:
on commit:即提交事務以后
on demand:簡單講就是用戶手動刷新
2)物化視圖同步的刷新類型
complete:完全刷新
fast:追求速度,增量刷新
force:Oracle自動判斷使用complete還是fast類型刷新
never:從不刷新
·關于以上四個類型,Oracle默認選擇force刷新。工作中無特殊需求,無需更改
6、創(chuàng)建物化視圖
1)首先用sys登陸,為scott用戶授權
2)創(chuàng)建物化視圖日志
3)正式創(chuàng)建
注釋: build immediate :立即創(chuàng)建
refresh fast :刷新類型為fast
enable query rewrite :啟用查詢重寫
4)刪除物化視圖
**drop materialized view materview;***
總結
以上是生活随笔為你收集整理的oracle+事务开始+结束,Oracle事务和对象上集(视图、索引)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: oracle终止dbms调度,Oracl
- 下一篇: php过滤手机特殊字符,php过滤特殊字