Transact-SQL 參考
成都創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),石景山企業(yè)網(wǎng)站建設(shè),石景山品牌網(wǎng)站建設(shè),網(wǎng)站定制,石景山網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營(yíng)銷(xiāo),網(wǎng)絡(luò)優(yōu)化,石景山網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競(jìng)爭(zhēng)力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專(zhuān)業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長(zhǎng)自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。
GO
用信號(hào)通知 Microsoft? SQL Server? 實(shí)用工具一批 Transact-SQL 語(yǔ)句的結(jié)束。
語(yǔ)法
GO
注釋
GO 不是 Transact-SQL 語(yǔ)句;而是可為 osql 和 isql 實(shí)用工具及 SQL Server 查詢分析器識(shí)別的命令。
SQL Server 實(shí)用工具將 GO 解釋為應(yīng)將當(dāng)前的 Transact-SQL 批處理語(yǔ)句發(fā)送給 SQL Server 的信號(hào)。當(dāng)前批處理語(yǔ)句是自上一 GO 命令后輸入的所有語(yǔ)句,若是第一條 GO 命令,則是從特殊會(huì)話或腳本的開(kāi)始處到這條 GO 命令之間的所有語(yǔ)句。SQL 查詢分析器和 osql 及 isql 命令提示實(shí)用工具執(zhí)行 GO 命令的方式不同。有關(guān)更多信息,請(qǐng)參見(jiàn) osql 實(shí)用工具、isql 實(shí)用工具和 SQL 查詢分析器。
GO 命令和Transact-SQL 語(yǔ)句不可在同一行上。但在 GO 命令行中可包含注釋。
用戶必須遵照使用批處理的規(guī)則。例如,在批處理中的第一條語(yǔ)句后執(zhí)行任何存儲(chǔ)過(guò)程必須包含 EXECUTE 關(guān)鍵字。局部(用戶定義)變量的作用域限制在一個(gè)批處理中,不可在 GO 命令后引用。
USE pubs
GO
DECLARE @MyMsg VARCHAR(50)
SELECT @MyMsg = 'Hello, World.'
GO -- @MyMsg is not valid after this GO ends the batch.
-- Yields an error because @MyMsg not declared in this batch.
PRINT @MyMsg
GO
SELECT @@VERSION;
-- Yields an error: Must be EXEC sp_who if not first statement in
-- batch.
sp_who
GO
SQL Server 應(yīng)用程序可將多條 Transact-SQL 語(yǔ)句作為一個(gè)批處理發(fā)給 SQL Server 去執(zhí)行。在此批處理中的語(yǔ)句編譯成一個(gè)執(zhí)行計(jì)劃。程序員在 SQL Server 實(shí)用工具中執(zhí)行特定語(yǔ)句,或生成 Transact-SQL 語(yǔ)句腳本在 SQL Server 實(shí)用工具中運(yùn)行,用 GO 來(lái)標(biāo)識(shí)批處理的結(jié)束。
如果基于 DB-Library、ODBC 或 OLE DB APIs 的應(yīng)用程序試圖執(zhí)行 GO 命令時(shí)會(huì)收到語(yǔ)法錯(cuò)誤。SQL Server 實(shí)用工具永遠(yuǎn)不會(huì)向服務(wù)器發(fā)送 GO 命令。
權(quán)限
GO 是一個(gè)不需權(quán)限的實(shí)用工具命令??梢杂扇魏斡脩魣?zhí)行。
示例
下面的示例創(chuàng)建兩個(gè)批處理。第一個(gè)批處理只包含一條 USE pubs 語(yǔ)句,用于設(shè)置數(shù)據(jù)庫(kù)上下文。剩下的語(yǔ)句使用了一個(gè)局部變量,因此所有的局部變量聲明必須在一個(gè)批處理中。這一點(diǎn)可通過(guò)在最后一條引用此變量的語(yǔ)句之后才使用 GO 命令來(lái)做到。
USE pubs
GO
DECLARE @NmbrAuthors int
SELECT @NmbrAuthors = COUNT(*)
FROM authors
PRINT 'The number of authors as of ' +
CAST(GETDATE() AS char(20)) + ' is ' +
CAST(@NmbrAuthors AS char (10))
GO
一般命令
所謂一般命令,就是在一定時(shí)間內(nèi)會(huì)執(zhí)行完的命令。比如 grep, cat 等等。 執(zhí)行命令的步驟是:連接,執(zhí)行,獲取結(jié)果
連接
連接包含了認(rèn)證,可以使用 password 或者 sshkey 2種方式來(lái)認(rèn)證。下面的示例為了簡(jiǎn)單,使用了密碼認(rèn)證的方式來(lái)完成連接。
import (
"fmt"
"time"
"golang.org/x/crypto/ssh"
)
func connect(user, password, host string, port int) (*ssh.Session, error) {
var (
auth []ssh.AuthMethod
addr string
clientConfig *ssh.ClientConfig
client *ssh.Client
session *ssh.Session
err error
)
// get auth method
auth = make([]ssh.AuthMethod, 0)
auth = append(auth, ssh.Password(password))
clientConfig = ssh.ClientConfig{
User: user,
Auth: auth,
Timeout: 30 * time.Second,
}
// connet to ssh
addr = fmt.Sprintf("%s:%d", host, port)
if client, err = ssh.Dial("tcp", addr, clientConfig); err != nil {
return nil, err
}
// create session
if session, err = client.NewSession(); err != nil {
return nil, err
}
return session, nil
}
連接的方法很簡(jiǎn)單,只要提供登錄主機(jī)的 用戶*, *密碼*, *主機(jī)名或者IP*, *SSH端口
執(zhí)行,命令獲取結(jié)果
連接成功后,執(zhí)行命令很簡(jiǎn)單
import (
"fmt"
"log"
"os"
"time"
"golang.org/x/crypto/ssh"
)
func main() {
session, err := connect("root", "xxxxx", "127.0.0.1", 22)
if err != nil {
log.Fatal(err)
}
defer session.Close()
session.Run("ls /; ls /abc")
}
上面代碼運(yùn)行之后,雖然命令正常執(zhí)行了,但是沒(méi)有正常輸出的結(jié)果,也沒(méi)有異常輸出的結(jié)果。 要想顯示結(jié)果,需要將 session 的 Stdout 和 Stderr 重定向 修改 func main 為如下:
func main() {
session, err := connect("root", "xxxxx", "127.0.0.1", 22)
if err != nil {
log.Fatal(err)
}
defer session.Close()
session.Stdout = os.Stdout
session.Stderr = os.Stderr
session.Run("ls /; ls /abc")
}
這樣就能在屏幕上顯示正常,異常的信息了。
交互式命令
上面的方式無(wú)法遠(yuǎn)程執(zhí)行交互式命令,比如 top , 遠(yuǎn)程編輯一個(gè)文件,比如 vi /etc/nginx/nginx.conf 如果要支持交互式的命令,需要當(dāng)前的terminal來(lái)接管遠(yuǎn)程的 PTY。
func main() {
session, err := connect("root", "olordjesus", "dockers.iotalabs.io", 2210)
if err != nil {
log.Fatal(err)
}
defer session.Close()
fd := int(os.Stdin.Fd())
oldState, err := terminal.MakeRaw(fd)
if err != nil {
panic(err)
}
defer terminal.Restore(fd, oldState)
// excute command
session.Stdout = os.Stdout
session.Stderr = os.Stderr
session.Stdin = os.Stdin
termWidth, termHeight, err := terminal.GetSize(fd)
if err != nil {
panic(err)
}
// Set up terminal modes
modes := ssh.TerminalModes{
ssh.ECHO: 1, // enable echoing
ssh.TTY_OP_ISPEED: 14400, // input speed = 14.4kbaud
ssh.TTY_OP_OSPEED: 14400, // output speed = 14.4kbaud
}
// Request pseudo terminal
if err := session.RequestPty("xterm-256color", termHeight, termWidth, modes); err != nil {
log.Fatal(err)
}
session.Run("top")
}
總結(jié)
好了,這樣就可以執(zhí)行交互式命令了,比如上面的 top 也可以通過(guò) vi /etc/nginx/nignx.conf 之類(lèi)的命令來(lái)遠(yuǎn)程編輯文件。
您好,很高興為您解答。
安裝daemonize
安裝git環(huán)境
yum?install?git?-y
獲取daemonize
git?clone?git://github.com/bmc/daemonize.git
安裝daemonize
cd?daemonize
./configure
make??make?install
查看是否安裝
daemonize?-v
通過(guò)daemonize執(zhí)行g(shù)olang守護(hù)進(jìn)程
需要打包golang程序?yàn)榭蓤?zhí)行文件(go build),并通過(guò)daemonize來(lái)執(zhí)行它來(lái)實(shí)現(xiàn)守護(hù)進(jìn)程,如:
daemonize?-p?/var/run/myapp.pid?-l?/var/lock/subsys/myapp?-u?nobody?/path/to/myapp
如若滿意,請(qǐng)點(diǎn)擊右側(cè)【采納答案】,如若還有問(wèn)題,請(qǐng)點(diǎn)擊【追問(wèn)】
希望我的回答對(duì)您有所幫助,望采納!
~?O(∩_∩)O~
1、goroutine:在go語(yǔ)言中,每一個(gè)并發(fā)的執(zhí)行單元叫做goroutine,如果一個(gè)程序中包含多個(gè)goroutine,對(duì)兩個(gè)函數(shù)的調(diào)用則可能發(fā)生在同一時(shí)刻
2、main goroutine:當(dāng)一個(gè)程序啟動(dòng)時(shí),其主函數(shù)即在一個(gè)單獨(dú)的goroutine中運(yùn)行,我們叫他為main gorountine
3、go goroutine:新的goroutine會(huì)用go語(yǔ)句來(lái)創(chuàng)建,go+函數(shù)名,go語(yǔ)句會(huì)使其語(yǔ)句中的函數(shù)在一新創(chuàng)建的goroutine中運(yùn)行,而go語(yǔ)句本身會(huì)迅速地完成
4、goroutine的退出:主函數(shù)返回時(shí),所有的goroutine都會(huì)被直接打斷,程序退出,除了從主函數(shù)退出或者終止程序之外,沒(méi)有其他方法能夠讓一個(gè)goroutine來(lái)打斷另一個(gè)的執(zhí)行,但是可以通過(guò)另一種方式來(lái)實(shí)現(xiàn)這個(gè)目的,通過(guò)goroutine之間的通信來(lái)讓一個(gè)goroutine請(qǐng)求其他的goroutine,并讓請(qǐng)求的goroutine自行結(jié)束執(zhí)行
網(wǎng)站欄目:go語(yǔ)言程序如何執(zhí)行 go語(yǔ)言編寫(xiě)
瀏覽地址:http://jinyejixie.com/article6/dddhcog.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、網(wǎng)站營(yíng)銷(xiāo)、網(wǎng)站導(dǎo)航、小程序開(kāi)發(fā)、網(wǎng)站排名、網(wǎng)站設(shè)計(jì)公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)