shell提示符mysql提示符 懶人筆記

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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章