没有合适的资源?快使用搜索试试~ 我知道了~
MySQL使用教程,初学者可以过来参考参考
资源推荐
资源详情
资源评论
本章通过演示如何使用 mysql 客户程序创造和使用一个简单的数据库,提供一个
MySQL 的入门教程。mysql(有时称为“终端监视器”或只是“监视”)是一个交互式程序,
允许你连接一个 MySQL 服务器,运行查询并察看结果。mysql 可以用于批模式:你预
先把查询放在一个文件中,然后告诉 mysql 执行文件的内容。本章将介绍使用 mysql
的两个方法。
要想查看由 mysql 提供的选择项目表,可以用--help 选项来调用:
shell> mysql --help
本章假定 mysql 已经被安装在你的机器上,并且有一个 MySQL 服务器可以连接。否
则,请联络 MySQL 管理员。(如果
你
是管理员,则需要查阅本手册的其它章节,例如
第 5 章:
数据库管理
。)
本章描述建立和使用一个数据库的全过程。如果你仅仅对访问一个已经存在的数据库
感兴趣,可以跳过描述怎样创建数据库及它所包含的表的章节。
由于本章是一个教程,省略了许多细节。关于这里所涉及的主题的详细信息,请查阅
本手册的相关章节。
3.1. 连接与断开服务器
为了连接服务器,当调用 mysql 时,通常需要提供一个 MySQL 用户名并且很可能需要
一个 密码。如果服务器运行在登录服务器之外的其它机器上,还需要指定主机名。联系管
理员以找出进行连接所使用的参数 (即,连接的主机、用户名和使用的密码)。知道正确的
参数后,可以按照以下方式进行连接:
shell> mysql -h host -u user -p
Enter password: ********
host 和 user 分别代表 MySQL 服务器运行的主机名和 MySQL 账户用户名。设置时替
换为正确的值。******** 代表你的密码;当 mysql 显示 Enter password:提示时输入它。
如果有效,你应该看见 mysql>提示符后的一些介绍信息:
shell> 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: 5.1.2-alpha-standard
Type 'help;' or '¥h' for help. Type '¥c' to clear the buffer.
mysql>
mysql> 提示符告诉你 mysql 准备为你输入命令。
一些 MySQL 安装允许用户以匿名(未命名)用户连接到本地主机上运行的服务器。如果
你的机器是这种情况,你应该能不带任何选项地调用 mysql 与该服务器连接:
shell> mysql
成功地连接后,可以在 mysql>提示下输入 QUIT (或¥q)随时退出:
mysql> QUIT
Bye
在 Unix 中,也可以按 control-D 键断开服务器。
在下列章节的大多数例子都假设你连接到了服务器。由 mysql>提示指明。
3.2. 输入查询
确保你连接上了服务器,如在先前的章节讨论的。连接上服务器并布代表选择了任何
数据库,但这样就可以了。知道关于如何查询的基本知识,比马上跳至创建表、给他们
装载数据并且从他们检索数据更重要。本节描述输入命令的基本原则,使用几个查询,
你能尝试了解 mysql 是如何工作的。
这是一个简单的命令,要求服务器告诉它的版本号和当前日期。在 mysql>提示输入如
下命令并按回车键:
mysql> SELECT VERSION(), CURRENT_DATE;
+-----------------+--------------+
| VERSION() | CURRENT_DATE |
+-----------------+--------------+
| 5.1.2-alpha-log | 2005-10-11 |
+-----------------+--------------+
1 row in set (0.01 sec)
mysql>
这询问说明 mysql 的几个方面:
· 一个命令通常由 SQL 语句组成,随后跟着一个分号。(有一些例外不需要分号。
早先提到的 QUIT 是一个例子。后面我们将看到其它的例子。)
· 当发出一个命令时,mysql 将它发送给服务器并显示执行结果,然后显示另一
个 mysql>显示它准备好接受其它命令。
· mysql 用表格(行和列)方式显示查询输出。第一行包含列的标签,随后的行是查
询结果。通常,列标签是你取自数据库表的列的名字。如果你正在检索一个表达式而
非表列的值(如刚才的例子),mysql 用表达式本身标记列。
· 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() |
+-----------------+
| 5.1.2-alpha-log |
+-----------------+
1 row in set (0.00 sec)
+---------------------+
| NOW() |
+---------------------+
| 2005-10-11 15:15:00 |
+---------------------+
1 row in set (0.00 sec)
不必全在一个行内给出一个命令,较长命令可以输入到多个行中。mysql 通过寻找终
止分号而不是输入行的结束来决定语句在哪儿结束。(换句话说,mysql 接受自由格式
的输入:它收集输入行但直到看见分号才执行。)
这里是一个简单的多行语句的例子:
mysql> SELECT
-> USER()
-> ,
-> CURRENT_DATE;
+---------------+--------------+
| USER() | CURRENT_DATE |
+---------------+--------------+
| jon@localhost | 2005-10-11 |
+---------------+--------------+
在这个例子中,在输入多行查询的第一行后,要注意提示符如何从 mysql>变为->,这
正是 mysql 如何指出它没见到完整的语句并且正在等待剩余的部分。提示符是你的
朋友,因为它提供有价值的反馈,如果使用该反馈,将总是知道 mysql 正在等待什么。
如果你决定不想执行正在输入过程中的一个命令,输入¥c 取消它:
mysql> SELECT
-> USER()
-> ¥c
mysql>
这里也要注意提示符,在你输入¥c 以后,它切换回到 mysql>,提供反馈以表明
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 语句,然后按 Enter(回车)键并等待结果,什么都没有出现。不
要惊讶,“为什么该查询这么长呢?”,注意">提示符提供的线索。它告诉你 mysql 期
望见到一个未终止字符串的余下部分。(你看见语句中的错误吗?字符串"Smith 丢掉
了第二个引号。)
走到这一步,你该做什么?最简单的是取消命令。然而,在这种情况下,你不能只是输
入¥c,因为 mysql 作为它正在收集的字符串的一部分来解释它!相反,应输入关闭的
引号字符(这样 mysql 知道你完成了字符串),然后输入¥c:
mysql> SELECT * FROM my_table WHERE name = 'Smith AND age < 30;
剩余47页未读,继续阅读
资源评论
u010703578
- 粉丝: 1
- 资源: 16
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功