MySQL教程之:输入查询

如上一节所述,确保您已连接到服务器。这样做本身不会选择任何要使用的数据库,但没关系。在这一点上,了解一下如何发出查询比直接创建表、加载数据和从中检索数据更重要。本节介绍输入查询的基本原则,使用几个查询,您可以尝试熟悉mysql的工作原理。

这是一个简单的查询,要求服务器告诉您它的版本号和当前日期。在mysql>提示符下输入它,然后按Enter:

sql 复制代码
mysql> SELECT VERSION(), CURRENT_DATE;
+-----------+--------------+
| VERSION() | CURRENT_DATE |
+-----------+--------------+
| 8.4.0-tr  | 2024-01-25   |
+-----------+--------------+
1 row in set (0.00 sec)

mysql>

这个查询说明了关于mysql的一些事情:

  • 查询通常由一个SQL语句后跟一个分号组成。(也有一些例外情况可以省略分号。前面提到的QUIT就是其中之一。我们稍后会讨论其他问题。)

  • 当您发出查询时,mysql将其发送到服务器执行并显示结果,然后打印另一个mysql>提示以指示它已准备好进行另一个查询。

  • mysql以表格形式显示查询输出(行和列)。第一行包含列的标签。下面的行是查询结果。通常,列标签是您从数据库表中拉取数据的列的名称。如果您检索的是表达式而不是表列的值(如刚刚显示的示例),mysql使用表达式本身标记列。

  • mysql显示了返回了多少行以及执行查询花费了多长时间,这让您对服务器性能有了一个大致的了解。这些值不精确,因为它们代表的是挂钟时间(不是CPU或机器时间),也因为它们受到服务器负载和网络延时等因素的影响。(为简洁起见,"设置中的行"行有时不会在本章剩余的示例中显示。)

关键字可以在任何字母大小写中输入。以下查询是等效的:

sql 复制代码
mysql> SELECT VERSION(), CURRENT_DATE;
mysql> select version(), current_date;
mysql> SeLeCt vErSiOn(), current_DATE;

这是另一个查询。它演示了您可以使用mysql作为简单的计算器:

sql 复制代码
mysql> SELECT SIN(PI()/4), (4+1)*5;
+------------------+---------+
| SIN(PI()/4)      | (4+1)*5 |
+------------------+---------+
| 0.70710678118655 |      25 |
+------------------+---------+
1 row in set (0.02 sec)

到目前为止,显示的查询都是相对较短的单行语句。您甚至可以在一行中输入多个语句。只需用分号结束每个语句:

sql 复制代码
mysql> SELECT VERSION(); SELECT NOW();
+-----------+
| VERSION() |
+-----------+
| 8.4.0-tr  |
+-----------+
1 row in set (0.00 sec)

+---------------------+
| NOW()               |
+---------------------+
| 2024-01-25 18:33:04 |
+---------------------+
1 row in set (0.00 sec)

一个查询不需要在一行给出全部,所以需要几行的冗长查询不是问题。mysql通过查找终止分号来确定语句的结尾,而不是查找输入行的结尾。(换句话说,mysql接受自由格式的输入:它收集输入行,但在看到分号之前不会执行它们。)

这是一个简单的多行语句:

sql 复制代码
mysql> SELECT
    -> USER()
    -> ,
    -> CURRENT_DATE;
+---------------+--------------+
| USER()        | CURRENT_DATE |
+---------------+--------------+
| jon@localhost | 2018-08-24   |
+---------------+--------------+

在这个例子中,注意在你输入多行查询的第一行后,提示是如何从mysql>变为->的。这就是mysql如何表示它还没有看到一个完整的语句,正在等待其余的。提示是你的朋友,因为它提供了有价值的反馈。如果你使用那个反馈,你可以随时意识到mysql在等待什么。

如果您决定不执行正在输入的查询,请键入\c取消它:

sql 复制代码
mysql> SELECT
    -> USER()
    -> \c
mysql>

