设为首页 收藏本站
查看: 626|回复: 0

shell提示符mysql提示符 懒人笔记

[复制链接]

尚未签到

发表于 2018-8-25 08:55:54 | 显示全部楼层 |阅读模式
  shell提示符mysql提示符
  shell提示符在.bashrc 中添加以下几行:
  if [ "$TERM" = "linux" ]
  then
  #we're on the system console or maybe telnetting in
  export PS1="\[\e[32;1m\]\u@\H > \[\e[0m\]"
  else
  #we're not on the console, assume an xterm
  export PS1="\[\e]2;\u@\H \w\a\e[32;1m\]>\[\e[0m\] "
  fi
  这个 bash 条件语句将根据当前的终端设置动态设置提示行。为了获得一致性,您一定希望配置您的 ~/.bash_profile,以便它在启动时搜索 (source) 您的 ~/.bashrc。确保您的 ~/.bash_profile 文件中有以下这样一行:
  source ~/.bashrc
  参数变量PS1 PS2
  尽管这很有趣,但在提示行中包含大量静态文本并不是特别有用。大多数定制的提示行包含诸如用户名、工作目录或主机名之类的信息。这些花絮信息可以帮助您在 shell 世界中遨游。例如,下面的提示行将显示您的用户名和主机名:
  $ export PS1="\u@\H > "
  drobbins@freebox >
  这个提示行对于那些以多个不同名称的帐户登录多台机器的人尤为有用,因为它可以提醒您:您目前在哪台机器上操作,拥有什么权限。
  在上面的示例中,我们使用了专用的用反斜杠转义的字符序列,藉此通知 bash 将用户名和主机名插入提示行中,当这些转义字符序列出现在 PS1 变量中时,bash 就会用特定的值替换它们。我们使用了序列 "\u"(表示用户名)和 "\H"(表示主机名的第一部分)。下面是 bash 可识别的全部专用序列的完整列表(您可以在 bash man page 的 "PROMPTING" 部分找到这个列表):
  序列 说明
  \a ASCII 响铃字符(也可以键入 \007)
  \d "Wed Sep 06" 格式的日期
  \e ASCII 转义字符(也可以键入 \033)
  \h 主机名的第一部分(如 "mybox")
  \H 主机的全称(如 "mybox.mydomain.com")
  \j 在此 shell 中通过按 ^Z 挂起的进程数
  \l 此 shell 的终端设备名(如 "ttyp4")
  \n 换行符
  \r 回车符
  \s shell 的名称(如 "bash")
  \t 24 小时制时间(如 "23:01:01")
  \T 12 小时制时间(如 "11:01:01")
  \@ 带有 am/pm 的 12 小时制时间
  \u 用户名
  \v bash 的版本(如 2.04)
  \V Bash 版本(包括补丁级别) ?/td>
  \w 当前工作目录(如 "/home/drobbins")
  \W 当前工作目录的“基名 (basename)”(如 "drobbins")
  \! 当前命令在历史缓冲区中的位置
  \# 命令编号(只要您键入内容,它就会在每次提示时累加)
  \$ 如果您不是超级用户 (root),则插入一个 "$";如果您是超级用户,则显示一个 "#"
  \xxx 插入一个用三位数 xxx(用零代替未使用的数字,如 "\007")表示的 ASCII 字符
  \\ 反斜杠
  \[ 这个序列应该出现在不移动光标的字符序列(如颜色转义序列)之前。它使 bash 能够正确计算自动换行。
  \] 这个序列应该出现在非打印字符序列之后。
  这样,您已经知道了 bash 中用反斜杠转义的全部专用序列。请稍微演练一下这些序列,以对它们的工作方式获得一些感性认识。在您做了一些测试之后,下面开始添加颜色。
  彩色化
  添加颜色相当容易;第一步是设计不带颜色的提示行。然后,我们所要做的只是添加终端(而不是 bash)可识别的专用转义序列,以使它以彩色显示文本的某些部分。标准 Linux 终端和 X 终端允许您设置前景(文字)颜色和背景颜色,如果需要,还可以启用 "bold" 字符。有八种颜色可供我们选择。
  颜色是通过在 PS1 中添加专用序列来选择的 -- 基本上是夹在 "\e["(转义开方括号)和 "m" 之间数字值。如果指定一个以上的数字代码,则用分号将它们分开。下面是一个颜色代码示例:
  "\e[0m"
  export PS1="\w> "
  变为:
  export PS1="\e[32;40m\w> "
  到现在为止,提示行尽管已经很不错了,但仍不太完美。在 bash 显示出工作目录以后,我们需要使用 "\e[0m" 序列将颜色重新设置为正常值。
  export PS1="\e[32;40m\w> \e[0m"
  这个定义将显示一个漂亮的绿色提示行,但我们仍需要做一些扫尾工作。我们不需要包括 "40" 这个背景颜色设置,因为它将背景设置为黑色,而黑色是默认颜色。此外,绿色还很暗;我们通过添加一个 "1" 颜色代码来修正这个问题,这将启用更亮的加粗文字。除了这个修改之外,我们还需要将全部非打印字符用专用的 bash 转义序列 "\[" 和 "\]" 括起来。这两个序列通知 bash,被括起来的字符不占用行上的任何空间,这样就使自动换行能够继续正常工作。没有这两个转义序列,尽管您有了一个非常漂亮的提示行,但是如果您键入的命令恰好到达终端的最右端,就会造成显示混乱。下面是我们最终的提示行:
  export PS1="\[\e[32;1m\]\w> \[\e[0m\]"
  别担心在同一个提示行中使用几种颜色,就像下面这样:
  export PS1="\[\e[36;1m\]\u@\[\e[32;1m\]\H> \[\e[0m\]"
  Xterm 中的乐趣
  我已说明了如何在提示行中添加信息和颜色,但您还可以更进一步。您可以通过在提示行中添加专用代码来使 X 终端(如 rxvt 或 aterm)的标题栏得到动态更新。您所要做的只是将下面的序列添加到您的 PS1 提示行中:
  "\e]2;titlebar\a"
  只须用您希望其出现在 xterm 标题栏中的文字替换子串 "titlebar" 即可,现在已经一切就绪了!不必使用静态文字;您可以将 bash 转义序列插入标题栏中。请查看下面这个示例,它将用户名、主机名和当前工作目录显示在标题栏中,并定义了一个简短、明亮的绿色提示行:
  export PS1="\[\e]2;\u@\H \w\a\e[32;1m\]>\[\e[0m\] "
  mysql提示符
  默认mysql>提示符可以重新配置。定义提示符的字符串可以包含下面的特殊序列:
  选项
  描述
  \v
  服务器版本
  \d
  当前的数据库
  \h
  服务器主机
  \p
  当前的TCP/IP端口或套接字文件
  \u
  你的用户名
  \U
  你的全user_name@host_name账户名
  \\
  ‘\’反斜线字符
  \n
  新行字符
  \t
  Tab字符
  \
  空格(反斜线后面的空格)
  \_
  空格
  \R
  当前的时间,24-小时军用时间(0-23)
  \r
  当前的时间,标准12-小时(1-12)
  \m
  当前时间的分钟
  \y
  当前的年,两位
  \Y
  当前的年,四位
  \D
  当前的日期
  \s
  当前时间的秒
  \w
  当前周的天,3字符格式(Mon,Tue,...)
  \P
  am/pm
  \o
  当前的月,数字格式
  \O
  当前的月,3字符格式(Jan,Feb,...)
  \c
  随发出的每个语句递增的计数
  \S
  分号
  \'
  单引号
  \"
  双引号
  ‘\’后面跟随的其它字母则变为该字母。
  如果不用任何参量指定提示命令,mysql将提示重新设置位默认mysql>。
  可以用MYSQL_PS1环境变量来设置提示字符串。例如:
  shell> export MYSQL_PS1="(\u@\h) [\d]> "
  使用选项文件
  可以在MySQL选项文件中的[mysql]组设置提示,例如根目录中的/etc/my.cnf或.my.cnf文件。例如:
  [mysql]prompt=(\\u@\\h) [\\d]>\\
  在该例子中,请注意反斜线是双线。
  如果使用选项文件中的prompt选项来设置提示,当使用特殊提示选项时,建议使用双反斜线。在允许的提示选项和选项文件中可识别的特殊转义序列中有部分重叠。(这些序列列于4.3.2节,“使用选项文件”)。如果使用单反斜线,会遇到问题。例如,\s被解释为空格而不是当前的秒值。下面的例子显示了如何在选项文件中定义提示以包括当前的时间,格式为HH:MM:SS>:
  [mysql]prompt="\\r:\\m:\\s> "
  使用命令行选项
  可以在mysql的命令行中设置--prompt选项。例如:
  bash shell交互式命令> mysql --prompt="(\u@\h) [\d]> "(user@host) [database]>
  你可以使用prompt(或\R)命令交互地更改提示。例如:
  mysql> prompt (\u@\h) [\d]>\_PROMPT set to '(\u@\h) [\d]>\_'(user@host) [database]>(user@host) [database]> promptReturning to default PROMPT of mysql>mysql>
  mysql --prompt="\u@\h \D \d>"
  root@localhost Tue Mar 24 15:19:22 2009 (none)>
  mysql --prompt="\u@\h \D:\r:\m:\s \d>"
  root@localhost Tue Mar 24 15:19:06 2009:03:19:06 (none)>
  mysql> prompt mysql (
  PROMPT set to 'mysql ('
  mysql (\u@\h \t)>
  ERROR 1049 (42000): Unknown database '@h'
  mysql (prompt mysql (\u@\h \t)>
  PROMPT set to 'mysql (\u@\h \t)>'
  mysql (root@localhost   )>prompt \u@\h \d >
  PROMPT set to '\u@\h \d >'
  root@localhost (none) >use lportal;
  Database changed
  root@localhost lportal >prompt \u@\h \d \\r:\\m:\\s>
  PROMPT set to '\u@\h \d \\r:\\m:\\s>'
  root@localhost lportal \r:\m:\s>prompt \u@\h \d "\\r:\\m:\\s">
  PROMPT set to '\u@\h \d "\\r:\\m:\\s">'
  root@localhost lportal "\r:\m:\s">prompt \u@\h \d \s>
  PROMPT set to '\u@\h \d \s>'
  root@localhost lportal 00>prompt \u@\h \d \r:\m:\s>
  PROMPT set to '\u@\h \d \r:\m:\s>'
  root@localhost lportal 03:17:17>use lportal;
  Database changed
  root@localhost lportal 03:17:24>\q
  Bye


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-556200-1-1.html 上篇帖子: 用shell批量更改库文件名,软链接成.so结尾 下篇帖子: 一个简单的自动创建Shell脚本的脚本
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表