zoukankan      html  css  js  c++  java
  • MySQL 【教程二】

    MySQL 创建数据表

    • 创建MySQL数据表需要以下信息:
      • 表名
      • 表字段名
      • 定义每个表字段

    语法

    • 以下为创建MySQL数据表的SQL通用语法:
    # CREATE TABLE table_name (column_name column_type);
    • 以下例子中我们将在 RUNOOB 数据库中创建数据表runoob_tbl:
    CREATE TABLE IF NOT EXISTS `runoob_tbl`(
       `runoob_id` INT UNSIGNED AUTO_INCREMENT,
       `runoob_title` VARCHAR(100) NOT NULL,
       `runoob_author` VARCHAR(40) NOT NULL,
       `submission_date` DATE,
       PRIMARY KEY ( `runoob_id` )
    )ENGINE=InnoDB DEFAULT CHARSET=utf8;

    实例解析:

    • 如果你不想字段为 NULL 可以设置字段的属性为 NOT NULL, 在操作数据库时如果输入该字段的数据为NULL ,就会报错。
    • AUTO_INCREMENT定义列为自增的属性,一般用于主键,数值会自动加1。
    • PRIMARY KEY关键字用于定义列为主键。 您可以使用多列来定义主键,列间以逗号分隔。
    • ENGINE 设置存储引擎,CHARSET 设置编码。

    通过命令提示符创建表

    • 通过 mysql> 命令窗口可以很简单的创建MySQL数据表。你可以使用 SQL 语句 CREATE TABLE 来创建数据表。

    实例

    • 以下为创建数据表 runoob_tbl 实例:
    root@host# mysql -u root -p
    Enter password:*******
    mysql> use RUNOOB;
    Database changed
    mysql> CREATE TABLE runoob_tbl(
       -> runoob_id INT NOT NULL AUTO_INCREMENT,
       -> runoob_title VARCHAR(100) NOT NULL,
       -> runoob_author VARCHAR(40) NOT NULL,
       -> submission_date DATE,
       -> PRIMARY KEY ( runoob_id )
       -> )ENGINE=InnoDB DEFAULT CHARSET=utf8;
    Query OK, 0 rows affected (0.16 sec)
    mysql>
    • 注意:MySQL命令终止符为分号 ; 。
    • 注意: -> 是换行符标识,不要复制。

    使用PHP脚本创建数据表

    • 你可以使用 PHP 的 mysqli_query() 函数来创建已存在数据库的数据表。
    • 该函数有两个参数,在执行成功时返回 TRUE,否则返回 FALSE。

    语法

    # mysqli_query(connection,query,resultmode);
    参数描述
    connection 必需。规定要使用的 MySQL 连接。
    query 必需,规定查询字符串。
    resultmode

    可选。一个常量。可以是下列值中的任意一个:

    • MYSQLI_USE_RESULT(如果需要检索大量数据,请使用这个)
    • MYSQLI_STORE_RESULT(默认)

    实例

    以下实例使用了PHP脚本来创建数据表:

    <?php 
    $dbhost = 'localhost:3306'; // mysql服务器主机地址 
    $dbuser = 'root'; // mysql用户名 
    $dbpass = '123456'; // mysql用户名密码 
    $conn = mysqli_connect($dbhost, $dbuser, $dbpass); 
    if(! $conn ) 
    { 
        die('连接失败: ' . mysqli_error($conn)); 
    } 
    echo '连接成功<br />'; 
    $sql = "CREATE TABLE runoob_tbl( ". 
              "runoob_id INT NOT NULL AUTO_INCREMENT, ". 
              "runoob_title VARCHAR(100) NOT NULL, ".
              "runoob_author VARCHAR(40) NOT NULL, ". 
              "submission_date DATE, ".
              "PRIMARY KEY ( runoob_id ))ENGINE=InnoDB DEFAULT CHARSET=utf8; "; 
    mysqli_select_db( $conn, 'RUNOOB' ); 
    $retval = mysqli_query( $conn, $sql ); 
    if(! $retval ) 
    { 
        die('数据表创建失败: ' . mysqli_error($conn)); 
    } 
    echo "数据表创建成功
    "; 
    mysqli_close($conn); 
    ?>
    创建数据表

    执行成功后,就可以通过命令行查看表结构:

     

    MySQL 删除数据表

    • MySQL中删除数据表是非常容易操作的, 但是你再进行删除表操作时要非常小心,因为执行删除命令后所有数据都会消失。

    语法

    • 以下为删除MySQL数据表的通用语法
    # DROP TABLE table_name ;

    在命令提示窗口中删除数据表:

    • 在mysql>命令提示窗口中删除数据表SQL语句为 DROP TABLE 

    实例

    • 以下实例删除了数据表runoob_tbl:
    root@host# mysql -u root -p
    Enter password:*******
    mysql> use RUNOOB;
    Database changed
    mysql> DROP TABLE runoob_tbl
    Query OK, 0 rows affected (0.8 sec)
    mysql>

    使用PHP脚本删除数据表

    • PHP使用 mysqli_query 函数来删除 MySQL 数据表。
    • 该函数有两个参数,在执行成功时返回 TRUE,否则返回 FALSE。

    语法

    # mysqli_query(connection,query,resultmode);
    参数描述
    connection 必需。规定要使用的 MySQL 连接。
    query 必需,规定查询字符串。
    resultmode

    可选。一个常量。可以是下列值中的任意一个:

    • MYSQLI_USE_RESULT(如果需要检索大量数据,请使用这个)
    • MYSQLI_STORE_RESULT(默认)

    实例

    • 以下实例使用了PHP脚本删除数据表 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)); 
    } 
    echo '连接成功<br />'; 
    $sql = "DROP TABLE runoob_tbl"; mysqli_select_db( $conn, 'RUNOOB' ); 
    $retval = mysqli_query( $conn, $sql ); 
    if(! $retval ) 
    { 
        die('数据表删除失败: ' . mysqli_error($conn)); 
    } 
    echo "数据表删除成功
    "; 
    mysqli_close($conn); 
    ?>
    删除数据库
    • 执行成功后,我们使用以下命令,就看不到 runoob_tbl 表了:
    # mysql> show tables;
    # Empty set (0.01 sec)

    MySQL 插入数据

    • MySQL 表中使用 INSERT INTO SQL语句来插入数据。
    • 你可以通过 mysql> 命令提示窗口中向数据表中插入数据,或者通过PHP脚本来插入数据。

    语法

    • 以下为向MySQL数据表插入数据通用的 INSERT INTO SQL语法:
    INSERT INTO table_name ( field1, field2,...fieldN )
                           VALUES
                           ( value1, value2,...valueN );
    • 如果数据是字符型,必须使用单引号或者双引号,如:"value"。

    通过命令提示窗口插入数据

    • 以下我们将使用 SQL INSERT INTO 语句向 MySQL 数据表 runoob_tbl 插入数据

    实例

    • 以下实例中我们将向 runoob_tbl 表插入三条数据:
    root@host# mysql -u root -p password;
    Enter password:*******
    mysql> use RUNOOB;
    Database changed
    mysql> INSERT INTO runoob_tbl 
        -> (runoob_title, runoob_author, submission_date)
        -> VALUES
        -> ("学习 PHP", "前端", NOW());
    Query OK, 1 rows affected, 1 warnings (0.01 sec)
    mysql> INSERT INTO runoob_tbl
        -> (runoob_title, runoob_author, submission_date)
        -> VALUES
        -> ("学习 MySQL", "Python", NOW());
    Query OK, 1 rows affected, 1 warnings (0.01 sec)
    mysql> INSERT INTO runoob_tbl
        -> (runoob_title, runoob_author, submission_date)
        -> VALUES
        -> ("JAVA 教程", "RUNOOB.COM", '2016-05-06');
    Query OK, 1 rows affected (0.00 sec)
    mysql>
    • 注意: 使用箭头标记 -> 不是 SQL 语句的一部分,它仅仅表示一个新行,如果一条SQL语句太长,我们可以通过回车键来创建一个新行来编写 SQL 语句,SQL 语句的命令结束符为分号 ;
    • 在以上实例中,我们并没有提供 runoob_id 的数据,因为该字段我们在创建表的时候已经设置它为 AUTO_INCREMENT(自动增加) 属性。 所以,该字段会自动递增而不需要我们去设置。实例中 NOW() 是一个 MySQL 函数,该函数返回日期和时间。
    • 接下来我们可以通过以下语句查看数据表数据:

    读取数据表:

    # select * from runoob_tbl;

    使用PHP脚本插入数据

    • 你可以使用PHP 的 mysqli_query() 函数来执行 SQL INSERT INTO命令来插入数据。
    • 该函数有两个参数,在执行成功时返回 TRUE,否则返回 FALSE。

    语法

    # mysqli_query(connection,query,resultmode);
    参数描述
    connection 必需。规定要使用的 MySQL 连接。
    query 必需,规定查询字符串。
    resultmode

    可选。一个常量。可以是下列值中的任意一个:

    • MYSQLI_USE_RESULT(如果需要检索大量数据,请使用这个)
    • MYSQLI_STORE_RESULT(默认)

    实例

    • 以下实例中程序接收用户输入的三个字段数据,并插入数据表中:
    <?php 
    $dbhost = 'localhost:3306'; // mysql服务器主机地址 
    $dbuser = 'root'; // mysql用户名 
    $dbpass = '123456'; // mysql用户名密码 
    $conn = mysqli_connect($dbhost, $dbuser, $dbpass); 
    if(! $conn ) 
    { 
       die('连接失败: ' . mysqli_error($conn)); 
    } 
    echo '连接成功<br />';
    // 设置编码,防止中文乱码 
    mysqli_query($conn , "set names utf8"); 
    $runoob_title = '学习 Python'; 
    $runoob_author = 'RUNOOB.COM'; 
    $submission_date = '2016-03-06'; 
    $sql = "INSERT INTO runoob_tbl ". 
              "(runoob_title,runoob_author, submission_date) ". 
              "VALUES ". 
              "('$runoob_title','$runoob_author','$submission_date')"; mysqli_select_db( $conn, 'RUNOOB' ); 
    $retval = mysqli_query( $conn, $sql ); 
    if(! $retval ) 
    {
        die('无法插入数据: ' . mysqli_error($conn)); 
    } 
    echo "数据插入成功
    "; 
    mysqli_close($conn); 
    ?>
    添加数据
    • 对于含有中文的数据插入,需要添加 mysqli_query($conn , "set names utf8"); 语句。
    • 接下来我们可以通过以下语句查看数据表数据:

    读取数据表:

    # select * from runoob_tbl;

    MySQL 查询数据

    • MySQL 数据库使用SQL SELECT语句来查询数据。
    • 你可以通过 mysql> 命令提示窗口中在数据库中查询数据,或者通过PHP脚本来查询数据。

    语法

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

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

    最基本查询语句  

    mysql> select * from student limit 2;                    #仅查看student表中前两行数据
    mysql> select * from student limit 5 offset 3;       #从第三行开始查询,并且只显示5行数据

    GROUP BY 语句:指定以什么分组(比如可以统计出有多少同名数据)        

    mysql> select name,count(*) from student group by name;
    mysql> select coalesce(name,"Total age"),sum(age) from student group by name with rollup;

    修改(update)     

    mysql> update student set name="lisi",age=22 where id=1; #将表中id=1的条目改成name=lisi,age=22
    mysql> update student set name="lisi",age=22 where id>4; #上面仅仅修改一条,这里修改id>4的所有

    删除(delete)

    mysql> delete from student where name="zhangsan";    #删除student表中所有name=“zhangsan”

    MySQL WHERE 子句

    • 我们知道从 MySQL 表中使用 SQL SELECT 语句来读取数据。
    • 如需有条件地从表中选取数据,可将 WHERE 子句添加到 SELECT 语句中。

    语法

    • 以下是 SQL SELECT 语句使用 WHERE 子句从数据表中读取数据的通用语法:
    SELECT field1, field2,...fieldN FROM table_name1, table_name2...
    [WHERE condition1 [AND [OR]] condition2.....
    • 查询语句中你可以使用一个或者多个表,表之间使用逗号, 分割,并使用WHERE语句来设定查询条件。
    • 你可以在 WHERE 子句中指定任何条件。
    • 你可以使用 AND 或者 OR 指定一个或多个条件。
    • WHERE 子句也可以运用于 SQL 的 DELETE 或者 UPDATE 命令。
    • WHERE 子句类似于程序语言中的 if 条件,根据 MySQL 表中的字段值来读取指定的数据。

    以下为操作符列表,可用于 WHERE 子句中。

    • 下表中实例假定 A 为 10, B 为 20
    操作符描述实例
    = 等号,检测两个值是否相等,如果相等返回true (A = B) 返回false。
    <>, != 不等于,检测两个值是否相等,如果不相等返回true (A != B) 返回 true。
    > 大于号,检测左边的值是否大于右边的值, 如果左边的值大于右边的值返回true (A > B) 返回false。
    < 小于号,检测左边的值是否小于右边的值, 如果左边的值小于右边的值返回true (A < B) 返回 true。
    >= 大于等于号,检测左边的值是否大于或等于右边的值, 如果左边的值大于或等于右边的值返回true (A >= B) 返回false。
    <= 小于等于号,检测左边的值是否小于或等于右边的值, 如果左边的值小于或等于右边的值返回true (A <= B) 返回 true。
    • 如果我们想在 MySQL 数据表中读取指定的数据,WHERE 子句是非常有用的。
    • 使用主键来作为 WHERE 子句的条件查询是非常快速的。
    • 如果给定的条件在表中没有任何匹配的记录,那么查询不会返回任何数据。

    where; like; order by;使用

    mysql> select * from student where id >3 and age >103;
    mysql> select * from student where register_data like "2016-06%";         #查询所有在2016-06这一条新建的条目
    mysql> select * from student order by id desc;                              #按主键降续
    mysql> select * from student order by id asc;                                 #按主键升续排序(默认升续)
    mysql> select * from student where name like binary "%si" order by id desc;
    #查找名字以“si”结尾的所有条目,并且按照id降续排列

    MySQL UPDATE 更新

    • 如果我们需要修改或更新 MySQL 中的数据,我们可以使用 SQL UPDATE 命令来操作。

    语法

    • 以下是 UPDATE 命令修改 MySQL 数据表数据的通用 SQL 语法:
    # UPDATE table_name SET field1=new-value1, field2=new-value2
    # [WHERE Clause]
    • 你可以同时更新一个或多个字段。
    • 你可以在 WHERE 子句中指定任何条件。
    • 你可以在一个单独表中同时更新数据。
    • 当你需要更新数据表中指定行的数据时 WHERE 子句是非常有用的。

    通过命令提示符更新数据

    • 以下我们将在 SQL UPDATE 命令使用 WHERE 子句来更新 runoob_tbl 表中指定的数据:

    实例

    • 以下实例将更新数据表中 runoob_id 为 3 的 runoob_title 字段值:

    SQL UPDATE 语句:

    mysql> UPDATE runoob_tbl SET runoob_title='学习 C++' WHERE runoob_id=3; 
    Query OK, 1 rows affected (0.01 sec)
    mysql> SELECT * from runoob_tbl WHERE runoob_id=3;
    +-----------+--------------+---------------+-----------------+
    | runoob_id | runoob_title | runoob_author | submission_date |
    +-----------+--------------+---------------+-----------------+
    | 3 | 学习 C++ |RUNOOB.COM | 2016-05-06 |
    +-----------+--------------+---------------+-----------------+
    1 rows in set (0.01 sec)
    • 从结果上看,runoob_id 为 3 的 runoob_title 已被修改。

    使用PHP脚本更新数据

    • PHP 中使用函数 mysqli_query() 来执行 SQL 语句,你可以在 SQL UPDATE 语句中使用或者不使用 WHERE 子句。
    • 注意:不使用 WHERE 子句将数据表的全部数据进行更新,所以要慎重。
    • 该函数与在 mysql> 命令提示符中执行 SQL 语句的效果是一样的。

    实例

    • 以下实例将更新 runoob_id 为 3 的 runoob_title 字段的数据。
    <?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 = 'UPDATE runoob_tbl 
               SET runoob_title="学习 Python" 
               WHERE runoob_id=3'; 
    mysqli_select_db( $conn, 'RUNOOB' ); 
    $retval = mysqli_query( $conn, $sql ); 
    if(! $retval ) 
    { 
         die('无法更新数据: ' . mysqli_error($conn)); 
    } 
    echo '数据更新成功!'; 
    mysqli_close($conn); 
    ?>
    MySQL UPDATE 语句测试

    MySQL DELETE 语句

    • 你可以使用 SQL 的 DELETE FROM 命令来删除 MySQL 数据表中的记录。
    • 你可以在 mysql> 命令提示符或 PHP 脚本中执行该命令。

    语法

    • 以下是 SQL DELETE 语句从 MySQL 数据表中删除数据的通用语法:
    # DELETE FROM table_name [WHERE Clause]
    • 如果没有指定 WHERE 子句,MySQL 表中的所有记录将被删除。
    • 你可以在 WHERE 子句中指定任何条件
    • 您可以在单个表中一次性删除记录。
    • 当你想删除数据表中指定的记录时 WHERE 子句是非常有用的。

    从命令行中删除数据

    • 这里我们将在 SQL DELETE 命令中使用 WHERE 子句来删除 MySQL 数据表 runoob_tbl 所选的数据。

    实例

    • 以下实例将删除 runoob_tbl 表中 runoob_id 为3 的记录:

    DELETE 语句:

    mysql> use RUNOOB; 
    Database changed mysql> DELETE FROM runoob_tbl WHERE runoob_id=3;
    Query OK, 1 row affected (0.23 sec)

    使用 PHP 脚本删除数据

    • PHP使用 mysqli_query() 函数来执行SQL语句, 你可以在 SQL DELETE 命令中使用或不使用 WHERE 子句。
    • 该函数与 mysql> 命令符执行SQL命令的效果是一样的。

    实例

    • 以下PHP实例将删除 runoob_tbl 表中 runoob_id 为 3 的记录:
    <?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 = 'DELETE FROM runoob_tbl WHERE runoob_id=3'; mysqli_select_db( $conn, 'RUNOOB' ); 
    $retval = mysqli_query( $conn, $sql ); 
    if(! $retval ) 
    {
        die('无法删除数据: ' . mysqli_error($conn)); 
    } 
    echo '数据删除成功!'; 
    mysqli_close($conn); 
    ?>
    MySQL DELETE 子句测试

    MySQL LIKE 子句

    • 我们知道在 MySQL 中使用 SQL SELECT 命令来读取数据, 同时我们可以在 SELECT 语句中使用 WHERE 子句来获取指定的记录。
    • WHERE 子句中可以使用等号 = 来设定获取数据的条件,如 "runoob_author = 'RUNOOB.COM'"。
    • 但是有时候我们需要获取 runoob_author 字段含有 "COM" 字符的所有记录,这时我们就需要在 WHERE 子句中使用 SQL LIKE 子句。
    • SQL LIKE 子句中使用百分号 %字符来表示任意字符,类似于UNIX或正则表达式中的星号 *。
    • 如果没有使用百分号 %, LIKE 子句与等号 = 的效果是一样的。

    语法

    • 以下是 SQL SELECT 语句使用 LIKE 子句从数据表中读取数据的通用语法:
    SELECT field1, field2,...fieldN 
    FROM table_name
    WHERE field1 LIKE condition1 [AND [OR]] filed2 = 'somevalue'
    • 你可以在 WHERE 子句中指定任何条件。
    • 你可以在 WHERE 子句中使用LIKE子句。
    • 你可以使用LIKE子句代替等号 =。
    • LIKE 通常与 % 一同使用,类似于一个元字符的搜索。
    • 你可以使用 AND 或者 OR 指定一个或多个条件。
    • 你可以在 DELETE 或 UPDATE 命令中使用 WHERE...LIKE 子句来指定条件。

    在命令提示符中使用 LIKE 子句

    • 以下我们将在 SQL SELECT 命令中使用 WHERE...LIKE 子句来从MySQL数据表 runoob_tbl 中读取数据。

    实例

    • 以下是我们将 runoob_tbl 表中获取 runoob_author 字段中以 COM 为结尾的的所有记录:

    SQL LIKE 语句:

    mysql> use RUNOOB; 
    Database changed
    mysql> SELECT * from runoob_tbl WHERE runoob_author LIKE '%COM';
    +-----------+---------------+---------------+-----------------+
    | runoob_id | runoob_title | runoob_author | submission_date |
    +-----------+---------------+---------------+-----------------+
    | 3 | 学习 Java | RUNOOB.COM | 2015-05-01 |
    | 4 | 学习 Python | RUNOOB.COM | 2016-03-06 |
    +-----------+---------------+---------------+-----------------+
    2 rows in set (0.01 sec)

    示例

    '%a'   # 以a结尾的数据
    'a%'   # 以a开头的数据
    '%a%'  # 含有a的数据
    '_a_'  # 三位且中间字母是a的
    '_a'   # 两位且结尾字母是a的
    'a_'   # 两位且开头字母是a的
    
    # 查询以 Python 字段开头的信息。
    SELECT * FROM position WHERE name LIKE 'Python%';
    
    # 查询包含 Python 字段的信息。
    SELECT * FROM position WHERE name LIKE '%Python%';
    
    # 查询以 Python 字段结尾的信息。
    SELECT * FROM position WHERE name LIKE '%Python';

    MySQL UNION 操作符

    • 介绍 MySQL UNION 操作符的语法和实例。

    描述

    • MySQL UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中。多个 SELECT 语句会删除重复的数据。

    语法

    • MySQL UNION 操作符语法格式:
    SELECT expression1, expression2, ... expression_n
    FROM tables
    [WHERE conditions]
    UNION [ALL | DISTINCT]
    SELECT expression1, expression2, ... expression_n
    FROM tables
    [WHERE conditions];

    参数

    • expression1, expression2, ... expression_n: 要检索的列。

    • tables: 要检索的数据表。

    • WHERE conditions: 可选, 检索条件。

    • DISTINCT: 可选,删除结果集中重复的数据。默认情况下 UNION 操作符已经删除了重复数据,所以 DISTINCT 修饰符对结果没啥影响。

    • ALL: 可选,返回所有结果集,包含重复数据。

    演示数据库

    • 我们将使用 RUNOOB 样本数据库。
    • 下面是选自 "Websites" 表的数据:
    # mysql> SELECT * FROM Websites;
    +----+--------------+---------------------------+-------+---------+
    | id | name         | url                       | alexa | country |
    +----+--------------+---------------------------+-------+---------+
    | 1  | Google       | https://www.google.cm/    | 1     | USA     |
    | 2  | 淘宝          | https://www.taobao.com/   | 13    | CN      |
    | 3  | 菜鸟教程      | http://www.runoob.com/    | 4689  | CN      |
    | 4  | 微博          | http://weibo.com/         | 20    | CN      |
    | 5  | Facebook     | https://www.facebook.com/ | 3     | USA     |
    | 7  | stackoverflow | http://stackoverflow.com/ |   0 | IND     |
    +----+---------------+---------------------------+-------+--------+
    • 下面是 "apps" APP 的数据:
    # mysql> SELECT * FROM apps;
    +----+------------+-------------------------+---------+
    | id | app_name   | url                     | country |
    +----+------------+-------------------------+---------+
    |  1 | QQ APP     | http://im.qq.com/       | CN      |
    |  2 | 微博 APP | http://weibo.com/       | CN      |
    |  3 | 淘宝 APP | https://www.taobao.com/ | CN      |
    +----+------------+-------------------------+---------+
    3 rows in set (0.00 sec)
    • SQL UNION 实例
      • 下面的 SQL 语句从 "Websites" 和 "apps" 表中选取所有不同的country(只有不同的值):

    实例

    SELECT country FROM Websites
    UNION
    SELECT country FROM apps
    ORDER BY country;
    • 执行以上 SQL 输出结果如下:
    • 注释:UNION 不能用于列出两个表中所有的country。如果一些网站和APP来自同一个国家,每个国家只会列出一次。UNION 只会选取不同的值。请使用 UNION ALL 来选取重复的值!

    SQL UNION ALL 实例

    • 下面的 SQL 语句使用 UNION ALL 从 "Websites" 和 "apps" 表中选取所有的country(也有重复的值):

    实例

    SELECT country FROM Websites
    UNION ALL
    SELECT country FROM apps
    ORDER BY country;
    • 执行以上 SQL 输出结果如下:

    带有 WHERE 的 SQL UNION ALL

    • 下面的 SQL 语句使用 UNION ALL 从 "Websites" 和 "apps" 表中选取所有的中国(CN)的数据(也有重复的值):

    实例

    SELECT country, name FROM Websites
    WHERE country='CN'
    UNION ALL
    SELECT country, app_name FROM apps
    WHERE country='CN'
    ORDER BY country;
    • 执行以上 SQL 输出结果如下:

    谢谢以上内容是对 MySQL 数据库表操作的讲述、后续更新内容从分组开始、详细内容请听下回分解

  • 相关阅读:
    Mysql面对高并发修改的问题处理【2】
    HSF处理流程分析
    com.jcraft.jsch.JSchException: invalid privatekey
    linux常用命令
    VPS教程:VPS主机能PING通但是SSH无法连接
    Windows 和Linux 不同操作系统的VPS有哪些区别,如何选择?
    Windows VPS有哪些?
    VPS教程:搭建个人云笔记服务器
    VPS搭个人网盘,seafile、kodexplorer、h5ai谁更合适?
    VPS教程:搭建个人网盘—seafile
  • 原文地址:https://www.cnblogs.com/yangmaosen/p/12528249.html
Copyright © 2011-2022 走看看