如何在选择查询中内插列及其值?

时间:2015-10-20 06:38:41

标签: php mysql implode

我有用户选择的列数组和值。我需要根据这些列和值执行搜索。

例如,用户选择:

上午(专栏)=>周四,太阳(值)
下午(专栏)=> SAT(值)

现在,如何搜索与列和值匹配的记录?我正在使用PDO。

数组:

//列

var_dump($cols);
 array (size=3)
      0 => string 'morning' (length=7)
      1 => string 'morning' (length=7)
      2 => string 'afternoon' (length=9)



var_dump($days);

//值

array (size=3)
  0 => string 'Thrs' (length=4)
  1 => string 'Sun' (length=3)
  2 => string 'Sat' (length=3)

存储在数据库中的示例列和值,用于记录。所以,我想使用上述日期和列作为搜索条件。

在以下记录中,此用户有

'morning' => string 'Thrs' 
'afternoon' => string 'Fri,Sat' 
'evening' => ''

我早上的搜索条件是周四和周日。但是这个用户只能在周四早上使用。符合SO 1标准。

下午,这个用户可以在星期五,星期五。我的搜索只需要周六。因为任何一个都符合,所以符合这个标准。

但是请说我的搜索条件只是晚上而不是早上和下午。然后,该用户将不会选择,因为他/她晚上不可用。

希望你明白它是怎么回事。如果没有随意问的话。谢谢。

array (size=1)
  0 => 
    array (size=25)
      'postUUID' => string '5623853773026' (length=13)
      'subid' => string '36' (length=2)
      'subname' => string 'Muay Thai' (length=9)
      'catID' => string '4' (length=1)
      'catname' => string 'Martial Arts' (length=12)
      'pricing' => string '200' (length=3)
      'post_status' => string '0' (length=1)
      'UUID' => string '562385374bddf' (length=13)
      'Name' => string 'Kalaivani Nair' (length=14)
      'Phone' => string '012345666' (length=9)
      'Email' => string 'kalaivaninair@ymail.com' (length=23)
      'location' => string 'kajang' (length=6)
      'lat' => string '2.993518' (length=8)
      'lon' => string '101.7874058' (length=11)
      'DateReg' => string '2015-10-18 19:40:39' (length=19)
      'Reputation' => string '0' (length=1)
      'ReviewPlus' => string '' (length=0)
      'ReviewNeg' => string '' (length=0)
      'Sex' => string 'f' (length=1)
      'centre' => string '0' (length=1)
      'morning' => string 'Thrs' (length=4)
      'afternoon' => string 'Fri,Sat' (length=7)
      'evening' => string '' (length=0)
      'catid' => string '4' (length=1)
      'distance' => string '0' (length=1)

根据史蒂夫的回答编辑

    "avail":["Wed-2","Wed-3"]//JSON string
   $data = json_decode($return, true);//decoded
  $avail = $data['avail'];//stored into database

      if($avail != ""){
        foreach($avail as $k=>$v)
        {
            echo $v;

            $array = explode('-', $v);
            $day =$array[0]; // Languages
            $column =  $array[1]; // English

            echo"<br/>";
            if($column == 1)
            {
            $col = "morning";

            }
            if($column == 2)
            {
                $col = "afternoon";
            }
            if($column == 3)
            {
                $col = "evening";
            }
             echo $col ."=>". $day;
            echo $sql=" SELECT * , (3956 * 2 * ASIN(SQRT( POWER(SIN(('$lat' - lat) *  pi()/180 / 2), 2) +COS('$lat' * pi()/180) * COS(lat * pi()/180) * POWER(SIN(('$lon' - lon) * pi()/180 / 2), 2) ))) as distance  
    from posts,subjects WHERE ('posts.".$col."' LIKE '%".$day."%') AND posts.catID = '$catid' AND posts.subname LIKE '%$subject%' AND posts.subid = subjects.subid AND posts.catID = subjects.catid  AND posts.pricing <= '$rate'  having  distance <= '$distance' order by distance ";
    echo"<br/>";
            // array_push($cols,$col);
            // array_push($days,$day);
        }
        }
            $stmt =connection::$pdo->prepare($sql);
            $stmt->execute();
    $place=array();
    while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) { 
                   $place[] = $row;
                   }

1 个答案:

答案 0 :(得分:1)

使用MySQL中的LIKE函数搜索列中的字符串。

在你的第一个例子中,搜索星期四或星期天的早晨:

SELECT * FROM `tableName` WHERE (`morning` LIKE '%Thrs%' OR `morning` LIKE '%Sun%');

要搜索周五或周六下午:

SELECT * FROM `tableName` WHERE (`afternoon` LIKE '%Fri%' OR `afternoon` LIKE '%Sat%');

这对于潜在值列表很短的场景就足够了。但是,在传统的关系数据库中,通常的做法是将具有多个值的列移动到单独的表中,而不是在单个列中使用逗号分隔值。通过使用索引可以更好地扩展,并提供更多的灵活性或可以运行的查询。