SQL基础入门-条件查询语句

前言

SQL基础入门-条件查询语句_第1张图片

可以关注我的云原生社区:云原生社区
也可以关注我的英语社区:从零开始学英语

一. 创建数据库并写入数据

1.1 创建数据库

MySQL [school]> create database game;
Query OK, 1 row affected (0.01 sec)

MySQL [school]> use game
Database changed
MySQL [game]> 

1.2 创建一个名字为game_characters的表

包含以下字段:

  • "id"字段:用于唯一标识每条记录的ID,采用INT数据类型,并使用PRIMARY KEY约束和AUTO_INCREMENT属性。
  • "name"字段:用于存储游戏人物的姓名,采用VARCHAR(50)数据类型,并设置为NOT NULL。
  • "level"字段:用于存储游戏人物的等级,采用INT数据类型。
  • "class"字段:用于存储游戏人物所属的职业,采用VARCHAR(50)数据类型。
  • "health"字段:用于存储游戏人物的生命值,采用INT数据类型。
  • "mana"字段:用于存储游戏人物的魔法值,采用INT数据类型。
  • "description"字段:用于存储游戏人物的描述信息,采用TEXT数据类型。
MySQL [game]> CREATE TABLE game_characters (
    ->   id INT PRIMARY KEY AUTO_INCREMENT,
    ->   name VARCHAR(50) NOT NULL,
    ->   level INT,
    ->   class VARCHAR(50),
    ->   health INT,
    ->   mana INT,
    ->   description TEXT
    -> );
Query OK, 0 rows affected (0.01 sec)

1.3 插入数据

MySQL [game]> INSERT INTO game_characters (name, level, class, health, mana, description)
    -> VALUES
    ->   ('大乔', 50, '法师', 1000, 800, '大乔是一位强大的法术攻击型角色。'),
    ->   ('小乔', 45, '刺客', 800, 500, '小乔是一位敏捷且擅长暗杀的角色。'),
    ->   ('曹操', 55, '战士', 1200, 200, '曹操是一位勇猛的近战战士。'),
    ->   ('刘备', 50, '勇士', 1100, 300, '刘备是一位正直而有领导力的角色。'),
    ->   ('孙权', 48, '射手', 900, 600, '孙权是一位精通远程射击的角色。');
Query OK, 5 rows affected (0.00 sec)
Records: 5  Duplicates: 0  Warnings: 0

MySQL [game]> select * from game_characters;
+----+--------+-------+--------+--------+------+--------------------------------------------------+
| id | name   | level | class  | health | mana | description                                      |
+----+--------+-------+--------+--------+------+--------------------------------------------------+
|  1 | 大乔   |    50 | 法师   |   1000 |  800 | 大乔是一位强大的法术攻击型角色。                 |
|  2 | 小乔   |    45 | 刺客   |    800 |  500 | 小乔是一位敏捷且擅长暗杀的角色。                 |
|  3 | 曹操   |    55 | 战士   |   1200 |  200 | 曹操是一位勇猛的近战战士。                       |
|  4 | 刘备   |    50 | 勇士   |   1100 |  300 | 刘备是一位正直而有领导力的角色。                 |
|  5 | 孙权   |    48 | 射手   |    900 |  600 | 孙权是一位精通远程射击的角色。                   |
+----+--------+-------+--------+--------+------+--------------------------------------------------+
5 rows in set (0.00 sec)

二. SQL语句的查询

SQL语句的基础条件查询语句:语法:select 字段名1,字段名2 from 表名 [where 条件];

2.1 查询game_characters的name和level字段


