精品免费在线观看-精品欧美-精品欧美成人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站長網微信二維碼

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

掃一掃,關注站長網微信

大家都在看

熱門排行

最近更新

返回頂部
主站蜘蛛池模板: 国产一区二区三区影院 | 婷婷丁香综合网 | 经典三级影院 | 97色婷婷成人综合在线观看 | 国产精品日韩 | 18p爽视频在线观看免费 | 国产精品福利片免费看 | 国产美女网站视频 | 亚洲高清网站 | 国产精品思瑞在线观看 | 女人色毛片女人色毛片中国 | 在线观看成年美女黄网色视频 | 久本草在线中文字幕亚洲欧美 | 成人在线观看午夜 | 欧美人在线一区二区三区 | 色视频在线观看网站 | 九九精品视频在线免费观看 | 久久se精品一区二区影院 | 欧美黑寡妇香蕉视频 | 久久国产精品视频 | 国产精品一区高清在线观看 | 国产大尺度福利视频在线 | 东京一热本色道久久爱 | 色综合色狠狠天天久久婷婷基地 | 国产精品99精品久久免费 | 麻豆国产成人精品午夜视频 | 亚洲丁香婷婷综合久久六月 | 草草视频在线观看最新 | 亚洲欧美日韩中文字幕网址 | 亚洲精品aⅴ一区二区三区 亚洲精品aⅴ中文字幕乱码 | 亚洲三级成人 | 欧美综合激情网 | 国产网红主播精品福利大秀专区 | 91精品久久一区二区三区 | 黄色短视频在线播放 | 91成人国产网站在线观看 | 久久在线免费观看 | 五月婷婷六月合 | 亚洲最新视频在线观看 | 国产成人 免费观看 | 免费视频网站在线观看黄 |