zoukankan      html  css  js  c++  java
  • 吴裕雄 11-MySQL查询数据

    以下为在MySQL数据库中查询数据通用的 SELECT 语法:
    SELECT column_name,column_name
    FROM table_name
    [WHERE Clause]
    [LIMIT N][ OFFSET M]
    查询语句中你可以使用一个或者多个表,表之间使用逗号(,)分割,
    并使用WHERE语句来设定查询条件。
    SELECT 命令可以读取一条或者多条记录。
    你可以使用星号(*)来代替其他字段,SELECT语句会返回表的所有字段数据
    你可以使用 WHERE 语句来包含任何条件。
    你可以使用 LIMIT 属性来设定返回的记录数。
    你可以通过OFFSET指定SELECT语句开始查询的数据偏移量。默认情况下偏移量为0。

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

    使用PHP脚本来获取数据
    使用 PHP 函数的 mysqli_query() 及 SQL SELECT 命令来获取数据。
    该函数用于执行 SQL 命令,然后通过 PHP 函数 mysqli_fetch_array()
    来使用或输出所有查询的数据。
    mysqli_fetch_array() 函数从结果集中取得一行作为关联数组,或数字数组,
    或二者兼有 返回根据从结果集取得的行生成的数组,如果没有更多行则返回 false。
    以下实例为从数据表 runoob_tbl 中读取所有记录。
    实例
    尝试以下实例来显示数据表 runoob_tbl 的所有记录。
    <?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 '<h2>菜鸟教程 mysqli_fetch_array 测试<h2>';
    echo '<table border="1"><tr><td>教程 ID</td><td>标题</td><td>作者</td><td>提交日期</td></tr>';
    while($row = mysqli_fetch_array($retval, MYSQLI_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);
    ?>

    注意:记住如果你需要在字符串中使用变量,请将变量置于花括号。
    在上面的例子中,PHP mysqli_fetch_array() 函数第二个参数为 MYSQLI_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 '<h2>菜鸟教程 mysqli_fetch_assoc 测试<h2>';
    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);
    ?>

    你也可以使用常量 MYSQLI_NUM 作为 PHP mysqli_fetch_array()
    函数的第二个参数,返回数字数组。
    实例
    以下实例使用 MYSQLI_NUM 参数显示数据表 runoob_tbl 的所有记录:
    <?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 '<h2>菜鸟教程 mysqli_fetch_array 测试<h2>';
    echo '<table border="1"><tr><td>教程 ID</td><td>标题</td><td>作者</td><td>提交日期</td></tr>';
    while($row = mysqli_fetch_array($retval, MYSQLI_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);
    ?>

    内存释放
    在我们执行完 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 '<h2>菜鸟教程 mysqli_fetch_array 测试<h2>';
    echo '<table border="1"><tr><td>教程 ID</td><td>标题</td><td>作者</td><td>提交日期</td></tr>';
    while($row = mysqli_fetch_array($retval, MYSQLI_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);
    ?>

    select _column,_column from _table [where Clause] [limit N][offset M]
    select * : 返回所有记录
    limit N : 返回 N 条记录
    offset M : 跳过 M 条记录, 默认 M=0, 单独使用似乎不起作用
    limit N,M : 相当于 offset N limit M , 从第 N 条记录开始, 返回 M 条记录
    实现分页:
    select * from _table limit (page_number-1)*lines_perpage, lines_perpage

    select * from _table limit lines_perpage offset (page_number-1)*lines_perpage

    MySQL limit 应用的一些例子。
    语法格式:
    SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset
    解析:LIMIT 子句可以被用于强制 SELECT 语句返回指定的记录数。
    LIMIT 接受一个或两个数字参数。参数必须是一个整数常量。
    如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,
    第二个参数指定返回记录行的最大数目。
    初始记录行的偏移量是 0(而不是 1): 为了与 PostgreSQL 兼容,
    MySQL 也支持句法: LIMIT # OFFSET #。

    mysql> SELECT * FROM table LIMIT 5,10; // 检索记录行 6-15

    //为了检索从某一个偏移量到记录集的结束所有的记录行,可以指定第二个参数为 -1:
    mysql> SELECT * FROM table LIMIT 95,-1; // 检索记录行 96-last.

    //如果只给定一个参数,它表示返回最大的记录行数目:
    mysql> SELECT * FROM table LIMIT 5; //检索前 5 个记录行

    //换句话说,LIMIT n 等价于 LIMIT 0,n。
    Mysql 的分页查询语句的性能分析
    MySql 分页 sql 语句,如果和 MSSQL 的 TOP 语法相比,
    那么 MySQL 的 LIMIT 语法要显得优雅了许多。使用它来分页是再自然不过的事情了。

    2.1 最基本的分页方式:
    SELECT ... FROM ... WHERE ... ORDER BY ... LIMIT ...
    在中小数据量的情况下,这样的 SQL 足够用了,唯一需要注意的问题就是确保使用了索引。

    举例来说,如果实际 SQL 类似下面语句,那么在 category_id, id 两列上建立复合索引比较好。

    SELECT * FROM articles WHERE category_id = 123 ORDER BY id LIMIT 50, 10

    2.2 子查询的分页方式
    随着数据量的增加,页数会越来越多,查看后几页的 SQL 就可能类似:

    SELECT * FROM articles WHERE category_id = 123 ORDER BY id LIMIT 10000, 10
    一言以蔽之,就是越往后分页,LIMIT 语句的偏移量就会越大,速度也会明显变慢。

    此时,我们可以通过子查询的方式来提高分页效率,大致如下:

    SELECT * FROM articles WHERE id >=
    (SELECT id FROM articles WHERE category_id = 123 ORDER BY id LIMIT 10000, 1) LIMIT 10

    2.3 JOIN 分页方式
    SELECT * FROM `content` AS t1
    JOIN (SELECT id FROM `content` ORDER BY id desc LIMIT ".($page-1)*$pagesize.", 1) AS t2
    WHERE t1.id <= t2.id ORDER BY t1.id desc LIMIT $pagesize;
    经过我的测试,join 分页和子查询分页的效率基本在一个等级上,消耗的时间也基本一致。

    Mysql 简单查询语句,可以通过不同的查询语句进行套用。
    /*websites 表名 NAME alexa url country 字段*/
    SELECT * FROM websites; /* 查询表所有数据 */

    SELECT NAME FROM websites; /* 查询表字段数据 */

    SELECT * FROM websites where name = "广西"; /* 查询表字段下条件数据 */

    SELECT * from websites where name like "_o%"; /* 模糊查询表下数据 */

    SELECT * FROM websites where id BETWEEN "1" AND "5"; /* 查询表下字段范围数据 */

    SELECT * FROM websites WHERE name in ("广西","百度"); /* 查询表字段下固定条件数据 */

    SELECT DISTINCT country FROM Websites; /* 查询去重值 */

    SELECT * FROM Websites WHERE country = "CN" AND alexa > 50; /*查询表下范围条件数据*/

    SELECT * FROM Websites WHERE country = "USA" OR country="sh"; /* 查询表下条件不同值 */

    SELECT * FROM Websites ORDER BY alexa; /* 查询表下值排序结果 */

    SELECT * FROM Websites ORDER BY alexa DESC; /* 查询表下排序结果降序 */

    SELECT * FROM Websites LIMIT 2; /* 查询表下范围数据 */

    SELECT name as zzz from websites; /*别名查询表下数据*/

  • 相关阅读:
    老树新芽,在ES6下使用Express
    Swift3翻天覆地的改变
    NodeJs回调操作Promise化
    Node的关系型数据库ORM库:bookshelf
    基于Node的PetShop,RESTful API以及认证
    基于Node的PetShop,oauth2认证RESTful API
    Mongoose轻松搞定MongoDB,不要回调!
    Thymeleaf常用语法:表达式语法之运算符
    Thymeleaf对象的使用:日期对象
    Thymeleaf对象的使用:字符串对象
  • 原文地址:https://www.cnblogs.com/tszr/p/10089394.html
Copyright © 2011-2022 走看看