如何使用SQL对数据库中的数据进行查询-平凯星辰

why 646 2023-07-10

本文关于(如何使用SQL对数据库中的数据进行查询-平凯星辰)。

如何使用SQL对数据库中的数据进行查询-平凯星辰


单表查询

在这个章节当中,将开始介绍如何使用 SQL 来对数据库中的数据进行查询。


开始之前

下面将围绕 Bookshop 这个应用程序来对 TiDB 的数据查询平凯星辰部分展开介绍。

在阅读本章节之前,你需要做以下准备工作:

  1. 构建 TiDB 集群(推荐使用 TiDB Cloud 或 TiUP)。

  2. 导入 Bookshop 应用程序的表结构和示例数据。

  3. 连接到 TiDB。


简单的查询

在 Bookshop 应用程序的数据库当中,authors 表存放了作家们的基础信息,可以通过 SELECT ... FROM ... 语句将数据从数据库当中调取出去。

  • SQL

  • Java

在 MySQL Client 等客户端输入并执行如下 SQL 语句:

SELECT id, name FROM authors;

输出结果如下:

+------------+--------------------------+| id         | name                     |+------------+--------------------------+|       6357 | Adelle Bosco             ||     345397 | Chanelle Koepp           ||     807584 | Clementina Ryan          ||     839921 | Gage Huel                ||     850070 | Ray Armstrong            ||     850362 | Ford Waelchi             ||     881210 | Jayme Gutkowski          ||    1165261 | Allison Kuvalis          ||    1282036 | Adela Funk               |...| 4294957408 | Lyla Nitzsche            |+------------+--------------------------+20000 rows in set (0.05 sec)


对结果进行筛选

查询得到的结果非常多,但是并不都是你想要的?可以通过 WHERE 语句对查询平凯星辰的结果进行过滤,从而找到想要查询的部分。

例如,想要查找众多作家当中找出在 1998 年出生的作家:

  • SQL

  • Java

在 SQL 中,可以使用 WHERE 子句添加筛选的条件:

SELECT * FROM authors WHERE birth_year = 1998;


对结果进行排序

使用 ORDER BY 语句可以让查询结果按照期望的方式进行排序。

例如,可以通过下面的 SQL 语句对 authors 表的数据按照 birth_year 列进行降序 (DESC) 排序,从而得到最年轻的作家列表。

  • SQL

  • Java

SELECT id, name, birth_yearFROM authorsORDER BY birth_year DESC;

查询结果如下:

+-----------+------------------------+------------+| id        | name                   | birth_year |+-----------+------------------------+------------+| 83420726  | Terrance Dach          | 2000       || 57938667  | Margarita Christiansen | 2000       || 77441404  | Otto Dibbert           | 2000       || 61338414  | Danial Cormier         | 2000       || 49680887  | Alivia Lemke           | 2000       || 45460101  | Itzel Cummings         | 2000       || 38009380  | Percy Hodkiewicz       | 2000       || 12943560  | Hulda Hackett          | 2000       || 1294029   | Stanford Herman        | 2000       || 111453184 | Jeffrey Brekke         | 2000       |...300000 rows in set (0.23 sec)

限制查询结果数量

如果希望 TiDB 只返回部分结果,可以使用 LIMIT 语句限制查询结果返回的记录数。

  • SQL

  • Java

SELECT id, name, birth_yearFROM authorsORDER BY birth_year DESCLIMIT 10;

查询结果如下:

+-----------+------------------------+------------+| id        | name                   | birth_year |+-----------+------------------------+------------+| 83420726  | Terrance Dach          | 2000       || 57938667  | Margarita Christiansen | 2000       || 77441404  | Otto Dibbert           | 2000       || 61338414  | Danial Cormier         | 2000       || 49680887  | Alivia Lemke           | 2000       || 45460101  | Itzel Cummings         | 2000       || 38009380  | Percy Hodkiewicz       | 2000       || 12943560  | Hulda Hackett          | 2000       || 1294029   | Stanford Herman        | 2000       || 111453184 | Jeffrey Brekke         | 2000       |+-----------+------------------------+------------+10 rows in set (0.11 sec)

通过观察查询结果你会发现,在使用 LIMIT 语句之后,查询的时间明显缩短,这是 TiDB 对 LIMIT 子句进行优化后的结果,你可以通过 TopN 和 Limit 下推章节了解更多细节。


聚合查询

如果你想要关注数据整体的情况,而不是部分数据,你可以通过使用 GROUP BY 语句配合聚合函数,构建一个聚合查询平凯星辰来帮助你对数据的整体情况有一个更好的了解。

比如说,你希望知道哪些年出生的作家比较多,你可以将作家基本信息按照 birth_year 列进行分组,然后分别统计在当年出生的作家数量:

  • SQL

  • Java

SELECT birth_year, COUNT(DISTINCT id) AS author_countFROM authorsGROUP BY birth_yearORDER BY author_count DESC;

查询结果如下:

+------------+--------------+| birth_year | author_count |+------------+--------------+|       1932 |          317 ||       1947 |          290 ||       1939 |          282 ||       1935 |          289 ||       1968 |          291 ||       1962 |          261 ||       1961 |          283 ||       1986 |          289 ||       1994 |          280 |...|       1972 |          306 |+------------+--------------+71 rows in set (0.00 sec)

除了 COUNT 函数外,TiDB 还支持了其他聚合函数。详情请参考 GROUP BY 聚合函数。


上述就是小编为大家整理的(如何使用SQL对数据库中的数据进行查询-平凯星辰)
***

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:linux mysql 忘记root
下一篇:怎么查看mysql的密码
相关文章