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

首頁 > 開發 > 綜合 > 正文

對Foreign Key的進一步認識

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

  讀的時候,看到書上的例子了。
  
  這里寫一下關于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鎖了。很有意思吧?

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 梅河口市| 贺州市| 益阳市| 嘉义县| 孟连| 扶绥县| 涿鹿县| 巫山县| 怀远县| 淮南市| 石首市| 宜宾市| 钦州市| 巧家县| 恩施市| 久治县| 杂多县| 阳谷县| 彭泽县| 黄大仙区| 郴州市| 绥滨县| 平顺县| 吉隆县| 宁安市| 田东县| 措美县| 伊金霍洛旗| 濮阳市| 察雅县| 桦甸市| 禹州市| 徐州市| 张家川| 平武县| 商城县| 桑日县| 独山县| 包头市| 酒泉市| 永年县|