目录
回复内容:
首页 后端开发 php教程 mariadb - php使用带where的SQL查不出数据

mariadb - php使用带where的SQL查不出数据

Jun 06, 2016 pm 08:30 PM
mariadb php sql

先上代码:

<code>php</code><code class="lang-php"><form method="post" action="&lt;?php%20echo%20htmlspecialchars(%24_SERVER%5B" php_self>"&gt; 
<input name="qname" type="text" class="textlable" id="lname" onfocus="if (value =='姓名'){value ='';}" onblur="if (value == ''){value='姓名';}" value="姓名">
<input name="qcont" type="submit" value="查询">
</form>
<?php if ($_SERVER["REQUEST_METHOD"] == "POST") {
     if ($_POST["qname"] =="姓名") {
     $nameErr = "请输入姓名";
     }else {
        $con = mysql_connect("localhost","root","123456");
if (!$con)
  {
  die('Could not connect: ' . mysql_error());
  }
    mysql_query("set names ’utf8’ ");  
    mysql_query("set character_set_client=utf8");  
    mysql_query("set character_set_results=utf8"); 
    mysql_select_db("gkweb", $con);
    $sql="select c_name,c_extension,c_mail from gk_contacts where c_name='".$_POST["qname"]."'";
    echo $sql;
    $result = mysql_query($sql);
    echo "<table align='center' class='altrowstable' id='alternatecolor'><tr>
<th>姓名</th>
<th>座机</th>
<th>电子邮件</th>
</tr>";
    echo 123;
while($row = mysql_fetch_array($result))
  {
  echo "<tr>";
  echo "<td>" . $row['c_name'] . "</td>";
  echo "<td>" . $row['c_extension'] . "</td>";
  echo "<td>" . $row['c_mail'] . "</td>";
  echo "</tr>";
  }
echo "";
mysql_close($con);
     }}
?&gt;
</code>
登录后复制
登录后复制

不知道为什么只要使用了带where的sql进行查询就没有输出结果。
但是使用$sql="select c_name,c_extension,c_mail from gk_contacts"却能输出所有数据.
我也使用echo $sql;输出的SQL在数据库后台查询了,能输出结果。求大神告知是哪里写错了。
不知道怎么排版,求不嫌弃。谢谢
刚才有大神说可能是数据库字符编码的问题,可我数据库都是用的UTF8

<code>bash</code><code class="lang-bash">MariaDB [(none)]&gt;  show variables like '%char%';
+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | utf8                       |
| character_set_connection | utf8                       |
| character_set_database   | utf8                       |
| character_set_filesystem | binary                     |
| character_set_results    | utf8                       |
| character_set_server     | utf8                       |
| character_set_system     | utf8                       |
| character_sets_dir       | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
8 rows in set (0.00 sec)
</code>
登录后复制
登录后复制

回复内容:

先上代码:

<code>php</code><code class="lang-php"><form method="post" action="&lt;?php%20echo%20htmlspecialchars(%24_SERVER%5B" php_self>"&gt; 
<input name="qname" type="text" class="textlable" id="lname" onfocus="if (value =='姓名'){value ='';}" onblur="if (value == ''){value='姓名';}" value="姓名">
<input name="qcont" type="submit" value="查询">
</form>
<?php if ($_SERVER["REQUEST_METHOD"] == "POST") {
     if ($_POST["qname"] =="姓名") {
     $nameErr = "请输入姓名";
     }else {
        $con = mysql_connect("localhost","root","123456");
if (!$con)
  {
  die('Could not connect: ' . mysql_error());
  }
    mysql_query("set names ’utf8’ ");  
    mysql_query("set character_set_client=utf8");  
    mysql_query("set character_set_results=utf8"); 
    mysql_select_db("gkweb", $con);
    $sql="select c_name,c_extension,c_mail from gk_contacts where c_name='".$_POST["qname"]."'";
    echo $sql;
    $result = mysql_query($sql);
    echo "<table align='center' class='altrowstable' id='alternatecolor'><tr>
<th>姓名</th>
<th>座机</th>
<th>电子邮件</th>
</tr>";
    echo 123;
while($row = mysql_fetch_array($result))
  {
  echo "<tr>";
  echo "<td>" . $row['c_name'] . "</td>";
  echo "<td>" . $row['c_extension'] . "</td>";
  echo "<td>" . $row['c_mail'] . "</td>";
  echo "</tr>";
  }
echo "";
mysql_close($con);
     }}
?&gt;
</code>
登录后复制
登录后复制

不知道为什么只要使用了带where的sql进行查询就没有输出结果。
但是使用$sql="select c_name,c_extension,c_mail from gk_contacts"却能输出所有数据.
我也使用echo $sql;输出的SQL在数据库后台查询了,能输出结果。求大神告知是哪里写错了。
不知道怎么排版,求不嫌弃。谢谢
刚才有大神说可能是数据库字符编码的问题,可我数据库都是用的UTF8

<code>bash</code><code class="lang-bash">MariaDB [(none)]&gt;  show variables like '%char%';
+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | utf8                       |
| character_set_connection | utf8                       |
| character_set_database   | utf8                       |
| character_set_filesystem | binary                     |
| character_set_results    | utf8                       |
| character_set_server     | utf8                       |
| character_set_system     | utf8                       |
| character_sets_dir       | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
8 rows in set (0.00 sec)
</code>
登录后复制
登录后复制

mysql_query("set names ’utf8’ "); 改成mysql_query("set names utf8 ")

先确认一下记录是否存在或者qname是否拼写错误。如果都无误的话。那应该就是数据库表的编码问题了。

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

适用于 Ubuntu 和 Debian 的 PHP 8.4 安装和升级指南 适用于 Ubuntu 和 Debian 的 PHP 8.4 安装和升级指南 Dec 24, 2024 pm 04:42 PM

适用于 Ubuntu 和 Debian 的 PHP 8.4 安装和升级指南

CakePHP 日期和时间 CakePHP 日期和时间 Sep 10, 2024 pm 05:27 PM

CakePHP 日期和时间

CakePHP 文件上传 CakePHP 文件上传 Sep 10, 2024 pm 05:27 PM

CakePHP 文件上传

CakePHP 项目配置 CakePHP 项目配置 Sep 10, 2024 pm 05:25 PM

CakePHP 项目配置

CakePHP 路由 CakePHP 路由 Sep 10, 2024 pm 05:25 PM

CakePHP 路由

讨论 CakePHP 讨论 CakePHP Sep 10, 2024 pm 05:28 PM

讨论 CakePHP

CakePHP 快速指南 CakePHP 快速指南 Sep 10, 2024 pm 05:27 PM

CakePHP 快速指南

如何设置 Visual Studio Code (VS Code) 进行 PHP 开发 如何设置 Visual Studio Code (VS Code) 进行 PHP 开发 Dec 20, 2024 am 11:31 AM

如何设置 Visual Studio Code (VS Code) 进行 PHP 开发

See all articles