国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

對Foreign Key的進一步認識。

2024-07-21 02:33:11
字體:
來源:轉載
供稿:網友

  讀<eXPert one on one Oracle>的時候,看到書上的例子了。
這里寫一下關于FK跟一點LOCK的東西,很少。

content:

先建表

create table p ( x int PRimary key );
create table c ( y references p );

往父表里插入兩個數據:

into p values ( 1 );
insert into p values ( 2 );
commit;

這個時候,限制就看出來了:好,往FK的子表里插入數據。

SQL> insert into C values (1);
insert into C values (1)
*
ERROR 位于第 1 行:
ORA-02291: integrity constraint (SCOTT.SYS_C001486) violated - parent key not
found

看到了嗎?子表里不讓你往里插入父表里沒有的數據,在看這個:

SQL> insert into C values (2);

已創建 1 行。

這樣就可以了。
==============================================
下面說一下lock: transaction 的Lock就是TX類型的lock.

我用SCOTT用戶把C里面插入一個2的值,而且沒有commit.
這個時候,表C上有TX鎖。
如下:

SQL> select sid,username from v$session where sid=13;

       SID USERNAME
---------- ------------------------------
        13 SCOTT

Elapsed: 00:00:00.01
SQL> select sid,type from v$lock where sid=13;

       SID TY
---------- --
        13 TX
        13 TM

Elapsed: 00:00:00.02

此時用SCOTT用戶查看C表,有兩個記錄:

SQL> select * from C;

         Y
----------
         3
         2

可是用SYS用戶看呢:

SQL> select * from scott.C;

         Y
----------
         3

Elapsed: 00:00:00.00

希奇吧?竟然只有一個數據,跟SCOTT看到的不一樣。

可是當SCOTT執行COMMIT命令之后呢?

SQL> commit;

提交完成。

此時再看SCOTT的鎖:

SQL> select sid,type from v$lock where sid=13;

no rows selected

Elapsed: 00:00:00.02

再用SYS看SCOTT的表C:

SQL> select * from scott.C;

         Y
----------
         3
         2

Elapsed: 00:00:00.00

這個就是TX鎖了。很有意思吧?



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 涪陵区| 赤峰市| 噶尔县| 旬邑县| 依安县| 玉环县| 静乐县| 石渠县| 黑山县| 衡阳县| 中宁县| 尤溪县| 阜南县| 隆安县| 岳池县| 清水河县| 京山县| 丹江口市| 辉南县| 镇平县| 呼玛县| 博乐市| 兴宁市| 泰顺县| 永靖县| 东方市| 石家庄市| 苍溪县| 柳州市| 扶绥县| 罗平县| 山东| 杭锦后旗| 青龙| 秀山| 唐河县| 安宁市| 车险| 乌审旗| 辽阳市| 大连市|