亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

sqlserver中操作主從關系表的sql語句

2024-08-31 00:58:12
字體:
來源:轉載
供稿:網友
典型的方法就是對于主表的各數據字段進行更新或新增,對于從表一般都會先刪除相關的所有記錄,然后再進行插入。也就是說每次保存時,從表的數據都要重新執行一遍刪除再插入的過程。這是一個不錯的方法,在使用數據庫事務后,不會存在刪除后又沒有插入導致數據不一致的情況。
ok,原理是這樣,那么到實際的操作中,大家如何操作的呢?有人通過在程序中,通過多次數據庫操作完成如上的要求,這種方法可能存在這數據的不一致性,因為無法保證在兩個數據語句操作之間出現意外。那么我們就合并到一個存儲過程中去完成吧,復雜的參數和接收后處理,讓這個存儲過程變的困難。下邊我就結合實際應用說說此過程吧。應用場景,在學生管理中,添加一條學生記錄,對應的要 添加學生對應的課程。即每次更新和新增學生記錄,對應其課程也要跟著變化。
那么這個過程,就符合上邊的邏輯。
通用的參數傳遞,在此不再詳說,重點講解,科目信息傳遞過后怎么處理。假設從表Tb_StudentSubject 存在StudentId,SubjectId兩個字段。那么代碼如下:

復制代碼 代碼如下:


Create proc SaveInfo
(
---參數列表不再逐一書寫
@subjectList varchar(400))
as
begin tran
--新增或修改主表 省略
DECLARE @subjectID int,
@subjectIDsLen int,--科目長度
@subjectIDLen int,--單個科目長度
@nStart INT , -- 記錄查找的起始位置
@nLast INT -- 記錄‘,'的位置
select @subjectIDsLen=len(@SubjectIDs),@nStart=1,@nLast=0
DELETE Tb_StudentSubject WHERE StudentId=@sId --刪除相關的全部記錄
IF(@subjectIDsLen>0)
BEGIN
while(@nStart<@subjectIDsLen)
BEGIN
set @nLast=charindex(',',@SubjectIDs,@nStart)--從第@nStart個位置開始記錄逗號的位置
set @subjectIDLen=@nLast-@nStart --記錄每個subjectID的長度
set @subjectID=substring(@SubjectIDs,@nStart,@subjectIDLen)--獲取一個subjectID
Insert Into Tb_StudentSubject(StudentId,SubjectID)values(@sId,@subjectID)
set @nStart=@nLast+1--設置下次查找的起始位置
END
END
if @@Error=0
commit transaction
else
rollback transaction
End



