SQLString

using System;
using System.Collections;

namespace BookShop.Common
{
 /// <summary>
 /// SQLString 的摘要说明。
 /// </summary>
 public class SqlStringConstructor
 {
  /// <summary>
  /// 公有静态方法,将文本转换成适合在Sql语句里使用的字符串。
  /// </summary>
  /// <returns>转换后文本</returns> 
  public static String GetQuotedString(String pStr)
  {
   return ("'" + pStr.Replace("'","''") + "'");
  }

  /// <summary>
  /// 根据条件哈希表,构造SQL语句中的AND条件子句
  /// </summary>
  /// <param name="conditionHash">条件哈希表</param>
  /// <returns>AND关系条件子句</returns>
        public static String GetConditionClause(Hashtable queryItems)
        {

            int Count = 0;
            String Where = "";
          

            //根据哈希表,循环生成条件子句
            foreach (DictionaryEntry item in queryItems)
            {
                if (Count == 0)
                    Where = " where ";
                else
                    Where += " and ";

                //根据查询列的数据类型,决定是否加单引号
                if (item.Value.GetType().ToString() == "System.String" )
                {
                    Where += item.Key.ToString()
                        + " like "
                        + SqlStringConstructor.GetQuotedString("%"
                        + item.Value.ToString()
                        + "%");
                      
                }
                else if (item.Value.GetType().ToString() == "System.DateTime[]")
                {
                    string[] time = item.Value.ToString().Split(',');
                        Where += item.Key.ToString()
                               + " between "
                               + SqlStringConstructor.GetQuotedString(((DateTime[])item.Value)[0].ToString()) + " and " + SqlStringConstructor.GetQuotedString(((DateTime[])item.Value)[1].ToString());
                             
                             
                                   
               
                }

                else
                {
                    Where += item.Key.ToString() + "= " + item.Value.ToString();
                }
                Count++;
            }
            return Where;
        }
 }
}
 

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值