精品免费在线观看-精品欧美-精品欧美成人bd高清在线观看-精品欧美高清不卡在线-精品欧美日韩一区二区

17站長網

17站長網 首頁 數據庫 SQLite教程 查看內容

SQLite外鍵的實現

2023-3-21 15:55| 查看: 2426 |來源: 互聯網

SQLite現在的版本還不支持外鍵功能,雖然外鍵約束會被解析,但執行的時候被忽略。但我們可以手動實現外鍵,實現的原理就是觸發器。下面是我的實現方法。主要是針 ...

SQLite現在的版本還不支持外鍵功能,雖然外鍵約束會被解析,但執行的時候被忽略。但我們可以手動實現外鍵,實現的原理就是觸發器。下面是我的實現方法。主要是針對一個例子:

先看下面兩個表。

CREATE TABLE PLU (PluID integer NOT NULL PRIMARY KEY,

Name text NOT NULL,

Property text,

Price double NOT NULL,

Left integer NOT NULL,

Department text,

Other text);

CREATE TABLE PluSuit (SuitID integer NOT NULL PRIMARY KEY,

Price double NOT NULL,

Property text,

Name text NOT NULL,

PluID integer NOT NULL CONSTRAINT fk_plu_id REFERENCES PLU(PluID) ON DELETE CASCADE,

Numbers integer NOT NULL)

這樣就為PluSuit表建立對PLU表的外鍵約束,這樣就可以實現CORE2數據需求中的要求,問題是SQLite不執行這個約束,所以這樣創建以后,我們還要再創建三個觸發器,INSERT,UPDATE,DELETE觸發器:

BEFORE INSERT ON PluSuit

FOR EACH ROW BEGIN

SELECT RAISE(ROLLBACK, 'insert on table "PluSuit" violates foreign key constraint "fk_plu_id"')

WHERE (SELECT PluID FROM PLU WHERE PluID = NEW.PluID) IS NULL;

END;

BEFORE UPDATE ON PluSuit

FOR EACH ROW BEGIN

SELECT RAISE(ROLLBACK, 'update on table "PluSuit" violates foreign key constraint "fk_plu_id"')

WHERE (SELECT PluID FROM PLU WHERE PluID = NEW.PluID) IS NULL;

END;

CREATE TRIGGER fkd_plusuit_pluid

BEFORE DELETE ON PLU

FOR EACH ROW BEGIN

DELETE from PluSuit WHERE PluID = OLD.PluID;

END;

下面我們分別來作三個實驗:

一、插入實驗

首先我們在PLU里面插入一個數據(一雙anta運動鞋的信息):

insert into PLU values(1,'anta','sport',299,100,'sales','ok');

insert into PLU values(3,'nike','sport',699,200,'sales','ok');

然后我們開始在PluSuit里面插入一個數據(兩雙一起打折賣):

insert into PluSuit values(100,350,'old','anta',1,2);成功了

insert into PluSuit values(100,350,'old','anta',2,2);失敗,得到正確的錯誤信息

更新實驗

update PluSuit set PluID=2 where SuitID=100;失敗,得到正確的錯誤信息

update PluSuit set PluID=3 where SuitID=100;成功

刪除實驗

delete from PLU where PluID=1;

查看PluSuit中數據被正確刪除。

實驗結果,觸發器的實現完全正確。

本文最后更新于 2023-3-21 15:55,某些文章具有時效性,若有錯誤或已失效,請在網站留言或聯系站長:[email protected]
·END·
站長網微信號:w17tui,關注站長、創業、關注互聯網人 - 互聯網創業者營銷服務中心

免責聲明:本站部分文章和圖片均來自用戶投稿和網絡收集,旨在傳播知識,文章和圖片版權歸原作者及原出處所有,僅供學習與參考,請勿用于商業用途,如果損害了您的權利,請聯系我們及時修正或刪除。謝謝!

17站長網微信二維碼

始終以前瞻性的眼光聚焦站長、創業、互聯網等領域,為您提供最新最全的互聯網資訊,幫助站長轉型升級,為互聯網創業者提供更加優質的創業信息和品牌營銷服務,與站長一起進步!讓互聯網創業者不再孤獨!

掃一掃,關注站長網微信

大家都在看

熱門排行

最近更新

返回頂部
主站蜘蛛池模板: 日韩欧美国产偷亚洲清高 | 国产高清精品入口麻豆 | 国产成人精品永久免费视频 | 久久精品免费播放 | 999国产精品999久久久久久 | 日本特级黄色 | 国产精品嫩草影院在线播放 | 一级国产20岁美女毛片 | 国产精品黄色 | 亚洲第一免费视频 | 一 级 黄 色生活片 一 级 黄 色蝶 片 | 国产成人lu在线视频 | 在线免费你懂的 | 国产亚洲99影院 | 国产精品原创巨作无遮挡 | 亚洲国产精品久久久久网站 | 色综合中文字幕在线亚洲 | 婷婷六月在线 | 精品久久久久久亚洲 | 欧美激情综合亚洲一二区 | 黑人与欧洲性大战 | 国产成人禁片免费观看视频 | 欧美乱xxxxxxxxx| 国产精品亚洲欧美云霸高清 | 久久五月婷 | 国产乱码精品一区二区三区网页版 | 国产精品99在线观看 | 欧美不在线 | 欧美精品久久一区二区三区 | 日韩激情中文字幕一区二区 | 日韩美女一级毛片 | 欧美日韩成人高清色视频 | 久久精品国产999大香线焦 | 国产精品国产亚洲精品看不卡 | 久久99亚洲精品一区二区 | 香蕉免费一区二区三区在线观看 | 久久亚洲精品中文字幕第一区 | 国产精品对白刺激久久久 | 久久99精品久久久久久三级 | 亚洲美女在线观看亚洲美女 | 中文字幕一区二区三区免费看 |