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

news/2024/11/28 5:43:39/

前言

在这里插入图片描述

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

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

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: 0MySQL [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语句。 你学会了吗。

在这里插入图片描述


http://www.ppmy.cn/news/446757.html

相关文章

DJ4-1 网络层概述

目录 一、网络层提供的功能 二、路由和转发 三、数据平面和控制平面 四、网络层的服务模型 一、网络层提供的功能 网络层实现主机与主机之间的通信 从发送方主机传输报文段到接收方主机&#xff1a; 发送方主机封装报文段 (segments) 为数据报 (datagrams)接收方主机递交…

使用Apache ShardingSphere简答实现水平分表

1 简介 Apache ShardingSphere 是一款分布式的数据库生态系统&#xff0c; 可以将任意数据库转换为分布式数据库&#xff0c;并通过数据分片、弹性伸缩、加密等能力对原有数据库进行增强。 官方网站 https://shardingsphere.apache.org/document/current/cn/overview/2 创建…

黑莓手机企业激活注意事项和可能问题

手机能否打电话 手机网络模式 电信UIM卡&#xff1a;手机要设置为Global或者EVDO 移动SIM卡&#xff1a;手机j建议设置为GSM/2G 联通UIM卡&#xff1a;手机j建议设置为3G 手机能否上网 浏览器访问www.baidu.com 提示&#xff1a;某些黑莓手机做过企业激活了&#xff0c;前一个公…

武汉移动137和武汉电信189手机业务比较

本人长期使用移动1372XXXX834的号码&#xff0c;以下简称137&#xff0c;现在试用了一下电信1897XXXX137&#xff0c;以下简称189。试用一个月后感受良多&#xff0c;恰逢接触过经营分析及BOSS系统&#xff0c;我来比较一下&#xff0c;都是亲身感受。 一、137原是M-ZONE动感地…

如何将计算机接入互联网络,怎么设置网络-计算机:如何通过无线网络接入技术接入Internet网络...

1.无线网络接入技术 GSM、CDMA、GPRS移动通信接入技术 GSM 是一种起源于欧洲的移动通信技术标准,是第二代移动通信技术。该技术是目前个人通信的一种常见技术代表。GSM数字网具有较强的保密性和抗干扰性,音质清晰,通话稳定,并具备容量大,频率资源利用率高,接口开放,功能…

中国电信5G定制网产品要点

来源&#xff1a;中国电信5G定制网产品手册&#xff08;2020年11月&#xff09; 版本说明&#xff1a; 2021年11月4日初稿。网络能力&#xff08;N&#xff09;产品化比较清晰。边缘智能&#xff08;I&#xff09;、云边协同&#xff08;C&#xff09;、应用随选&#xff08;…

玩转天翼3G:手机4种上网方式

中国电信推出互联网手机&#xff0c;开始了手机互联网时代&#xff0c; 用户可以随时随地的畅游互联网。中国电信互联网手机成功实现“CW”上网方式&#xff0c;有以下几种上网方式&#xff1a;1、手机直接上互联网&#xff1b;2、手机号作为宽带帐号&#xff0c;用 笔记本在WL…

天翼空间---常见问题

天翼空间---常见问题 2010年08月07日 [b]应用问题[/b] 1、在天翼空间下载的应用&#xff0c;能否在PC上使用呢&#xff1f; 天翼空间提供手机和PC两种类型的应用&#xff0c;在应用描述-规格处有相应提示&#xff0c;手机应用不能在PC上使用 2、应用下载后&#xff0c;若换UIM…