- Rongsen.Com.Cn 版权所有 2008-2010 京ICP备08007000号 京公海网安备11010802026356号 朝阳网安编号:110105199号
- 北京黑客防线网安工作室-黑客防线网安服务器维护基地为您提供专业的
服务器维护
,企业网站维护
,网站维护
服务 - (建议采用1024×768分辨率,以达到最佳视觉效果) Powered by 黑客防线网安 ©2009-2010 www.rongsen.com.cn
作者:黑客防线网安SQL维护基地 来源:黑客防线网安SQL维护基地 浏览次数:0 |
因為覺得每次要用條件式查詢很煩(如範例一),就想有沒有更方便的用法,試出一種方法還不錯,分享給大家。
測試環境
DBMS:Sql Server 2008 Express
DB:AdventureWorks
Table:Sales.SalesOrderDetail(Count:121,317)
情境
對Sales.SalesOrderDetail的OrderId與ProduceId與SaleDate這三個欄位做查詢(如圖一),如果沒有輸入條件為顯示全部。
範例一 傳統的條件式
1: StringBuilder sb = new StringBuilder();
2:
3: if (!string.IsNullOrEmpty(Order.Text))
4: sb.AppendFormat("SalesOrderID='{0}'", Order.Text);
5:
6: if (!string.IsNullOrEmpty(Produce.Text))
7: {
8: if (sb.Length > 0)
9: sb.Append(" AND ");
10:
11: sb.AppendFormat("ProductID='{0}'", Produce.Text);
12: }
13:
14: if (!string.IsNullOrEmpty(StartDate.Text))
15: {
16: if (sb.Length > 0)
17: sb.Append(" AND ");
18:
19: sb.AppendFormat("ModifiedDate > '{0}'", StartDate.Text);
20: }
21:
22: if (!string.IsNullOrEmpty(EndDate.Text))
23: {
24: if (sb.Length > 0)
25: sb.Append(" AND ");
26:
27: sb.AppendFormat("ModifiedDate < '{0}'", EndDate.Text);
28: }
29:
30: if (sb.Length > 0)
31: sb.Insert(0, " WHERE ");
32:
33: sb.Insert(0,"SELECT * FROM Sales.SalesOrderDetail");
我要申请本站:N点 | 黑客防线官网 | |
专业服务器维护及网站维护手工安全搭建环境,网站安全加固服务。黑客防线网安服务器维护基地招商进行中!QQ:29769479 |