dpauf28808 2016-08-01 10:45
浏览 42
已采纳

如何使用php和mysql从外表中搜索数据?

Here is 3 mysql tables format :

project_status

psid    p_id  cdid  sid  short_list  res_sent
1       3     112   24   0           0
2       3     113   25   0           1
3       4     114   22   0           1
4       4     115   23   1           0 
5       5     116   26   0           0  

contact_details :

cdid   family_name    given_name     department     title    cid
112    xx             xx             xx             xx       1
113    xx             xx             xx             xx       2
114    xx             xx             xx             xx       3
115    xx             xx             xx             xx       4
116    xx             xx             xx             xx       5

company :

cid   company_name
1     xx
2     xx
3     xx
4     xx
5     xx

Now, I need to search cdid from project_status table based on p_id and sid to show family_name, given_name, department, title

So that I am using following query and I get 3 results

SELECT
    cd.family_name,
    cd.given_name,
    cd.department,
    cd.title,
    cd.cid,
    ps.*, company.company_name
FROM
    contact_details AS cd
LEFT JOIN project_status AS ps ON cd.cdid = ps.cdid
LEFT JOIN company ON company.cid = cd.cid
WHERE
    1 = 1
AND ps.sid IN (25, 22)
AND ps.p_id = '3'
ORDER BY
    company.company_name ASC

NOW again I want to search on last result data (which was 3 results) based on family_name or given_name or department search string

For that I am using following query :

SELECT
    cd.family_name,
    cd.given_name,
    cd.department,
    cd.title,
    cd.cid,
    ps.*, company.company_name
FROM
    contact_details AS cd
LEFT JOIN project_status AS ps ON cd.cdid = ps.cdid
LEFT JOIN company ON company.cid = cd.cid
WHERE
    1 = 1
AND ps.sid IN (25, 22)
AND company.company_name LIKE '%ab%'
OR cd.family_name LIKE '%ab%'
OR cd.given_name LIKE '%ab%'
AND ps.p_id = '3'
GROUP BY
    cd.cdid
ORDER BY
    company.company_name ASC

Now it's should not show me more that 3 result because I have 3 result shown on my first query. BUT unfortunately it's showing me more than 3 results from contact_details table

  • 写回答

3条回答 默认 最新

  • douren1891 2016-08-01 10:56
    关注

    Try to modify last part of sql:

    SELECT
    cd.family_name,
    cd.given_name,
    cd.department,
    cd.title,
    cd.cid,
    ps.*, 
    company.company_name
    FROM contact_details AS cd
    LEFT JOIN project_status AS ps ON cd.cdid = ps.cdid
    LEFT JOIN company ON company.cid = cd.cid
    WHERE ps.sid IN (25, 22)
    AND (company.company_name LIKE '%ab%' 
       OR cd.family_name LIKE '%ab%' 
       OR cd.given_name LIKE '%ab%' )
    AND ps.p_id = '3'
    GROUP BY cd.cdid
    ORDER BY company.company_name ASC
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 找一个网络防御专家,外包的
  • ¥100 能不能让两张不同的图片md5值一样,(有尝)
  • ¥15 informer代码训练自己的数据集,改参数怎么改
  • ¥15 请看一下,学校实验要求,我需要具体代码
  • ¥50 pc微信3.6.0.18不能登陆 有偿解决问题
  • ¥20 MATLAB绘制两隐函数曲面的交线
  • ¥15 求TYPCE母转母转接头24PIN线路板图
  • ¥100 国外网络搭建,有偿交流
  • ¥15 高价求中通快递查询接口
  • ¥15 解决一个加好友限制问题 或者有好的方案