这里也注意到提示。在您键入\c后,它会切换回mysql>,提供反馈以指示mysql已准备好进行新查询。下表显示了您可能看到的每个提示,并总结了它们对mysql所处状态的含义。

提示 含义
mysql> 准备好新查询
-> 等待多行查询的下一行
'> 等待下一行,等待完成以单引号开头的字符串('
"> 等待下一行,等待完成以双引号开头的字符串("
```>`` 等待下一行,等待完成以反引号开头的标识符(`````)
/*> 等待下一行,等待完成以/*

当您打算对单行发出查询,但忘记了终止分号时,多行语句通常会意外出现。在这种情况下,mysql会等待更多输入:

sql 复制代码
mysql> SELECT USER()
    ->

如果这种情况发生在你身上(你认为你输入了一个语句,但唯一的响应是->提示符),很可能mysql正在等待分号。如果你没有注意到提示符告诉你什么,你可能会在那里坐一会儿才意识到你需要做什么。输入一个分号来完成语句,mysql执行它:

sql 复制代码
mysql> SELECT USER()
    -> ;
+---------------+
| USER()        |
+---------------+
| jon@localhost |
+---------------+

字符串收集过程中会出现'>和">提示符(表示MySQL正在等待字符串完成的另一种方式)。MySQL,您可以编写由'或"字符包围的字符串(例如,'hello'或"goodbye"),mysql允许您输入跨越多行的字符串。当您看到'>或">提示符时,表示您输入了包含以'或"

sql 复制代码
mysql> SELECT * FROM my_table WHERE name = 'Smith AND age < 30;
    '>

如果您输入这个SELECT语句,然后按Enter并等待结果,什么也不会发生。与其想知道为什么这个查询需要这么长时间,不如注意'>提示符提供的线索。它告诉你mysql期望看到一个未终止字符串的其余部分。(你看到语句中的错误了吗?字符串'Smith缺少第二个单引号。)

在这一点上,你会怎么做?最简单的事情是取消查询。但是,在这种情况下,您不能只键入\c,因为mysql将其解释为它正在收集的字符串的一部分。相反,输入结束引号字符(这样mysql就知道您已经完成了字符串),然后键入\c:

sql 复制代码
mysql> SELECT * FROM my_table WHERE name = 'Smith AND age < 30;
    '> '\c
mysql>

提示变回mysql>,表示mysql已准备好进行新的查询。

'```>``提示符类似于'>">提示符,但表示您已经开始但尚未完成反引号标识符。

了解'>、">和`>提示的含义非常重要,因为如果您错误地输入了未终止的字符串,您键入的任何其他行似乎都会被mysql忽略------包括包含QUIT的行。这可能非常令人困惑,尤其是如果您不知道在取消当前查询之前需要提供终止引号。

从这一点开始,多行语句在没有辅助(->或其他)提示的情况下编写,以便更轻松地复制和粘贴语句以供自己尝试。

相关推荐
@逆风微笑代码狗3 分钟前
144.《在 macOS 上安装 Redis》
数据库·redis·macos
大霸王龙3 分钟前
Apache AGE:基于PostgreSQL的图数据库深度解析
数据库·postgresql·apache
前端 贾公子40 分钟前
MySQL数据库基础 === 多表查询
数据库
大雄野比1 小时前
Mysql连接报错排查解决记录
数据库·mysql·adb
Run Out Of Brain1 小时前
MySQL教程之:批量使用mysql
数据库·mysql
BabyFish131 小时前
MySQL数据导出导入
android·mysql·adb
Minxinbb1 小时前
MySQL主从:如何处理“Got Fatal Error 1236”或 MY-013114 错误(percona译文)
数据库·mysql·dba
loveLifeLoveCoding1 小时前
springboot 默认的 mysql 驱动版本
java·spring boot·mysql
人总该做点什么1 小时前
【数据库】三、SQL语言
数据库·sql
HelloZheQ1 小时前
探索 Oracle 数据库:核心概念与实践指南
数据库·oracle