dongxue163536 2013-10-17 11:32
浏览 108
已采纳

查找与多列搜索查询匹配的列名称

I Have a simple search query which works just fine

$result = mysql_query("SELECT id, $column, $column2 FROM $table WHERE BINARY account_no='{$_SESSION['account']}' AND $column LIKE '$query' OR $column2 LIKE '$query'") or die(mysql_error());

$output_column=column1 or column2 //which column has been matched?

However when there is a match on a particulat column i would like to be able to find out which column has been matched.

Is this possible?

  • 写回答

1条回答 默认 最新

  • dongwei1921 2013-10-17 11:37
    关注

    Yes, just edit your query like this:

    $result = mysql_query("
        SELECT 
            id, $column, $column2,
            IF ($column LIKE '$query', 1, 0) AS `column_true`,
            IF ($column2 LIKE '$query', 1, 0) AS `column2_true`
        FROM $table
        WHERE BINARY account_no='{$_SESSION['account']}' AND ($column LIKE '$query' OR $column2 LIKE '$query')")
    or die(mysql_error());
    

    so you will fetch also another 2 data field. if column_true = 1, first column condition was true if column2_true = 1, second column condition was true

    if both are 1, the both column and column2 matched your condition.

    Btw: you have error in your query, missing ( ) around OR condition

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 请问有会的吗,用MATLAB做
  • ¥15 phython如何实现以下功能?查找同一用户名的消费金额合并—
  • ¥15 ARIMA模型时间序列预测用pathon解决
  • ¥15 孟德尔随机化怎样画共定位分析图
  • ¥18 模拟电路问题解答有偿速度
  • ¥15 CST仿真别人的模型结果仿真结果S参数完全不对
  • ¥15 误删注册表文件致win10无法开启
  • ¥15 请问在阿里云服务器中怎么利用数据库制作网站
  • ¥60 ESP32怎么烧录自启动程序,怎么查看客户esp32板子上程序及烧录地址
  • ¥50 html2canvas超出滚动条不显示