如何在 select 查询中内爆列及其值?
How to implode columns and their value in select query?
我有一组列及其由用户选择的值。我需要根据这些列和值执行搜索。
例如,用户选择:
早上(列)=> 周四、周日(值)
下午(列)=> 星期六(值)
现在,如何搜索与列和值匹配的记录?我正在使用 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)
Sample Columns and values stored in the database,对于一个record.So,我想使用上面的天数和列作为搜索条件。
在以下记录中,该用户有
'morning' => string 'Thrs'
'afternoon' => string 'Fri,Sat'
'evening' => ''
我的早上搜索条件是,星期四和星期日。但是这个用户只在星期四早上有空。满足 SO 1 标准。
下一个下午,该用户周五、周六有空。但我的搜索只需要星期六。由于满足其中一个,因此满足此条件。
但是假设我的搜索条件是晚上而不是早上和下午。那么该用户将不会被选中,因为 he/she 晚上不可用。
希望你能理解它是怎么回事..如果不明白,请随时问。谢谢。
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;
}
使用 MySQL 中的 LIKE 函数在您的列中搜索字符串。
在您的第一个示例中,搜索星期四或星期日早上:
SELECT * FROM `tableName` WHERE (`morning` LIKE '%Thrs%' OR `morning` LIKE '%Sun%');
要搜索周五或周六下午:
SELECT * FROM `tableName` WHERE (`afternoon` LIKE '%Fri%' OR `afternoon` LIKE '%Sat%');
这对于您的潜在值列表很短的场景来说已经足够了。然而,在传统的关系数据库中,将具有多个值的列移动到单独的 table 而不是在单个列中使用逗号分隔值通常是一种很好的做法。这通过使用索引可以更好地扩展,并在术语或查询方面提供更大的灵活性 运行。
我有一组列及其由用户选择的值。我需要根据这些列和值执行搜索。
例如,用户选择:
早上(列)=> 周四、周日(值)
下午(列)=> 星期六(值)
现在,如何搜索与列和值匹配的记录?我正在使用 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)
Sample Columns and values stored in the database,对于一个record.So,我想使用上面的天数和列作为搜索条件。
在以下记录中,该用户有
'morning' => string 'Thrs'
'afternoon' => string 'Fri,Sat'
'evening' => ''
我的早上搜索条件是,星期四和星期日。但是这个用户只在星期四早上有空。满足 SO 1 标准。
下一个下午,该用户周五、周六有空。但我的搜索只需要星期六。由于满足其中一个,因此满足此条件。
但是假设我的搜索条件是晚上而不是早上和下午。那么该用户将不会被选中,因为 he/she 晚上不可用。
希望你能理解它是怎么回事..如果不明白,请随时问。谢谢。
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;
}
使用 MySQL 中的 LIKE 函数在您的列中搜索字符串。
在您的第一个示例中,搜索星期四或星期日早上:
SELECT * FROM `tableName` WHERE (`morning` LIKE '%Thrs%' OR `morning` LIKE '%Sun%');
要搜索周五或周六下午:
SELECT * FROM `tableName` WHERE (`afternoon` LIKE '%Fri%' OR `afternoon` LIKE '%Sat%');
这对于您的潜在值列表很短的场景来说已经足够了。然而,在传统的关系数据库中,将具有多个值的列移动到单独的 table 而不是在单个列中使用逗号分隔值通常是一种很好的做法。这通过使用索引可以更好地扩展,并在术语或查询方面提供更大的灵活性 运行。