複数のクエリ条件を含む SQL ステートメントのスペル スキルについてアドバイスをお願いします。

WBOY
リリース: 2016-06-23 14:19:34
オリジナル
1237 人が閲覧しました

複数のクエリ条件を含む SQL ステートメントのスペル スキルについてアドバイスをお願いします。

$sql="select * from tb1";if($id=$_GET['id']){	$where.=" where id like "%$id%"";}if($name=$_GET['name']){	$where.=" where name like "%$name%"";}//当id有值的时候sql=select * from tb1 where id like "%$id%"//当name有值的时候sql=select * from tb1 where name like "%$name%"//当同时又值的时候,sql就出错了sql=select * from tb1 where name like "%$name%" where where id like "%$id%" //当然你可以说用if($id=$_GET['id']&&$name=$_GET['name']){	where.= "and";}
ログイン後にコピー

私が挙げた例には 2 つの条件しかありませんが、実際のプロジェクトでは、この方法は間違いなく機能しません。
より良い接合方法を求めています


ディスカッション(解決策)への返信

$where = array();foreach($_GET as $k=>v) $where[] = "$k like '%$v%'";$sql="select * from tb1";if($where) $sql .= ' where ' . join(' and ', $where);
ログイン後にコピー

$sql="select * from tb1";$where = array();if($id=$_GET['id']){    $where[]=" id like '%$id%'";}if($name=$_GET['name']){    $where[]=" name like '%$name%'";}$s=(!empty($where)) ? " where " . implode(" and " , $where) : '';$sql.=$s;
ログイン後にコピー

私は個人的に私の

$sql="select * from tb1 where 1=1";if($id=$_GET['id']) $sql.=" and id like "%$id%"";if($name=$_GET['name']) $sql.=" and name like "%$name%"";
ログイン後にコピー
ログイン後にコピー
はシンプルだと思います

私は個人的に私の

$sql="select * from tb1 where 1=1";if($id=$_GET['id']) $sql.=" and id like "%$id%"";if($name=$_GET['name']) $sql.=" and name like "%$name%"";
ログイン後にコピー
ログイン後にコピー
はシンプルだと思います
あなたは単純です No 2 #わかりました
でも、彼らは全員マスターです

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート