MySQL高阶语句之一

这篇具有很好参考价值的文章主要介绍了MySQL高阶语句之一。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

模版表

一、ORDER BY语法

1.1语法

 1.2升序

 1.3降序

 1.4多高字段排序

二、AND/OR--且/或

2.1AND

2.2OR

2.3嵌套/多条件

 三、distinct 查询不重复记录

3.1语法

四、GROUP  BY语法

4.1语法

 五、限制结果条目(limit)

5.1语法

 5.2实验

五、设置别名(alias----as)

5.1语法

5.2实验

 5.4查询info表的字段数量,以number显示

 5.5 AS 还可以作为连接语句的操作符。 创建t1表,将info表的查询记录全部插入info_bak表

六、通配符

 6.1 %

 6.2 _

七、接下来的内容请看MySQL高阶语句之二

MySQL高阶语句之二



模版表

create table info (id int,name varchar(10) primary key not null ,score decimal(5,2),address varchar(20),hobbid int(5));

insert into ky29 values(1,'liuyi',80,'beijing',2);
insert into ky29 values(2,'wangwu',90,'shengzheng',2);
insert into ky29 values(3,'lisi',60,'shanghai',4);
insert into ky29 values(4,'tianqi',99,'hangzhou',5);
insert into ky29 values(5,'jiaoshou',98,'laowo',3);
insert into ky29 values(6,'hanmeimei',10,'nanjing',3);
insert into ky29 values(7,'lilei',11,'nanjing',5);

select * from info;

MySQL高阶语句之一,mysql,数据库,sql

一、ORDER BY语法

使用 SELECT 语句可以将需要的数据从 MySQL 数据库中查询出来,如果对查询的结果进行排序,可以使用 ORDER BY 语句来对语句实现排序,并最终将排序后的结果返回给用户。这个语句的排序不光可以针对某一个字段,也可以针对多个字段

1.1语法

SELECT column1, column2, ... FROM table_name ORDER BY column1, column2, ... ASC|DESC;

 ASC 是按照升序进行排序的,是默认的排序方式,即 ASC 可以省略。SELECT 语句中如果没有指定具体的排序方式,则默认按 ASC方式进行排序。

DESC 是按降序方式进 行排列。当然 ORDER BY 前面也可以使用 WHERE 子句对查询结果进一步过滤。

 1.2升序

#以score参照,做升序
#不写默认是升序
select id,name,score from info3 order by score;

MySQL高阶语句之一,mysql,数据库,sql

 1.3降序

#以score为对象,做降序
select id,name,score from info3 order by score desc;

MySQL高阶语句之一,mysql,数据库,sql

 1.4多高字段排序

 ORDER BY 语句也可以使用多个字段来进行排序,当排序的第一个字段相同的记录有多条的情况下,这些多条的记录再按照第二个字段进行排序,ORDER BY 后面跟多个字段时,字段之间使用英文逗号隔开,优先级是按先后顺序而定 但order by 之后的第一个参数只有在出现相同值时,第二个字段才有意义

mysql> select  id,name,score,hobbid from info3 order by hobbid desc,id desc;
+------+-----------+-------+--------+
| id   | name      | score | hobbid |
+------+-----------+-------+--------+
|    7 | jixiaoman | 63.00 |      5 |
|    4 | tangsan   | 50.00 |      5 |
|    3 | lisi      | 60.00 |      4 |
|    6 | lilei     | 18.00 |      3 |
|    5 | hanmei    | 10.00 |      3 |
|    2 | wangwu    | 90.00 |      2 |
|    1 | luiyi     | 80.00 |      2 |
+------+-----------+-------+--------+
7 rows in set (0.00 sec)

二、AND/OR--且/或

2.1AND

mysql> select * from info3 where score > 70 and score <= 90;
+------+--------+-------+------------+--------+
| id   | name   | score | address    | hobbid |
+------+--------+-------+------------+--------+
|    1 | luiyi  | 80.00 | beijing    |      2 |
|    2 | wangwu | 90.00 | shengzheng |      2 |
+------+--------+-------+------------+--------+
2 rows in set (0.00 sec)

2.2OR

mysql> select * from info3 where score > 70 or score <= 90;
+------+-----------+-------+------------+--------+
| id   | name      | score | address    | hobbid |
+------+-----------+-------+------------+--------+
|    5 | hanmei    | 10.00 | nanjing    |      3 |
|    7 | jixiaoman | 63.00 | guizhou    |      5 |
|    6 | lilei     | 18.00 | kunshan    |      3 |
|    3 | lisi      | 60.00 | shandong   |      4 |
|    1 | luiyi     | 80.00 | beijing    |      2 |
|    4 | tangsan   | 50.00 | laowo      |      5 |
|    2 | wangwu    | 90.00 | shengzheng |      2 |
+------+-----------+-------+------------+--------+
7 rows in set (0.00 sec)

2.3嵌套/多条件

#嵌套方式,先执行嵌套里面的,在执行外面的。
mysql> select * from info3 where score > 70 or (score >60 and score <90);
+------+-----------+-------+------------+--------+
| id   | name      | score | address    | hobbid |
+------+-----------+-------+------------+--------+
|    7 | jixiaoman | 63.00 | guizhou    |      5 |
|    1 | luiyi     | 80.00 | beijing    |      2 |
|    2 | wangwu    | 90.00 | shengzheng |      2 |
+------+-----------+-------+------------+--------+
3 rows in set (0.00 sec)

 三、distinct 查询不重复记录

3.1语法

select distinct 字段 from 表名﹔
mysql> select distinct hobbid  from  info3;
+--------+
| hobbid |
+--------+
|      3 |
|      5 |
|      4 |
|      2 |
+--------+
4 rows in set (0.00 sec)

四、GROUP  BY语法

通过 SQL 查询出来的结果,还可以对其进行分组,使用 GROUP BY 语句来实现 ,GROUP BY 通常都是结合聚合函数一起使用的,常用的聚合函数包括:计数(COUNT)、 求和(SUM)、求平均数(AVG)、最大值(MAX)、最小值(MIN),GROUP BY 分组的时候可以按一个或多个字段对结果进行分组处理。

4.1语法

SELECT column_name, aggregate_function(column_name)FROM table_name WHERE column_name operator value GROUP BY column_name;

 按hobbid相同的分组,计算相同分数的学生个数(基于name个数进行计数)

mysql>  select count(name),hobbid from info3 group by hobbid;
+-------------+--------+
| count(name) | hobbid |
+-------------+--------+
|           2 |      2 |
|           2 |      3 |
|           1 |      4 |
|           2 |      5 |
+-------------+--------+
4 rows in set (0.00 sec)

结合where语句,筛选分数大于等于70的分组,计算学生个数

mysql> select count(name),hobbid from info3 where score >=70 gr
oup by hobbid;
+-------------+--------+
| count(name) | hobbid |
+-------------+--------+
|           2 |      2 |
+-------------+--------+
1 row in set (0.00 sec)

 结合order by把计算出的学生个数按升序排列

mysql>  select count(name),score,hobbid from info3 where score>=10 group by hobbid order by count(name) asc;
+-------------+-------+--------+
| count(name) | score | hobbid |
+-------------+-------+--------+
|           1 | 60.00 |      4 |
|           2 | 10.00 |      3 |
|           2 | 63.00 |      5 |
|           2 | 80.00 |      2 |
+-------------+-------+--------+
4 rows in set (0.00 sec)

 五、限制结果条目(limit)

limit 限制输出的结果记录

在使用 MySQL SELECT 语句进行查询时,结果集返回的是所有匹配的记录(行)。有时候仅 需要返回第一行或者前几行,这时候就需要用到 LIMIT 子句

LIMIT 的第一个参数是位置偏移量(可选参数),是设置 MySQL 从哪一行开始显示。 如果不设定第一个参数,将会从表中的第一条记录开始显示。需要注意的是,第一条记录的 位置偏移量是 0,第二条是 1,以此类推。第二个参数是设置返回记录行的最大数目。

5.1语法

SELECT column1, column2, ... FROM table_name LIMIT [offset,] number

 5.2实验

查询所有信息显示前4行记录

mysql> select * from info3 limit 4;
+------+-----------+-------+----------+--------+
| id   | name      | score | address  | hobbid |
+------+-----------+-------+----------+--------+
|    5 | hanmei    | 10.00 | nanjing  |      3 |
|    7 | jixiaoman | 63.00 | guizhou  |      5 |
|    6 | lilei     | 18.00 | kunshan  |      3 |
|    3 | lisi      | 60.00 | shandong |      4 |
+------+-----------+-------+----------+--------+
4 rows in set (0.00 sec)

 从第5行开始,往后显示3行内容

mysql> select * from info3 limit 4,3;
+------+---------+-------+------------+--------+
| id   | name    | score | address    | hobbid |
+------+---------+-------+------------+--------+
|    1 | luiyi   | 80.00 | beijing    |      2 |
|    4 | tangsan | 50.00 | laowo      |      5 |
|    2 | wangwu  | 90.00 | shengzheng |      2 |
+------+---------+-------+------------+--------+
3 rows in set (0.00 sec)

 结合order by语句,按id的大小升序排列显示前三行

mysql> select * from info3 order by id limit 3;
+------+--------+-------+------------+--------+
| id   | name   | score | address    | hobbid |
+------+--------+-------+------------+--------+
|    1 | luiyi  | 80.00 | beijing    |      2 |
|    2 | wangwu | 90.00 | shengzheng |      2 |
|    3 | lisi   | 60.00 | shandong   |      4 |
+------+--------+-------+------------+--------+
3 rows in set (0.00 sec)

五、设置别名(alias----as)

在 MySQL 查询时,当表的名字比较长或者表内某些字段比较长时,为了方便书写或者 多次使用相同的表,可以给字段列或表设置别名。使用的时候直接使用别名,简洁明了,增强可读性

5.1语法

#对于列的别名:
SELECT column_name AS alias_name FROM table_name;
#对于表的别名:
SELECT column_name(s) FROM table_name AS alias_name;

在使用 AS 后,可以用 alias_name 代替 table_name,其中 AS 语句是可选的。AS 之后的别名,主要是为表内的列或者表提供临时的名称,在查询过程中使用,库内实际的表名 或字段名是不会被改变的  

5.2实验

mysql> select id as 序号,name as 姓名,score as 成绩 from info3 order by id;
+--------+-----------+--------+
| 序号   | 姓名      | 成绩   |
+--------+-----------+--------+
|      1 | luiyi     |  80.00 |
|      2 | wangwu    |  90.00 |
|      3 | lisi      |  60.00 |
|      4 | tangsan   |  50.00 |
|      5 | hanmei    |  10.00 |
|      6 | lilei     |  18.00 |
|      7 | jixiaoman |  63.00 |
+--------+-----------+--------+
7 rows in set (0.00 sec)

 5.4查询info表的字段数量,以number显示

mysql> select count(*) 姓名 from info3;
+--------+
| 姓名   |
+--------+
|      7 |
+--------+
1 row in set (0.00 sec)

mysql> select count(*) number from info3;
+--------+
| number |
+--------+
|      7 |
+--------+
1 row in set (0.00 sec)

mysql> select count(*) 数量 from info3;
+--------+
| 数量   |
+--------+
|      7 |
+--------+
1 row in set (0.00 sec)

mysql> select count(*) as  数量 from info3;
+--------+
| 数量   |
+--------+
|      7 |
+--------+
1 row in set (0.00 sec)

 5.5 AS 还可以作为连接语句的操作符。 创建t1表,将info表的查询记录全部插入info_bak表

此处AS起到的作用:

1、创建了一个新表t1 并定义表结构,插入表数据(与info表相同)

2、但是”约束“没有被完全”复制“过来 #但是如果原表设置了主键,那么附表的:default字段会默认设置一个0 相似。

mysql> create  table  info_bak (select * from info3);
Query OK, 7 rows affected (0.01 sec)
Records: 7  Duplicates: 0  Warnings: 0

mysql> show  tables;
+----------------+
| Tables_in_text |
+----------------+
| info1          |
| info2          |
| info3          |
| info_bak       |
+----------------+
4 rows in set (0.00 sec)


mysql> desc info_bak;
+---------+--------------+------+-----+---------+-------+
| Field   | Type         | Null | Key | Default | Extra |
+---------+--------------+------+-----+---------+-------+
| id      | int(11)      | YES  |     | NULL    |       |
| name    | varchar(10)  | NO   |     | NULL    |       |
| score   | decimal(5,2) | YES  |     | NULL    |       |
| address | varchar(20)  | YES  |     | NULL    |       |
| hobbid  | int(5)       | YES  |     | NULL    |       |
+---------+--------------+------+-----+---------+-------+
5 rows in set (0.00 sec)



mysql> select * from info_bak;
+------+-----------+-------+------------+--------+
| id   | name      | score | address    | hobbid |
+------+-----------+-------+------------+--------+
|    5 | hanmei    | 10.00 | nanjing    |      3 |
|    7 | jixiaoman | 63.00 | guizhou    |      5 |
|    6 | lilei     | 18.00 | kunshan    |      3 |
|    3 | lisi      | 60.00 | shandong   |      4 |
|    1 | luiyi     | 80.00 | beijing    |      2 |
|    4 | tangsan   | 50.00 | laowo      |      5 |
|    2 | wangwu    | 90.00 | shengzheng |      2 |
+------+-----------+-------+------------+--------+
7 rows in set (0.00 sec)

六、通配符

通配符主要用于替换字符串中的部分字符,通过部分字符的匹配将相关结果查询出来。

通常通配符都是跟 LIKE 一起使用的,并协同 WHERE 子句共同来完成查询任务。常用的通配符有两个,分别是:

%:表示零个、一个或多个字符

_:下划线表示单个字符文章来源地址https://www.toymoban.com/news/detail-600455.html

 6.1 %

mysql> select id,name from info3  where name like 'li%'
    -> ;
+------+-------+
| id   | name  |
+------+-------+
|    6 | lilei |
|    3 | lisi  |
+------+-------+
2 rows in set (0.00 sec)

 6.2 _

mysql> select id,name from info3  where name like 'wang__';
+------+--------+
| id   | name   |
+------+--------+
|    2 | wangwu |
+------+--------+
1 row in set (0.00 sec)

七、接下来的内容请看MySQL高阶语句之二

MySQL高阶语句之二

到了这里,关于MySQL高阶语句之一的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MySQL相关的SQL语句、数据库、数据表、字段、类型

    1、 SQL 语句不区分大小写。 SQL语句 用途 描述 mysql -u root -p 连接 MySQL 在命令行窗口中输入 mysql -u root -p 命令,回车,然后输入 MySQL 密码(不要忘记了密码,找回麻烦),再回车就连接上 MySQL 了。最初都是使用 root 用户登录,工作中不能一直使用 root 用户登录。因为 root 权限太

    2024年02月13日
    浏览(89)
  • MySQL高阶语句之一

    目录 模版表 一、ORDER BY语法 1.1语法  1.2升序  1.3降序  1.4多高字段排序 二、AND/OR--且/或 2.1AND 2.2OR 2.3嵌套/多条件  三、distinct 查询不重复记录 3.1语法 四、GROUP  BY语法 4.1语法  五、限制结果条目(limit) 5.1语法  5.2实验 五、设置别名(alias----as) 5.1语法 5.2实验  5.4查询

    2024年02月16日
    浏览(17)
  • mysql,用sql语句,建立学生-课程数据库基本表

    学生表 学号 姓名 年龄 性别 院系 Student Sno Sname Sage Ssex Sdept 课程表 课程号 课程名 先行课 学分 Course Cno Cname Cpno Ccredit 选课表 学号 课程号 成绩 SC Sno Cno Grade 注意创建表的时候要注意它的字段名,类型,长度,约束条件,取值范围要合适,大小写符号要正确,中文逗号,分号

    2024年02月08日
    浏览(55)
  • MySQL数据库概念、管理以及SQL语句的基本命令操作

    数据(data) 描述事物的符号记录 包括数字,文字、图形、图像、声音、档案记录等 以“记录”形式按统一格式进行存储(记录可以看成一条记录) 表 将不同的记录组织在一起 用来存储具体数据 记录:行 字段(属性):列 以行+列的形式就组成了表(数据存储在表中) 数

    2024年02月08日
    浏览(68)
  • MySQL 数据库实用指南:测试数据准备、SQL语句规范与基本操作

    欢迎来到小K的MySQL专栏,本节将为大家准备MySQL测试数据、以及带来SQL语句规范、数据库的基本操作的详细讲解 要学习SQL查询语句,首先必须解决一个问题,数据问题。为了方便大家学习阅读我的文章,在这里提供了一个test.sql文件 ✨ 登录MySQL,输入 source xxx/test.sql 导入sql文

    2024年02月08日
    浏览(79)
  • MySQL数据库第十一课---------SQl语句的拔高-------水平提升

                                                       个人主页 ::小小页面                   gitee页面 :秦大大                 一个爱分享的小博主  欢迎小可爱们前来借鉴 ______________________________________________________    SQL提高   日期函数     

    2024年02月16日
    浏览(60)
  • MySQL数据库增删改查及聚合查询SQL语句学习汇总

    目录 数据库增删改查SQL语句 MySQL数据库指令 1.查询数据库 2.创建数据库 3.删除数据库 4.选择数据库 创建表table   查看所有表 创建表 查看指定表的结构 删除表 数据库命令进行注释 增删改查(CRUD)详细说明 增加 SQL库提供了关于时间的函数:now()  查询 查询表作列与列之间进

    2024年02月09日
    浏览(81)
  • 基于Linux操作系统中的MySQL数据库SQL语句(三十一)

    MySQL数据库SQL语句 目录 一、SQL语句类型 1、DDL 2、DML 3、DCL 4、DQL 二、数据库操作 1、查看 2、创建 2.1、默认字符集 2.2、指定字符集 3、进入  4、删除 5、更改 6、练习 三、数据表操作 (一)数据类型 1、数值类型 1.1、TINYINT 1.2、SMALLINT 1.3、INT 1.4、BIGINT 1.5、FLOAT(M,D) 2、时间

    2024年02月15日
    浏览(63)
  • MySQL:想实现sql语句进行批量删除数据库或表,而引发的熬夜探究

    因为在自测过程中,创建了很多数据库,一个个手动删除属实有点对不起程序员这个身份,那么有没有简单的sql语句操作来进行批量删除数据库呢?于是便有了本篇文章 上面图片是AI创作,未经允许,不可商用哦! 删库跑路需谨慎, 放弃一切亦不易。 了解到数据库或表的信

    2024年01月16日
    浏览(58)
  • 在IDEA中配置MySQL数据库连接以及在使用mybatis时设置sql语句的代码提示功能

    在IDEA中配置MySQL数据库连接以及在使用mybatis 时设置 sql语句的代码提示功能 一:在IDEA中配置MySQL数据库连接 第一步:在IDEA右侧区域有database选项,点击进去 第二步:database  - data soucre - mysql   第三步:配置连接信息,连接数据库   第四步:显示的数据库以及表的信息  第

    2024年02月14日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包