SQL多字段模糊查询

http://user.qzone.qq.com/382164370#!app=2&via=QZ.HashRefresh&pos=1346996967

代码是在VC++里面:


	CString sql, str;
	sql.Format(_T("SELECT * FROM tbPatient WHERE admitDate	BETWEEN CDate('%s %s') AND CDate('%s %s')"),
		dtStartDate.Format(_T("%x")), dtStartTime.Format(_T("%X")),
		dtEndDate.Format(_T("%x")), dtEndTime.Format(_T("%X")));


	//字段合并的模糊查询 MYSQL concat(email,address) like 'like%df%'
	if(!strKeyWord.IsEmpty())
	{
		//SQL Server中IsNull(expression, replace)有替换功能, 
		//Access需要结合IsNull ( expression ), iif (condition, value_if_true, value_if_false )函数
		
		//str.Format(_T(" AND IsNull(name, ' ') & IsNull(Empid, ' ') LIKE '%%%s%%'"), 
		//	strKeyWord.GetBuffer(0));


		str.Format(_T(" AND iif(IsNull(name),' ',name) & iif(IsNull(Empid),' ',Empid) LIKE  '%%%s%%'"), 
			strKeyWord.GetBuffer(0));


		sql += str;
	}


	TRACE1("%s\n", sql);


一种改写的代码

CString sql, str;
	sql.Format(_T("SELECT * FROM tbPatient"));
	
	if (!m_bDisplayAll)		//非全部显示则添加搜索条件
	{
		str.Format(_T(" WHERE admitDate	BETWEEN CDate('%s %s') AND CDate('%s %s')"),
			dtStartDate.Format(_T("%x")), dtStartTime.Format(_T("%X")),
			dtEndDate.Format(_T("%x")), dtEndTime.Format(_T("%X")));


		sql += str;


		//字段合并的模糊查询 MYSQL concat(email, address) like 'like%df%'
		if(!strKeyWord.IsEmpty())
		{
			//SQL Server中IsNull(expression, replace)有替换功能, 
			//Access需要结合IsNull ( expression ), iif (condition, value_if_true, value_if_false )函数


			//str.Format(_T(" AND IsNull(name, ' ') + IsNull(Empid, ' ') LIKE '%%%s%%'"), 
			//	strKeyWord.GetBuffer(0));


			str.Format(_T(" AND iif(IsNull(name),' ',name) & iif(IsNull(Empid),' ',Empid) LIKE  '%%%s%%'"), 
				strKeyWord.GetBuffer(0));


			sql += str;
		}
	}


	//sql += _T(" ORDER BY ASC");			//DESC, 添加排序


	TRACE1("%s\n", sql);

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值