第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

感覺是get方法和事務(wù)用了兩個(gè)連接,發(fā)生了死鎖?

感覺是get方法和事務(wù)用了兩個(gè)連接,發(fā)生了死鎖?

慕斯709654 2022-10-27 23:19:23
經(jīng)過(guò)調(diào)試,發(fā)現(xiàn)其它情況(如數(shù)據(jù)庫(kù)連接)正常,只是在執(zhí)行一條多表連接查詢時(shí)一定超時(shí)(數(shù)據(jù)庫(kù)數(shù)據(jù)只有十多條)。由于采用分層開發(fā),但將所有操作放在一起后,卻不見超時(shí)問(wèn)題。程序簡(jiǎn)單分為3層,數(shù)據(jù)層select直接調(diào)用連接,insert和update使用邏輯層的事務(wù)參數(shù)。以下為部分代碼:using (SqlConnection con = Helper.GetSqlConnection()){con.Open();using (SqlTransaction trans = con.BeginTransaction()){try{//刪除原來(lái)的權(quán)限、用戶組關(guān)系HAuthGroup.DeleteAuth_groupByAuthID(auth.Auth_id, con, trans);//更新權(quán)限HAuthority.UpdateAuthority(auth, con, trans);//如果新類別關(guān)聯(lián)了用戶組,添加新的權(quán)限、用戶組關(guān)系A(chǔ)uthType type = HAuthType.GetAuthTypeByID(auth.Type_id);///測(cè)試,添加幾個(gè)讀數(shù)據(jù)庫(kù)方法HGroup.GetGroupsByAuthType(new AuthType());///該處會(huì)導(dǎo)致超時(shí)List<Group> groups = HGroup.GetGroupsByAuthType(type);if (groups.Count > 0){foreach (Group group in groups){HAuthGroup.AddAuth_group(group.Group_id, auth.Auth_id, con, trans);}}trans.Commit();}catch{trans.Rollback();}}}public static List<Group> GetGroupsByAuthType(AuthType type){string strCmd = "select * from [sb_group] where [group_id] in(select [group_id] from [sb_auth_group] where [auth_id] in(select [auth_id] from [sb_authority] where [type_id]=" + type.Type_id + "))";return GetGroups(strCmd);}private static List<Group> GetGroups(string strCmd){List<Group> groups = new List<Group>();using (SqlConnection con = Helper.GetSqlConnection()){try{con.Open();SqlCommand cmd = new SqlCommand(strCmd, con);cmd.CommandTimeout = 5;using (SqlDataReader reader = cmd.ExecuteReader())// cmd.ExecuteReader()超時(shí) !1 將所有方法全部集成到一個(gè)方法里,多層嵌套的子查詢可以執(zhí)行,且不會(huì)超時(shí)。2 在邏輯層單獨(dú)調(diào)用GetGroupsByAuthType(AuthType type) 方法,沒有異常。3 注釋掉 HAuthority.UpdateAuthority(auth, con, trans),沒有異常。
查看完整描述

2 回答

?
慕俠2389804

TA貢獻(xiàn)1719條經(jīng)驗(yàn) 獲得超6個(gè)贊

SELECT *
FROM [sb_group]
WHERE [group_id] IN (
SELECT [group_id]
FROM [sb_auth_group]
WHERE [auth_id] IN ( SELECT [auth_id]
FROM [sb_authority]
WHERE [type_id] = " + type.Type_id + " ) )

此處的查詢語(yǔ)句 3層in查詢 效率 會(huì)有問(wèn)題
如果數(shù)據(jù)量大的話 超時(shí)會(huì)發(fā)生.

查看完整回答
反對(duì) 回復(fù) 2022-11-01
?
海綿寶寶撒

TA貢獻(xiàn)1809條經(jīng)驗(yàn) 獲得超8個(gè)贊

同意樓上的說(shuō)法,查詢語(yǔ)句復(fù)雜度太深,也許你在本地運(yùn)行時(shí)沒有問(wèn)題,當(dāng)在服務(wù)器上的SqlServer運(yùn)行時(shí)間太長(zhǎng)導(dǎo)致的,后者語(yǔ)句本有問(wèn)題。建議可以分批操作。

查看完整回答
反對(duì) 回復(fù) 2022-11-01
  • 2 回答
  • 0 關(guān)注
  • 96 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)