用SQL完成條件式查詢
2010-04-08 00:00:00 来源:WEB开发网因為覺得每次要用條件式查詢很煩(如範例一),就想有沒有更方便的用法,試出一種方法還不錯,分享給大家。
測試環境
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");
- ››SQL Server 2008 R2 下如何清理数据库日志文件
- ››sqlite 存取中文的解决方法
- ››SQL2005、2008、2000 清空删除日志
- ››SQL Server 2005和SQL Server 2000数据的相互导入...
- ››sql server 2008 在安装了活动目录以后无法启动服...
- ››sqlserver 每30分自动生成一次
- ››sqlite 数据库 对 BOOL型 数据的插入处理正确用法...
- ››sql server自动生成批量执行SQL脚本的批处理
- ››sql server 2008亿万数据性能优化
- ››SQL Server 2008清空数据库日志方法
- ››sqlserver安装和简单的使用
- ››SQL Sever 2008 R2 数据库管理
更多精彩
赞助商链接