文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL 查询数据

2024-04-02 19:55

关注

MySQL 查询数据

MySQL 数据库使用SQL SELECT语句来查询数据。

你可以通过 mysql> 命令提示窗口中在数据库中查询数据,或者通过PHP脚本来查询数据。

语法

以下为在MySQL数据库中查询数据通用的 SELECT 语法:

SELECT column_name,column_name
FROM table_name[WHERE Clause][LIMIT N][ OFFSET M]

通过命令提示符获取数据

以下实例我们将通过 SQL SELECT 命令来获取 MySQL 数据表 runoob_tbl 的数据:

实例

以下实例将返回数据表 runoob_tbl 的所有记录:

读取数据表:

select * from runoob_tbl;

输出结果:

MySQL 查询数据


使用PHP脚本来获取数据

使用 PHP 函数的 mysqli_query() 及 SQL SELECT 命令来获取数据。

该函数用于执行 SQL 命令,然后通过 PHP 函数 mysqli_fetch_array() 来使用或输出所有查询的数据。

mysqli_fetch_array() 函数从结果集中取得一行作为关联数组,或数字数组,或二者兼有 返回根据从结果集取得的行生成的数组,如果没有更多行则返回 false。

以下实例为从数据表 runoob_tbl 中读取所有记录。

实例

尝试以下实例来显示数据表 runoob_tbl 的所有记录。

使用 mysqli_fetch_array MYSQL_ASSOC 参数获取数据:

<?php

                     $dbhost = 'localhost:3306';          // mysql服务器主机地址

                     $dbuser = 'root';                          // mysql用户名

                     $dbpass = '123456';                    // mysql用户名密码

$conn = mysqli_connect($dbhost, $dbuser, $dbpass);

if(! $conn )

{    

                          die('连接失败: ' .mysqli_error($conn));

}

// 设置编码,防止中文乱码

mysqli_query($conn , "set names utf8");



$sql = 'SELECT runoob_id, runoob_title,    

           runoob_author, submission_date       

           FROM runoob_tbl';



mysqli_select_db( $conn, 'RUNOOB' );

$retval = mysqli_query( $conn, $sql );

if(! $retval )

{    

      die('无法读取数据: ' . mysqli_error($conn));

}

echo '<h3>菜鸟教程 mysqli_fetch_array 测试<h3>';

echo '<table border="1"><tr><td>教程 ID</td><td></td><td>作者</td><td>提交日期</td></tr>';

while($row = mysqli_fetch_array($retval, MYSQL_ASSOC))

{    

           echo "<tr><td> {$row['runoob_id']}</td> ".       

                    "<td>{$row['runoob_title']} </td> ".       

                    "<td>{$row['runoob_author']} </td> ".       

                    "<td>{$row['submission_date']} </td> ".       

                     "</tr>";}echo '</table>';mysqli_close($conn);?>

}

echo '</table>';

mysqli_close($conn);

?>

输出结果如下所示:

MySQL 查询数据

以上实例中,读取的每行记录赋值给变量 $row,然后再打印出每个值。

注意:记住如果你需要在字符串中使用变量,请将变量置于花括号。

在上面的例子中,PHP mysqli_fetch_array() 函数第二个参数为 MYSQL_ASSOC, 设置该参数查询结果返回关联数组,你可以使用字段名称来作为数组的索引。

PHP 提供了另外一个函数 mysqli_fetch_assoc(), 该函数从结果集中取得一行作为关联数组。 返回根据从结果集取得的行生成的关联数组,如果没有更多行,则返回 false。

实例

尝试以下实例,该实例使用了 mysqli_fetch_assoc() 函数来输出数据表 runoob_tbl 的所有记录:

使用 mysqli_fetch_assoc 获取数据:

<?php

$dbhost = 'localhost:3306';  // mysql服务器主机地址

$dbuser = 'root';                  // mysql用户名

$dbpass = '123456';            // mysql用户名密码

$conn = mysqli_connect($dbhost, $dbuser, $dbpass);

if(! $conn )

{    

die('连接失败: ' . mysqli_error($conn));

}

// 设置编码,防止中文乱码

mysqli_query($conn , "set names utf8");


$sql = 'SELECT runoob_id, runoob_title,       

            runoob_author, submission_date      

            FROM runoob_tbl';


