前言
可以关注我的云原生社区:云原生社区
也可以关注我的英语社区:从零开始学英语
一. 创建数据库并写入数据
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]>
- 查询生命值小于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)
- 查询等级介于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)
- 按照生命值升序排列人物:
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)
- 先按照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语句。 你学会了吗。