找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 5364|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

SQL合并多個字段的模糊查詢

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:77367 發(fā)表于 2015-4-18 20:53 | 只看該作者 回帖獎勵 |正序?yàn)g覽 |閱讀模式
代碼是在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")));                //時間范圍 CTime類型

//字段合并的模糊查詢 MYSQL concat(email, address) like 'like%df%'
if(!strKeyWord.IsEmpty())            //strKeyWord待查詢的關(guān)鍵字
{
            //SQL Server中IsNull(expression, replace)有替換功能,
            //str.Format(_T(" AND IsNull(name, ' ') + IsNull(Empid, ' ') LIKE '%%%s%%'"),
            //strKeyWord.GetBuffer(0));
               
           //Access需要結(jié)合IsNull ( expression ), iif (condition, value_if_true, value_if_false )函數(shù)
          str.Format(_T(" AND iif(IsNull(name),' ',name) & iif(IsNull(Empid),' ',Empid) LIKE  '%%%s%%'"),
         strKeyWord.GetBuffer(0));
         sql += str;
}
TRACE1("%s\n", sql);

============================================================================
ps: 上面的%%%s%%是C/C++的格式化字符串輸出, %%表示輸出%, %s表示輸出字符串, 默認(rèn)給搜索關(guān)鍵字前后加上%號, 這是SQL模糊匹配的符號,


改寫
========================================================================
CString sql, str;
sql.Format(_T("SELECT * FROM tbPatient"));



if (!m_bDisplayAll)//非全部顯示則添加搜索條件
{
        str.Format(_T(" WHERE admitDateBETWEEN 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需要結(jié)合IsNull ( expression ), iif (condition, value_if_true, value_if_false )函數(shù)

                //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);



分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表