- 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 |