Maison > développement back-end > tutoriel php > Comment implémenter une requête conditionnelle en php+mysql ? (exemple de code)

Comment implémenter une requête conditionnelle en php+mysql ? (exemple de code)

怪我咯
Libérer: 2023-03-14 12:06:01
original
24478 Les gens l'ont consulté

Comment implémenter plusieurs conditions dans les champs de requête SQL : connectez-vous d'abord à la base de données ; puis utilisez l'instruction "select from...WHERE...." de SQL pour effectuer des requêtes à condition unique et multi-conditions sur la base de données.

Comment implémenter une requête conditionnelle en php+mysql ? (exemple de code)

Cet article partage avec vous le code et des exemples d'utilisation de php+mysql pour implémenter des requêtes à condition unique et multi-conditions dans Friends. besoin peut s'y référer. Recommandez les

tutoriels vidéo mysql associés : "tutoriel mysql "

Requête à condition unique :

1. Il doit d'abord y avoir un tableau A montrant les données dans le tableau :

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  <title>无标题文档</title>
</head>

<body>
<table border="1" cellspacing="0" cellpadding="0">
  <tr>
    <td width="200">编号</td>
    <td width="200">姓名</td>
    <td width="200">电话</td>
    <td width="200" >分组</td>

  </tr>
  <?php
  $db = new mysqli("localhost","root","12345678","heiheihei");
  $sql = "select * from contacts";
  $r = $db->query($sql);
  //传值
  while ($attr = $r->fetch_row())
  {
    echo " <tr>
    <td>{$attr[0]}</td> 

    <td>{$attr[1]}</td>
    <td>{$attr[2]}</td>
    <td>{$attr[3]}</td>
    
  </tr>";
  }
  ?>
</table>


</body>
</html>
Copier après la connexion

Ci-dessus :

Un tableau sans aucun changement

2. Laissez l'utilisateur saisir un autre formulaire et cliquez pour interroger :

<form action="shouye.php" method="post">
  <p>
    输入名字:<input type="text" name="name"/>
    <input type="submit" value="查询"/>

  </p>

</form>
Copier après la connexion

Comme le montre l'image :

3. . Créez une requête par mot-clé :

<?php
  //实现两个逻辑
  //1.如果没有post数据.查所有的
  //2.如果有post数据.根据条件查
  $db = new mysqli("localhost","root","12345678","heiheihei");
  //连接数据库
  $tj = " 1 = 1 ";
  $name="";
  //恒成立,如果没有写数据,那就让条件等于1=1,这个条件是查找所有的数据
  //如果你写入数据,按照数据查
  if(!empty($_POST))
  {
    $name = $_POST[&#39;name&#39;];
    $tj = " name like &#39;%{$name}%&#39;";
  }
  //将条件拼接到SQl语句
  $sql = "select * from contacts WHERE {$tj}";
  echo $sql;

  //查出来
  $r = $db->query($sql);
  //传值
  if($r)
    //开始判断
  {
    //$attr已经接收到了值,现在只需要获取他的索引就行了
    while ($attr = $r->fetch_row())
    {
      //关键字特殊查询

     $str = str_replace($name,"<mark>{$name}</mark>",$attr[1]);  //查找替换如ctrl+f
      //substr_replace();     在指定位置替换
      //substr();    截取字符串

      $gname = "select gname from groups WHERE gid=&#39;{$attr[3]}&#39;";
      //分组表中的gid,和我点击的
      $nresult = $db->query($gname);
      $gname = $nresult->fetch_row();
      $nation = $gname[0];
 echo " <tr>
<td>{$attr[0]}</td> 

<td>{$str}</td>
<td>{$attr[2]}</td>
<td>{$nation}</td>


?>
Copier après la connexion

Image :

Requête multi-conditions :

La même que précédemment ; >

sort avec l'instruction php :

<?php
  //实现两个逻辑
  //1.如果没有post数据.查所有的
  //2.如果有post数据.根据条件查
  $db = new mysqli("localhost","root","12345678","heiheihei");
  //连接数据库
  $tj1 = " 1 = 1 ";
  $tj2 = " 1 = 1 ";//两个条件的恒等
  $name="";
  //恒成立,如果没有写数据,那就让条件等于1=1,这个条件是查找所有的数据
  //如果你写入数据,按照数据查
  if(!empty($_POST["name"])) //第一个条件的判断(用到了模糊查询)
  {
    $name = $_POST[&#39;name&#39;];
    $tj1 = " name like &#39;%{$name}%&#39;";
  }
  if(!empty($_POST["tel"]))
  {
    $tel = $_POST["tel"];
    $tj2 = "tel = &#39;$tel&#39;";
  }
  //将条件拼接到SQl语句
  $sql = "select * from contacts WHERE {$tj1} AND {$tj2}";
Copier après la connexion
Rendu :

De cette façon : s'il y a plusieurs conditions, créez plusieurs variables de condition , et la première condition sera exécutée si elle n'est pas vide. La première condition et la deuxième condition ne sont pas vides. La deuxième condition est exécutée si les deux sont vides, toutes les données sont recherchées

.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal