經過調試,發現其它情況(如數據庫連接)正常,只是在執行一條多表連接查詢時一定超時(數據庫數據只有十多條)。由于采用分層開發,但將所有操作放在一起后,卻不見超時問題。程序簡單分為3層,數據層select直接調用連接,insert和update使用邏輯層的事務參數。以下為部分代碼:using (SqlConnection con = Helper.GetSqlConnection()){con.Open();using (SqlTransaction trans = con.BeginTransaction()){try{//刪除原來的權限、用戶組關系HAuthGroup.DeleteAuth_groupByAuthID(auth.Auth_id, con, trans);//更新權限HAuthority.UpdateAuthority(auth, con, trans);//如果新類別關聯了用戶組,添加新的權限、用戶組關系AuthType type = HAuthType.GetAuthTypeByID(auth.Type_id);///測試,添加幾個讀數據庫方法HGroup.GetGroupsByAuthType(new AuthType());///該處會導致超時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()超時 !1 將所有方法全部集成到一個方法里,多層嵌套的子查詢可以執行,且不會超時。2 在邏輯層單獨調用GetGroupsByAuthType(AuthType type) 方法,沒有異常。3 注釋掉 HAuthority.UpdateAuthority(auth, con, trans),沒有異常。
2 回答

慕俠2389804
TA貢獻1719條經驗 獲得超6個贊
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 + " ) )
此處的查詢語句 3層in查詢 效率 會有問題
如果數據量大的話 超時會發生.

海綿寶寶撒
TA貢獻1809條經驗 獲得超8個贊
同意樓上的說法,查詢語句復雜度太深,也許你在本地運行時沒有問題,當在服務器上的SqlServer運行時間太長導致的,后者語句本有問題。建議可以分批操作。
- 2 回答
- 0 關注
- 92 瀏覽
添加回答
舉報
0/150
提交
取消