专栏首页IT 茂茂MySQL 【教程二】

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(默认)

  • 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(默认)

  • 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(默认)

  • 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 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 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 数据库表操作的讲述、后续更新内容从分组开始、详细内容请听下回分解

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Docker Compose 项目打包部署

    参考官方:https://docs.docker.com/compose/compose-file/

    IT茂茂
  • Python 【基础常识概念】

    下面再来看一个例子,例3中同一类型下的a和b的(a==b)都是为True,而(a is b)则不然。

    IT茂茂
  • Python 三程三器的那些事

        1.定义:把一个函数名当做实参传给另一个函数     2.返回值中包含函数名     3.下面使用高阶函数虽然可以实现装饰器的一些功能,但是违反了装饰器...

    IT茂茂
  • MySQL见闻录 - 入门之旅

    相比于5代版本,这款跨越6、7代版本的8代版本有许多的好评,当然我也没体验过5代版本,反正要用就用最新的嘛。

    看、未来
  • VALSE 2019 Call for Poster/Spotlight

    Poster环节是VALSE年度大会的重要内容之一,往届大会已有百篇以上论文报名进行Poster展示。VALSE2019将在往届经验教训的基础上,进一步强化该环...

    SIGAI学习与实践平台
  • 腾讯企点QTrade“现券台账”:支持恒生、衡泰模板快速导出

    如何实现从在线交易沟通、到交易信息的汇总和处理、再到机构内部协同工作流程的智能化,来帮助交易员更“聪明”地交易? 腾讯企点QTrade(下称“QTrade”)...

    腾讯企点
  • 特征工程 vs. 特征提取:比赛开始!

    用户1737318
  • FFT(快速傅里叶变换)示例

    用户6021899
  • JDBC 通过Statement 执行更新操作(3)

    桑鱼
  • AI 人才遭疯抢,Google 为 22 岁印度毕业生开出 1000w+ 年薪

    他就是仅有 22 岁的 Aditya Paliwal。2013 年到 2018 年,Aditya Paliwal 参加了为期五年的计算机综合 M.Tech 双学...

    IT派

扫码关注云+社区

领取腾讯云代金券