duanjuebiao6730 2016-02-08 19:46
浏览 41
已采纳

在UNION查询中将php数组中的值作为参数传递

I want to pass values from array as individual parameter in a query and use them as below

Array
(
    [0] => some
    [1] => text
)

I want this kind of function

public function getData($some,$text)
{
$sql = " select * from table where field1 = '{$some}' OR field3 = {$some}      ";
$union = " UNION ";
$sql = " select * from table where field2 = '{$text}' or field4 = {$text}  ";
}

Note: The array may have Nth number of index.

  • 写回答

2条回答 默认 最新

  • dryeyhe0266 2016-02-09 04:42
    关注

    You can use the following:

    public function getQuery($dataArray) {
        $queryArray = array();
        foreach($dataArray as $data) {
            $query = "SELECT * from `table`";
            $conditionArray = array();
            foreach($data as $key => $value) {
                $conditionArray[] = "`$key` = `$value`";
            }
            if (!empty ($conditionArray)) {
                $query .= " WHERE ". implode(" OR ", $conditionArray);
            }
            $queryArray[] = $query;
        }
        return implode(" UNION ", $queryArray);
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥30 关于用python写支付宝扫码付异步通知收不到的问题
  • ¥50 vue组件中无法正确接收并处理axios请求
  • ¥15 隐藏系统界面pdf的打印、下载按钮
  • ¥15 MATLAB联合adams仿真卡死如何解决(代码模型无问题)
  • ¥15 基于pso参数优化的LightGBM分类模型
  • ¥15 安装Paddleocr时报错无法解决
  • ¥15 python中transformers可以正常下载,但是没有办法使用pipeline
  • ¥50 分布式追踪trace异常问题
  • ¥15 人在外地出差,速帮一点点
  • ¥15 如何使用canvas在图片上进行如下的标注,以下代码不起作用,如何修改