8 指定程序选项

作者: 笑Skr人啊 | 来源:发表于2017-04-12 17:38 被阅读0次
  • 可以用几种方式提供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管理客户端。

相关文章

  • 8 指定程序选项

    可以用几种方式提供MySQL程序的选项:1: 在命令行中在程序名后面提供。这对于具体程序调用时使用的选项很普遍。2...

  • 使用选项文件

    使用选项文件 大部分MySql程序可以从选项文件中读取启动选项,这些选项文件提供了一个便利的途径来指定常用的选项,...

  • 9 使用选项文件

    MySQL程序可以从选项文件(有时也称为配置文件)读取启动选项。选项文件提供了一种很方便的方式来指定常用的选项,因...

  • Node性能分析和排查

    概要 本文主要简述通过V8自带的程序启动选项进行Node性能测试 V8程序启动选项: max-stack-size...

  • gcc命令

    语法 gcc(选项)(参数) 选项 -o:指定生成的输出文件;-On:n为数字1~3,使用编译优化级别n编译程序;...

  • 2018-09-09

    1、create table选项1、指定列选项:default、comment2、指定表选项:engine、aut...

  • iOS prefs

    在iOS应用程序中打开设备设置界面及其中某指定的选项界面[[UIApplicationsharedApplicat...

  • 2020-10-19

    在【型腔铣】加工操作里〖几何体〗选项卡里有:指定部件、指定毛坯、指定检查、指定切削区域和 指定修剪边界五个选项。跟...

  • 04_01_Linux用户管理命令详解04_02_权限及权限管理

    0401用户管理命令详解 添加用户命令:useradd [选项] 用户名 选项: -u 指定UID -g 指定...

  • iOS 各种权限判断及设置跳转

    iOS8之后用一下方法跳转到设置界面 补充资料: 在iOS应用程序中打开设备设置界面及其中某指定的选项界面 一些其...

网友评论

    本文标题:8 指定程序选项

    本文链接:https://www.haomeiwen.com/subject/ztgmattx.html