MySQL学习——连接服务器和输入查询

MySQL是一个流行的关系型数据库管理系统(RDBMS),由瑞典的MySQL AB公司开发,后来被Oracle公司收购。它使用SQL(结构化查询语言)作为访问和操作数据库的标准语言。

要查看 mysql 客户端程序提供的选项列表,可以使用 --help 选项来调用它。mysql 客户端是一个交互式的程序,允许连接到 MySQL 服务器、运行查询并查看结果。同时,mysql 也支持批处理模式,可以将查询预先放置在一个文件中,然后告诉 mysql 执行该文件的内容。

$> mysql --help

1 连接到服务器

为了连接到MySQL服务器,通常需要在调用mysql时提供一个MySQL用户名,并且很可能还需要一个密码。如果服务器运行在你登录的机器以外的其他机器上,你还必须指定一个主机名。并与你的管理员联系,以了解你应该使用什么连接参数进行连接(即应该使用哪个主机、用户名和密码)。一旦你知道了正确的参数,你就应该能够像这样连接:

$> mysql -h host -u user -p

Enter password: ********

在连接到MySQL服务器时,host 代表MySQL服务器运行的主机名,而 user 是你的MySQL账户的用户名。你需要根据你的具体设置替换为适当的值。******** 代表你的密码;当 mysql 显示 Enter password: 提示时,你需要输入它。

如果连接成功,你应该会看到一些介绍性的信息,随后出现一个 mysql> 提示符

$> mysql -h host -u user -p
Enter password: ********
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 25338 to server version: 8.4.0-standard

Type 'help;' or '\h' for help. Type '\c' to clear the buffer.

mysql>

mysql> 提示符表示 mysql 已经准备好让你输入SQL语句了。

如果你正在MySQL服务器运行的同一台机器上登录,你可以省略主机名,并简单地使用以下命令:

$> mysql -u user -p

如果在尝试登录时收到类似"ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)"的错误消息,这意味着MySQL服务器守护进程(Unix系统)或服务(Windows系统)没有运行。

某些MySQL安装允许用户作为匿名(未命名)用户连接到在本地主机上运行的服务器。如果你的机器上也是这种情况,那么你应该能够通过不带任何选项地调用mysql来连接到该服务器:

$> mysql

2 与服务器断开连接

成功连接后,你可以在mysql>提示符下随时键入QUIT(或\q)来断开连接:

mysql> QUIT

Bye

在Unix系统上,你还可以通过按Control+D来断开连接。

以下内容中的大多数示例都假设你已经连接到了服务器。它们通过mysql>提示符来表示这一点。

当你看到mysql>提示符时,这意味着你已经成功登录到MySQL服务器,并且可以开始输入SQL命令了。在这个提示符下,你可以执行各种数据库操作,如表的创建、数据的查询和修改等。

3 输入 查询

确保你已经按照上面的说明连接到了服务器。这样做本身并不会选择任何数据库来操作,但这没关系。在这一点上,了解如何发出查询比直接创建表、向表中加载数据和从表中检索数据更重要。本节描述了输入查询的基本原则,你可以尝试几个查询来熟悉mysql的工作方式。

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

mysql> SELECT VERSION(), CURRENT_DATE;

+-----------+--------------+

| VERSION() | CURRENT_DATE |

+-----------+--------------+

| 5.8.0-m17 | 2015-12-21   |

+-----------+--------------+

1 row in set (0.02 sec)

mysql>

这个查询说明了关于mysql的几件事:

  1. 一个查询通常由一个SQL语句后跟一个分号组成。(有一些例外情况可以省略分号。前面提到的QUIT就是其中之一。我们稍后会讲到其他情况。)
  2. 当你发出查询时,mysql会将其发送到服务器以执行并显示结果,然后打印另一个mysql>提示符,表示它已准备好进行另一个查询。
  3. mysql以表格形式(行和列)显示查询输出。第一行包含列的标签。下面的行是查询结果。通常,列标签是从数据库表中获取的列的名称。如果你正在检索表达式的值而不是表列(如刚才所示的例子),mysql会使用表达式本身为列加标签。
  4. mysql显示了返回了多少行以及查询执行了多长时间,这可以让你大致了解服务器的性能。这些值是不精确的,因为它们表示的是挂钟时间(而不是CPU或机器时间),并且受到服务器负载和网络延迟等因素的影响。(为了简洁起见,在本章的剩余示例中,有时不显示"行集"行。)

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

mysql> SELECT VERSION(), CURRENT_DATE;

mysql> select version(), current_date;

mysql> SeLeCt vErSiOn(), current_DATE;

这是另一个查询示例。它展示了你可以将mysql用作一个简单的计算器:

mysql> SELECT SIN(PI()/4), (4+1)*5;

+------------------+---------+

| SIN(PI()/4)      | (4+1)*5 |

+------------------+---------+

| 0.70710678118655 |      25 |

+------------------+---------+

1 row in set (0.02 sec)

