[20210301]延遲顯示輸出.txt
[20210301]延遲顯示輸出.txt
--//一位網友提出一個奇怪要求,就是分段顯示輸出.我不知道應用是否很好實現.
--//可以在select中加入sleep函式,自己測試看看.
1.環境:
SCOTT@book> @ ver1
PORT_STRING VERSION BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx 11.2.0.4.0 Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
CREATE OR REPLACE FUNCTION SCOTT.sleep (seconds IN NUMBER)
RETURN NUMBER
AS
BEGIN
sys.DBMS_LOCK.sleep (seconds);
RETURN seconds;
END;
/
SCOTT@book> set array 3
SCOTT@book> select emp.*,sleep(1) from emp ;
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO SLEEP(1)
---------- ---------- --------- ---------- ------------------- ---------- ---------- ---------- ----------
7369 SMITH CLERK 7902 1980-12-17 00:00:00 800 20 1
7499 ALLEN SALESMAN 7698 1981-02-20 00:00:00 1600 300 30 1
7521 WARD SALESMAN 7698 1981-02-22 00:00:00 1250 500 30 1
7566 JONES MANAGER 7839 1981-04-02 00:00:00 2975 20 1
7654 MARTIN SALESMAN 7698 1981-09-28 00:00:00 1250 1400 30 1
7698 BLAKE MANAGER 7839 1981-05-01 00:00:00 2850 30 1
7782 CLARK MANAGER 7839 1981-06-09 00:00:00 2450 10 1
7788 SCOTT ANALYST 7566 1987-04-19 00:00:00 3000 20 1
7839 KING PRESIDENT 1981-11-17 00:00:00 5000 10 1
7844 TURNER SALESMAN 7698 1981-09-08 00:00:00 1500 0 30 1
7876 ADAMS CLERK 7788 1987-05-23 00:00:00 1100 20 1
7900 JAMES CLERK 7698 1981-12-03 00:00:00 950 30 1
7902 FORD ANALYST 7566 1981-12-03 00:00:00 3000 20 1
7934 MILLER CLERK 7782 1982-01-23 00:00:00 1300 10 1
14 rows selected.
Elapsed: 00:00:14.02
--//這樣可以實現每次顯示3條記錄.估計這樣不符合對方要求.一般更多地採用透過程式設計實現.
2.不過我發現這個可以滿足一個很獨特的測試,就是一致性讀取測試,透過例子說明問題:
SCOTT@book> create table t as select rownum id1,rownum id2,lpad(rownum||'x',10) vc from dual connect by level<=10;
Table created.
SCOTT@book> create unique index i_t_id1 on t(id1);
Index created.
SCOTT@book> create index i_t_id2 on t(id2);
Index created.
--//分析略.
3.測試:
--//session 1:
SCOTT@book> select * from t where id1=4 and sleep(12);
--//session 2,以下命令最好事先輸入,避免12秒內無法完成:
SCOTT@book> update t set vc=upper(vc) where id1=4;
1 row updated.
SCOTT@book> commit ;
Commit complete.
--//session 1:
SCOTT@book> select * from t where id1=4 and sleep(12)=12;
ID1 ID2 VC
---------- ---------- --------------------
4 4 4X4X4X4X4X
--//你可以發現vc輸出是大寫,而如果按照以前傳統的理解,應該輸出的是小寫.
4.條件換成id2看看.
--//session 1:
SCOTT@book> select * from t where id2=3 and sleep(12)=12;
--//session 2,以下命令最好事先輸入,避免12秒內無法完成:
SCOTT@book> update t set vc=upper(vc) where id1=3;
1 row updated.
SCOTT@book> commit ;
Commit complete.
--//session 1:
SCOTT@book> select * from t where id2=3 and sleep(12)=12;
ID1 ID2 VC
---------- ---------- --------------------
3 3 3x3x3x3x3x
--//你可以發現輸出是小寫.
--//Oracle將這種改動稱為"RowCR Optimization",Oracle簡單的描述了什麼是RowCR Optimization:A brief overview of this
--//optimization is that we try to avoid rollbacks while constructing a CR block if the present block has no uncommitted
--//changes.這裡的avoid rollback,意味著在滿足特定的條件時,Oracle就不做一致讀了.
--//這個提前條件就是索引要唯一.
--//RowCR Optimization透過隱含引數"_row_cr"來控制.
SYS@book> @ hide _row_cr
NAME DESCRIPTION DEFAULT_VALUE SESSION_VALUE SYSTEM_VALUE ISSES ISSYS_MOD
-------- ------------------------- -------------- ------------- ------------ ----- ---------
_row_cr enable row cr for all sql TRUE TRUE TRUE FALSE IMMEDIATE
SCOTT@book> alter system set "_row_cr"=false scope=memory;
System altered.
--//退出session 1再登入重複測試:
--//sesion 1:
SCOTT@book> select * from t where id1=1 and sleep(12)=12;
--//session 2:
SCOTT@book> update t set vc=upper(vc) where id1=1;
1 row updated.
SCOTT@book> commit ;
Commit complete.
--//sesion 1:
SCOTT@book> select * from t where id1=1 and sleep(12)=12;
ID1 ID2 VC
---------- ---------- --------------------
1 1 1x1x1x1x1x
--//現在就輸出小寫了.
4.收尾:
--//重啟還原.
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/267265/viewspace-2760454/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- [20180312]iostat顯示輸出問題.txtiOS
- [20230405]奇怪的顯示輸出寬度.txt
- [20230501]為什麼沒有顯示輸出.txt
- [20190502]給顯示輸出加入時間戳.txt時間戳
- [20200313]windows顯示輸出時間戳指令碼.txtWindows時間戳指令碼
- esp32筆記[17]-顯示網路延遲筆記
- [20210529]延遲開啟資料庫.txt資料庫
- 什麼是高延遲檔案傳輸?為什麼要使用高延遲檔案傳輸
- [20180626]延遲塊清除與只讀表.txt
- [20190218]延遲約束問題2.txt
- Win10系統中下級選單顯示延遲的解決方法Win10
- [20210301]第2行插入Y.txt
- [20150409]只讀表空間與延遲塊清除.txt
- 遇到金沙賬號維護稽核注單延遲顯示異常怎麼辦?
- Linux基礎命令---dmsg顯示核心輸出Linux
- Mysql輸出中文顯示亂碼處理MySql
- ccat – 使用語法突出顯示輸出內容
- RabbitMQ延遲訊息的延遲極限是多少?MQ
- [java IO流]之 鍵盤顯示器輸入輸出流(System)Java
- 延遲繫結
- [20190321]smem的顯示缺陷.txt
- [20180811]windows 7 顯示桌面.txtWindows
- [20211020]奇怪lsnrctl status顯示.txt
- Python一行輸出不顯示的問題Python
- win10開啟左下圖示有延遲怎麼辦 win10桌面圖示開啟有延遲如何解決Win10
- [20190524]sqlplus 與輸出&.txtSQL
- [20210301]為什麼邏輯讀這麼多.txt
- [20190124]bbed恢復資料遇到延遲塊清除的問題.txt
- 讓 排序 按照 in 列表的的顯示順序排序輸出。排序
- redis 延遲佇列Redis佇列
- Mybatis延遲查詢MyBatis
- WebGL之延遲著色Web
- Laravel 延遲佇列Laravel佇列
- 疫情延遲 題解
- [20190412]bash顯示日期相減.txt
- [20180628]顯示bbed x命令格式.txt
- 實現簡單延遲佇列和分散式延遲佇列佇列分散式
- 基於rabbitmq延遲外掛實現分散式延遲任務MQ分散式