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 "数据表创建成功\n"; 
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 "数据表删除成功\n"; 
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 "数据插入成功\n"; 
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 数据库表操作的讲述、后续更新内容从分组开始、详细内容请听下回分解

 

posted @ 2020-03-20 17:45  茂茂er  阅读(233)  评论(0编辑  收藏  举报