MySQL [game]> select name,level from game_characters;
+--------+-------+
| name   | level |
+--------+-------+
| 大乔   |    50 |
| 小乔   |    45 |
| 曹操   |    55 |
| 刘备   |    50 |
| 孙权   |    48 |
+--------+-------+
5 rows in set (0.00 sec

2.2 去重复查询distinct [dɪˈstɪŋkt]

- 在表中再次插入一个level=50的人物

MySQL [game]> INSERT INTO game_characters (name, level, class, health, mana, description) VALUES ('嫦娥', 50, '法师', 800, 1200, '嫦娥是一位神秘的法术师。');;
Query OK, 1 row affected (0.01 sec)

MySQL [game]> select name,level from game_characters;
+--------+-------+
| name   | level |
+--------+-------+
| 大乔   |    50 |
| 小乔   |    45 |
| 曹操   |    55 |
| 刘备   |    50 |
| 孙权   |    48 |
| 嫦娥   |    50 |
+--------+-------+
6 rows in set (0.00 sec)

- 对level进行去重

MySQL [game]> select distinct level from game_characters;
+-------+
| level |
+-------+
|    50 |
|    45 |
|    55 |
|    48 |
+-------+
4 rows in set (0.00 sec)

MySQL [game]> 

distinct 对多个字段没有去重功能,只能对一个字段,如果要对多个字段去重,指的是对多个字段的组合体去重。 也就是 查看两个字段,两个字段都要重复的才会去掉,看两个字段,但只重复一个的不会去重

2.3 使用and和or进行多条件查询

MySQL [game]> select * from game_characters;
+----+--------+-------+--------+--------+------+--------------------------------------------------+
| id | name   | level | class  | health | mana | description                                      |
+----+--------+-------+--------+--------+------+--------------------------------------------------+
|  1 | 大乔   |    50 | 法师   |   1000 |  800 | 大乔是一位强大的法术攻击型角色。                 |
|  2 | 小乔   |    45 | 刺客   |    800 |  500 | 小乔是一位敏捷且擅长暗杀的角色。                 |
|  3 | 曹操   |    55 | 战士   |   1200 |  200 | 曹操是一位勇猛的近战战士。                       |
|  4 | 刘备   |    50 | 勇士   |   1100 |  300 | 刘备是一位正直而有领导力的角色。                 |
|  5 | 孙权   |    48 | 射手   |    900 |  600 | 孙权是一位精通远程射击的角色。                   |
|  6 | 嫦娥   |    50 | 法师   |    800 | 1200 | 嫦娥是一位神秘的法术师。                         |
+----+--------+-------+--------+--------+------+--------------------------------------------------+

  • 查询等级大于等于50且职业为法师的人物:
MySQL [game]> select * from game_characters where level >= 50 and class ='法师';
+----+--------+-------+--------+--------+------+--------------------------------------------------+
| id | name   | level | class  | health | mana | description                                      |
+----+--------+-------+--------+--------+------+--------------------------------------------------+
|  1 | 大乔   |    50 | 法师   |   1000 |  800 | 大乔是一位强大的法术攻击型角色。                 |
|  6 | 嫦娥   |    50 | 法师   |    800 | 1200 | 嫦娥是一位神秘的法术师。                         |
+----+--------+-------+--------+--------+------+--------------------------------------------------+
2 rows in set (0.00 sec)

MySQL [game]> 

  1. 查询生命值小于500或者法力值大于1000的人物:
MySQL [game]> select * from game_characters where health < 500 or mana >1000 ;
+----+--------+-------+--------+--------+------+--------------------------------------+
| id | name   | level | class  | health | mana | description                          |
+----+--------+-------+--------+--------+------+--------------------------------------+
|  6 | 嫦娥   |    50 | 法师   |    800 | 1200 | 嫦娥是一位神秘的法术师。             |
+----+--------+-------+--------+--------+------+--------------------------------------+
1 row in set (0.00 sec)


  1. 查询等级介于40到60之间,并且职业为战士或法师的人物:
MySQL [game]> select * from game_characters where (level >= 40 and level <= 60) and (class='战士' or class='法师');
+----+--------+-------+--------+--------+------+--------------------------------------------------+
| id | name   | level | class  | health | mana | description                                      |
+----+--------+-------+--------+--------+------+--------------------------------------------------+
|  1 | 大乔   |    50 | 法师   |   1000 |  800 | 大乔是一位强大的法术攻击型角色。                 |
|  3 | 曹操   |    55 | 战士   |   1200 |  200 | 曹操是一位勇猛的近战战士。                       |
|  6 | 嫦娥   |    50 | 法师   |    800 | 1200 | 嫦娥是一位神秘的法术师。                         |
+----+--------+-------+--------+--------+------+--------------------------------------------------+
3 rows in set (0.00 sec)

MySQL [game]> 

2.4 mysql查询排序

语法:select distinct 字段1,字段2 from 表名order by 字段名;
默认为升序 asc ,可以省略不写

当您需要对查询结果进行排序时,可以使用ORDER BY子句来指定排序的字段和排序方式(升序或降序)。

1. 按照等级降序排列人物:

MySQL [game]> select * from game_characters order by level desc;
+----+--------+-------+--------+--------+------+--------------------------------------------------+
| id | name   | level | class  | health | mana | description                                      |
+----+--------+-------+--------+--------+------+--------------------------------------------------+
|  3 | 曹操   |    55 | 战士   |   1200 |  200 | 曹操是一位勇猛的近战战士。                       |
|  1 | 大乔   |    50 | 法师   |   1000 |  800 | 大乔是一位强大的法术攻击型角色。                 |
|  4 | 刘备   |    50 | 勇士   |   1100 |  300 | 刘备是一位正直而有领导力的角色。                 |
|  6 | 嫦娥   |    50 | 法师   |    800 | 1200 | 嫦娥是一位神秘的法术师。                         |
|  5 | 孙权   |    48 | 射手   |    900 |  600 | 孙权是一位精通远程射击的角色。                   |
|  2 | 小乔   |    45 | 刺客   |    800 |  500 | 小乔是一位敏捷且擅长暗杀的角色。                 |
+----+--------+-------+--------+--------+------+--------------------------------------------------+
6 rows in set (0.00 sec)

  1. 按照生命值升序排列人物:
MySQL [game]> select * from game_characters order by health asc;
+----+--------+-------+--------+--------+------+--------------------------------------------------+
| id | name   | level | class  | health | mana | description                                      |
+----+--------+-------+--------+--------+------+--------------------------------------------------+
|  2 | 小乔   |    45 | 刺客   |    800 |  500 | 小乔是一位敏捷且擅长暗杀的角色。                 |
|  6 | 嫦娥   |    50 | 法师   |    800 | 1200 | 嫦娥是一位神秘的法术师。                         |
|  5 | 孙权   |    48 | 射手   |    900 |  600 | 孙权是一位精通远程射击的角色。                   |
|  1 | 大乔   |    50 | 法师   |   1000 |  800 | 大乔是一位强大的法术攻击型角色。                 |
|  4 | 刘备   |    50 | 勇士   |   1100 |  300 | 刘备是一位正直而有领导力的角色。                 |
|  3 | 曹操   |    55 | 战士   |   1200 |  200 | 曹操是一位勇猛的近战战士。                       |
+----+--------+-------+--------+--------+------+--------------------------------------------------+
6 rows in set (0.01 sec)
  1. 先按照health升序排序,再按照level降序排序人物:

这里指的是按照第一个字段health升序,当遇到相同的health值的时候,这个值按照level的降序进行排列。

MySQL [game]> select * from game_characters order by health asc,level desc;
+----+--------+-------+--------+--------+------+--------------------------------------------------+
| id | name   | level | class  | health | mana | description                                      |
+----+--------+-------+--------+--------+------+--------------------------------------------------+
|  6 | 嫦娥   |    50 | 法师   |    800 | 1200 | 嫦娥是一位神秘的法术师。                         |
|  2 | 小乔   |    45 | 刺客   |    800 |  500 | 小乔是一位敏捷且擅长暗杀的角色。                 |
|  5 | 孙权   |    48 | 射手   |    900 |  600 | 孙权是一位精通远程射击的角色。                   |
|  1 | 大乔   |    50 | 法师   |   1000 |  800 | 大乔是一位强大的法术攻击型角色。                 |
|  4 | 刘备   |    50 | 勇士   |   1100 |  300 | 刘备是一位正直而有领导力的角色。                 |
|  3 | 曹操   |    55 | 战士   |   1200 |  200 | 曹操是一位勇猛的近战战士。                       |
+----+--------+-------+--------+--------+------+------------------------------------

总结

关于sql语句的查询基本上就这么多,后面我们还会介绍更为复杂的sql语句。 你学会了吗。

SQL基础入门-条件查询语句_第2张图片

你可能感兴趣的:(#,5,-,数据库入门到精通篇,sql,数据库,运维)