在這邊代碼中,科目列表通過“,”進行分割,上邊的存儲過程帶注釋,重點說明兩個系統自帶的函數
CHARINDEX ( expression1 ,expression2 [ , start_location ] )
expression1 :其中包含要查找的字符的序列
expression2 :通常是一個為指定序列搜索的列
start_location :開始在 expression2 中搜索 expression1 時的字符位置。如果 start_location 未被指定、是一個負數或零
另一個函數就是:SUBSTRING ( expression ,start , length )從指定的數據源串中從指定位置截取指定長度的串
其中 expression :是字符串、二進制字符串,要操作的數據源串
start:要截取的開始位置,注意此方法和C#自帶的位置不一樣,數據庫中strat從1開始,程序中從0開始
length:截取內容的長度
另外一個就len(expres) 這個就比較簡單了,獲取指定字符的長度
通過以上代碼,就可以實現一個完整存儲過程實現主從表數據的處理了,在數據一致性和操作便捷性得到保證,而且相同通用。
注:在涉及類似主從關系表中,建議不要在從表中設置自動編號的主鍵,因為頻繁的刪除和添加,導致主鍵不斷的累增,而且毫無使用此主鍵的意義。
以上內容是個人見解,希望大家多交流相應的方法。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品视频大全| 精品国内产的精品视频在线观看| 91成人免费观看网站| 亚洲福利精品在线| 国产综合久久久久| 成人精品久久一区二区三区| 91亚洲精品一区二区| 久久99精品久久久久久噜噜| 91中文在线观看| 日本久久中文字幕| 亚洲va久久久噜噜噜久久天堂| 国产日韩av在线| 91亚洲精品一区二区| 亚洲精品视频免费在线观看| 国产欧美一区二区三区在线| 国产主播欧美精品| 91精品国产综合久久香蕉最新版| 国产精品私拍pans大尺度在线| 国产一区二区三区在线视频| 亚洲天堂视频在线观看| 欧美又大粗又爽又黄大片视频| 日韩一区二区三区在线播放| 久久精品99无色码中文字幕| 精品夜色国产国偷在线| 亚洲自拍小视频免费观看| 欧美精品一区在线播放| 国产成人精彩在线视频九色| 国产区亚洲区欧美区| 日韩成人av在线| 日韩av日韩在线观看| 国模私拍视频一区| 亚洲综合中文字幕在线观看| 久久欧美在线电影| 亚洲国产免费av| 欧美激情伊人电影| 中文字幕久久久av一区| 国产视频精品va久久久久久| 欧美激情亚洲一区| 日韩免费电影在线观看| 久久久久日韩精品久久久男男| 久久777国产线看观看精品| 日韩激情视频在线| www.xxxx精品| 亚洲欧美制服第一页| 亚洲欧美日韩天堂| 少妇高潮久久久久久潘金莲| 精品电影在线观看| 久久在线精品视频| 成人有码在线视频| 在线免费观看羞羞视频一区二区| 91在线色戒在线| 久久精品国产69国产精品亚洲| 亚洲美腿欧美激情另类| 欧美日韩中文字幕日韩欧美| 国产日韩欧美在线| 欧美巨猛xxxx猛交黑人97人| 亚洲电影免费观看高清完整版在线观看| 国产精品偷伦一区二区| 日韩中文字幕视频在线观看| 日韩第一页在线| 亚洲第一男人天堂| 亚洲欧美日韩精品久久亚洲区| 国产成人自拍视频在线观看| 欧美日韩亚洲一区二区三区| 亚洲另类图片色| 国产精品激情av在线播放| 国产精品美腿一区在线看| 欧美体内谢she精2性欧美| 精品视频在线导航| 日本成人免费在线| 国产精品精品久久久久久| 国产不卡视频在线| 国产在线高清精品| 亚洲一区二区日本| 欧美电影免费看| 在线午夜精品自拍| 久久精品国产电影| 日韩精品亚洲元码| 精品久久久久久中文字幕| 亚洲精品国产精品国自产在线| 国产精品美女网站| 国产精品一区二区性色av| 欧美成人免费全部| 国产亚洲欧洲高清一区| 日韩av在线资源| 亚洲精品美女久久久| 亚洲人成网站免费播放| 国产午夜精品一区理论片飘花| 欧美午夜女人视频在线| 国产精品一久久香蕉国产线看观看| 成人免费xxxxx在线观看| 国产成人aa精品一区在线播放| 日韩精品欧美激情| 亚洲高清一二三区| 亚洲国产精品电影在线观看| 日韩中文字幕不卡视频| 亚洲男人天堂九九视频| 亚洲永久免费观看| 国产日本欧美一区二区三区| 国产在线观看一区二区三区| 亚洲肉体裸体xxxx137| 91色精品视频在线| 黄色成人在线播放| 最近免费中文字幕视频2019| 久久伊人精品一区二区三区| 中文字幕不卡av| 欧美精品videofree1080p| 8090成年在线看片午夜| 久久精品国产清自在天天线| 欧美精品一区二区免费| 成人中文字幕+乱码+中文字幕| 91网站在线看| 国产欧美一区二区三区视频| 久久久久久尹人网香蕉| 日韩av成人在线| 中文字幕日韩高清| 亚洲三级黄色在线观看| 日韩大陆毛片av| 国产精品美女久久久免费| 国产精品女视频| 亚洲精品久久久久国产| 97精品国产97久久久久久春色| 色多多国产成人永久免费网站| 国产精品免费一区二区三区都可以| 欧美野外猛男的大粗鳮| 777午夜精品福利在线观看| 国产亚洲精品综合一区91| 成人免费视频网| 久久久精品视频在线观看| 98午夜经典影视| 欧美老女人www| 国产精品中文字幕久久久| 亚洲视频国产视频| 大伊人狠狠躁夜夜躁av一区| 亚洲男人天天操| 国产精品2018| 91成人福利在线| 久久夜色精品国产亚洲aⅴ| 欧美在线视频在线播放完整版免费观看| 欧洲永久精品大片ww免费漫画| 国产91精品不卡视频| 亚洲精品欧美一区二区三区| 69av视频在线播放| 精品激情国产视频| 国产精品99久久久久久久久| 欧美激情图片区| 国产日产欧美a一级在线| 精品av在线播放| 日韩av网站导航| 亚洲欧洲免费视频| 九九热这里只有在线精品视| 久久久久女教师免费一区| 日韩成人网免费视频| www.日韩系列| 伊人av综合网| 欧美激情a∨在线视频播放| 亚洲欧美自拍一区| 国产精品一区二区在线| 国产一区二区三区在线看| 中文字幕日韩高清| 91久久嫩草影院一区二区| 久久99亚洲热视| 亚洲成人久久久久| 日韩一区在线视频|