- 可以用几种方式提供MySQL程序的选项:
1: 在命令行中在程序名后面提供。这对于具体程序调用时使用的选项很普遍。
2: 在程序启动时读取的选项文件中设置。这对于每次程序运行时使用的选项很普遍。
3: 在环境变量中设置。这对每次程序运行时所使用的选项很有用,尽管实际上最常用选项文件。
MySQL程序首先检查环境变量,然后检查选项文件,然后检查命令行来确定给出了哪些选项。如果多次指定一个选项,最后出现的选项占先。这说明环境变量具有最低的优先级,命令行选项具有最高优先级。
可以在选项文件中指定程序选项的默认值来让MySQL程序处理各选项。不需要在每次运行程序时输入选项,但可以根据需要通过命令行选项来覆盖默认值
- 在命令行中指定的程序选项遵从下述规则:
1: 在命令名后面紧跟选项。
2: 选项参量以一个和两个破折号开始,取决于它具有短名还是长名。许多选项有两种形式。例如,-?和--help是指导MySQL程序显示帮助消息的选项的短名和长名。
3: 选项名对大小写敏感。-v和-V均有效,但具有不同的含义。(它们是--verbose和--version选项的短名)。
4: 部分选项在选项名后面紧随选项值。例如,-h localhost或--host=localhost表示客户程序的MySQL服务器主机。选项值可以告诉程序MySQL服务器运行的主机名。
5: 对于带选项值的长选项,通过一个‘=’将选项名和值隔离开来。对于带选项值的短选项,选项值可以紧随选项字母后面,或者二者之间可以用一个空格隔开。(-hlocalhost和-h localhost是等效的)。该规则的例外情况是指定MySQL密码的选项。该选项的形式可以为--password=pass_val或--password。在后一种情况(未给出 密码值),程序将提示输入密码。也可以给出密码选项,短形式为-ppass_val或-p。然而,对于短形式,如果给出了 密码值,必须紧跟在选项后面,中间不能插入空格。这样要求的原因是如果选项后面有空格,程序没有办法来告知后面的参量是 密码值还是其它某种参量。因此,下面两个命令的含义完全不同:
-shell> mysql -ptest
- shell> mysql -p test
第一个命令让mysql使用密码test,但没有指定默认数据库。第二个命令让mysql提示输入 密码并使用test作为默认数据库。
部分选项控制可以开关的行为。例如,mysql客户端支持--column-names选项,确定是否在查询结果开头显示一行栏目名。默认情况,该选项被启用。但是可能在某些情况下你想要禁用它,例如将mysql的输出发送到另一个只希望看到数据而不希望看到开始的标题行的程序中。
- 要想禁用列名,可以使用下面的形式来指定选项:
C:\Users\Administrator>mysql -h localhost -u root --disable-column-names -p123456
C:\Users\Administrator>mysql -h localhost -u root --skip-column-names -p123456
C:\Users\Administrator>mysql -h localhost -u root --column-names=0 -p123456
--disable和--skip前缀与=0后缀的效果相同:它们均关闭选项。
设置后,在进行查询,没有列名
mysql> use test;
Database changed
mysql> select * from a ;
+---+-------+
| 1 | 2,3 |
| 2 | 1,3,4 |
+---+-------+
2 rows in set (0.00 sec)
- 可以用下述方法“启用”选项:
C:\Users\Administrator>mysql -h localhost -u root --column-names -p123456
C:\Users\Administrator>mysql -h localhost -u root --enable-column-names -p123456
C:\Users\Administrator>mysql -h localhost -u root --column-names=1 -p123456
设置后,在进行查询,有列名
mysql> use test;
Database changed
mysql> select * from a;
+-----+-------+
| aId | bId |
+-----+-------+
| 1 | 2,3 |
| 2 | 1,3,4 |
+-----+-------+
2 rows in set (0.00 sec)
如果选项有前缀--loose,如果程序未识别出选项不会提示错误退出,但是会发出一条警告:
C:\Users\Administrator> mysql -h localhost -u root --loose-no-such-option -p123456
Warning: mysql: unknown option '--loose-no-such-option'
当你从安装了多个MySQL的同一台机器上运行程序时,--loose前缀会很有用。当你在一个选项文件中列出选项时,该前缀会特别有用。有可能不能被程序的所有版本识别的选项可以冠以--loose前缀(或在选项文件中用loose)。不能识别选项的程序版本将会发出一条警告并忽视该选项。
对mysql偶尔有用的另一个选项是-e或--execute选项,可用来将SQL语句传递给服务器。该语句必须用引号引起来(单引号或双引号)。(然而,如果想要在查询中将值引起来,则对于查询应使用双引号,查询中引用的值应使用单引号)。当使用该选项时,语句被执行,然后mysql立即退出命令外壳。
例如,你可以用下面的命令获得用户账户列表:
C:\Users\Administrator> mysql -h localhost -u root -e "SELECT User, Host FROM User" mysql -p123456
+------+-----------+
| User | Host |
+------+-----------+
| root | % |
| root | localhost |
+------+-----------+
请注意mysql数据库名作为一个独立的参量传递。然而,相同的查询可能已经使用
mysql -h localhost -u root -e "SELECT User, Host FROM mysql.User" -p123456
从外壳中执行。
- 可以按这种方式传递多个SQL语句,用分号隔开:
C:\Users\Administrator>mysql -h localhost -u root -e "SELECT User, Host FROM mysql.User;SELECT * FROM TEST.A" -p123456
+------+-----------+
| User | Host |
+------+-----------+
| root | % |
| root | localhost |
+------+-----------+
+-----+-------+
| aId | bId |
+-----+-------+
| 1 | 2,3 |
| 2 | 1,3,4 |
- 请注意长形式(--execute)后面必须紧跟一个等号(=)。
-e选项也可以以类似方式用来将命令传递给MySQL簇的ndb_mgm管理客户端。