到目前为止,所展示的查询都是相对较短的、单行的语句。你甚至可以在单行上输入多个语句。只需在每个语句的末尾加上分号即可:

mysql> SELECT VERSION(); SELECT NOW();

+-----------+

| VERSION() |

+-----------+

| 8.0.13    |

+-----------+

1 row in set (0.00 sec)



+---------------------+

| NOW()               |

+---------------------+

| 2018-08-24 00:56:40 |

+---------------------+

1 row in set (0.00 sec)

查询不必全部写在单行上,因此需要多行的冗长查询不是问题。mysql通过寻找终止分号来确定你的语句在哪里结束,而不是通过寻找输入行的末尾。(换句话说,mysql接受自由格式的输入:它收集输入行,但在看到分号之前不会执行它们。)

以下是一个简单的多行语句示例:

mysql> SELECT

    -> USER()

    -> ,

    -> CURRENT_DATE;

+---------------+--------------+

| USER()        | CURRENT_DATE |

+---------------+--------------+

| jon@localhost | 2018-08-24   |

+---------------+--------------+

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

如果你决定不想执行你正在输入的查询,可以通过键入\c来取消它:

mysql> SELECT

    -> USER()

    -> \c

mysql>

在这里,同样请注意提示符。在你键入\c之后,它会切换回mysql>,提供反馈来表明mysql已准备好接受新的查询。

下表展示了你可能会看到的每个提示符,并总结了它们关于mysql当前状态的含义。

多行语句通常是由于意外而产生的,当你打算在一行上发出查询,但忘记了终止分号时。在这种情况下,mysql会等待更多的输入:

mysql> SELECT USER()

->

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

mysql> SELECT USER()

    -> ;

+---------------+

| USER()        |

+---------------+

| jon@localhost |

+---------------+

'> 和 "> 提示符在收集字符串期间出现(换句话说,就是 MySQL 正在等待字符串的完成)。在 MySQL 中,你可以使用单引号 ' 或双引号 " 来包围字符串(例如,'hello' 或 "goodbye"),并且 mysql 允许你输入跨多行的字符串。当你看到 '> 或 "> 提示符时,这意味着你已经输入了一行包含以 ' 或 " 引号字符开始的字符串,但尚未输入匹配的引号来终止该字符串。这通常表示你无意中遗漏了一个引号字符。例如:

mysql> SELECT * FROM my_table WHERE name = 'Smith AND age < 30;

    '>

如果你输入了这个 SELECT 语句,然后按下回车并等待结果,但什么反应也没有。这时,与其纳闷为什么这个查询需要这么长时间,不如注意一下 '> 提示符提供的线索。它告诉你 mysql 正在等待一个未终止的字符串的其余部分。(你看到这个语句中的错误了吗?字符串 'Smith 缺少第二个单引号。)

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

mysql> SELECT * FROM my_table WHERE name = 'Smith AND age < 30;

    '> '\c

mysql>

提示符变回mysql>,表明mysql已经准备好接受新的查询。

>提示符与'>和">提示符类似,但它表示你已经开始但尚未完成一个用反引号括起来的标识符。

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

在实际操作中,如果你发现自己陷入了这样的困境,首先应该检查是否遗漏了引号或反引号来正确终止你的输入。一旦你补全了缺失的引号,mysql就会继续处理你的查询,或者你可以使用\c来取消它。

为了避免这种情况,建议在编写查询时保持警惕,确保所有的字符串和标识符都被正确地引用和终止。这样不仅可以避免不必要的混淆和延误,还可以提高你的工作效率和准确性。

注意

从此处开始,多行语句将不再包含次级提示符(如 -> 或其他),以便您更轻松地复制和粘贴这些语句进行尝试。

这意味着,在提供的示例中,您将不会看到在输入多行命令时MySQL通常显示的连续提示符。

相关推荐
shelby_loo23 分钟前
通过 Docker 部署 MySQL 服务器
服务器·mysql·docker
sleP4o6 小时前
Python操作MySQL
开发语言·python·mysql
大熊程序猿6 小时前
python 读取excel数据存储到mysql
数据库·python·mysql
知识分享小能手7 小时前
mysql学习教程,从入门到精通,SQL DISTINCT 子句 (16)
大数据·开发语言·sql·学习·mysql·数据分析·数据库开发
lamb张7 小时前
MySQL锁
数据库·mysql
躺平的花卷8 小时前
Python爬虫案例六:抓取某个地区某月份天气数据并保存到mysql数据库中
数据库·爬虫·python·mysql
飞翔的佩奇10 小时前
xxl-job适配sqlite本地数据库及mysql数据库。可根据配置指定使用哪种数据库。
数据库·spring boot·mysql·sqlite·xxl-job·任务调度
如意机反光镜裸11 小时前
CentOS7安装MySQL教程
数据库·mysql
冰镇毛衣11 小时前
1.4 MySql配置文件
数据库·mysql
计算机学姐12 小时前
基于python+django+vue的影视推荐系统
开发语言·vue.js·后端·python·mysql·django·intellij-idea