mysqli_select_db( $conn, 'RUNOOB' );

$retval = mysqli_query( $conn, $sql );

if(! $retval )


  die('无法读取数据: ' . mysqli_error($conn));

}

echo '<h3>菜鸟教程 mysqli_fetch_assoc 测试<h3>';

echo '<table border="1"><tr><td>教程 ID</td><td></td><td>作者</td><td>提交日期</td></tr>';

while($row = mysqli_fetch_assoc($retval))

{    

echo "<tr><td> {$row['runoob_id']}</td> ".       

         "<td>{$row['runoob_title']} </td> ".      

         "<td>{$row['runoob_author']} </td> ".    

         "<td>{$row['submission_date']} </td> ".     

         "</tr>";

}

echo '</table>';

mysqli_close($conn);

?>

输出结果如下所示:

MySQL 查询数据

你也可以使用常量 MYSQL_NUM 作为 PHP mysqli_fetch_array() 函数的第二个参数,返回数字数组。

实例

以下实例使用 MYSQL_NUM 参数显示数据表 runoob_tbl 的所有记录:

使用 mysqli_fetch_array MYSQL_NUM 参数获取数据:

<?php

           $dbhost = 'localhost:3306';  // mysql服务器主机地址

           $dbuser = 'root';                  // mysql用户名

          $dbpass = '123456';            // mysql用户名密码


$conn = mysqli_connect($dbhost, $dbuser, $dbpass);if(! $conn )

{   


die('连接失败: ' . mysqli_error($conn));

}

// 设置编码,防止中文乱码


mysqli_query($conn , "set names utf8");

              $sql = 'SELECT runoob_id, runoob_title,      

                         runoob_author, submission_date      

                        FROM runoob_tbl';


mysqli_select_db( $conn, 'RUNOOB' );

$retval = mysqli_query( $conn, $sql );


if(! $retval )

{   

die('无法读取数据: ' . mysqli_error($conn));

}

echo '<h3>菜鸟教程 mysqli_fetch_array 测试<h3>';

echo '<table border="1"><tr><td>教程 ID</td><td></td><td>作者</td><td>提交日期</td></tr>';


while($row = mysqli_fetch_array($retval, MYSQL_NUM))

{  

 echo "<tr><td> {$row[0]}</td> ".       

"<td>{$row[1]} </td> ".       

"<td>{$row[2]} </td> ".      

  "<td>{$row[3]} </td> ".        

"</tr>";

}

echo '</table>';

mysqli_close($conn);

?>

输出结果如下所示:

MySQL 查询数据

以上三个实例输出结果都一样。


内存释放

在我们执行完 SELECT 语句后,释放游标内存是一个很好的习惯。

可以通过 PHP 函数 mysqli_free_result() 来实现内存的释放。

以下实例演示了该函数的使用方法。

实例

尝试以下实例:

使用 mysqli_free_result 释放内存:

<?php

$dbhost = 'localhost:3306';   // mysql服务器主机地址

$dbuser = 'root';                   // mysql用户名

$dbpass = '123456';             // mysql用户名密码

$conn = mysqli_connect($dbhost, $dbuser, $dbpass);


if(! $conn )

{   

die('连接失败: ' . mysqli_error($conn));

}

// 设置编码,防止中文乱码


mysqli_query($conn , "set names utf8");

$sql = 'SELECT runoob_id, runoob_title,      

            runoob_author, submission_date     

            FROM runoob_tbl';


mysqli_select_db( $conn, 'RUNOOB' );

$retval = mysqli_query( $conn, $sql );

if(! $retval )

{  

 die('无法读取数据: ' . mysqli_error($conn));

}

echo '<h3>菜鸟教程 mysqli_fetch_array 测试<h3>';

echo '<table border="1"><tr><td>教程 ID</td><td></td><td>作者</td><td>提交日期</td></tr>';


while($row = mysqli_fetch_array($retval, MYSQL_NUM))

{  

 echo "<tr><td> {$row[0]}</td> ".       

"<td>{$row[1]} </td> ".       

"<td>{$row[2]} </td> ".        

"<td>{$row[3]} </td> ".       

"</tr>";}

echo '</table>';// 释放内存

mysqli_free_result($retval);

mysqli_close($conn);

?>

输出结果如下所示:

MySQL 查询数据


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