gosql
『壹』 怎麼判斷go-sql-driver 安裝成功
go操作mysql的驅動包很多,這里講解當下比較流行的Go-SQL-Driver/MySQL
1.下載安裝
執行下面兩個命令:
下載:go get github.com/Go-SQL-Driver/MySQL
安裝:go install github.com/Go-SQL-Driver/MySQL
安裝完成以後的文件截圖
root/go_s是go工作目錄,環境變數:$GOPATH中設置的值
2.導入包
import (
"database/sql"
_"github.com/Go-SQL-Driver/MySQL"
)
3.鏈接資料庫
Open函數:
db, err := sql.Open("mysql", "用戶名:密碼@tcp(IP:埠)/資料庫?charset=utf8")
例如:db, err := sql.Open("mysql", "root:111111@tcp(127.0.0.1:3306)/test?charset=utf8")
4.增刪改查
下面例子中的表結構:
CREATE TABLE `userinfo` (
`uid` int(10) NOT NULL AUTO_INCREMENT,
`username` varchar(64) DEFAULT NULL,
`departname` varchar(64) DEFAULT NULL,
`created` date DEFAULT NULL,
PRIMARY KEY (`uid`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;
截圖:
增加
有兩種方法:
1.直接使用Exec函數添加
result, err := db.Exec("INSERT INTO userinfo (username, departname, created) VALUES (?, ?, ?)","lily","銷售","2016-06-21")
2.首先使用Prepare獲得stmt,然後調用Exec添加
stmt, err := db.Prepare("INSERT userinfo SET username=?,departname=?,created=?")
res, err := stmt.Exec("zhja", "研發", "2016-06-17")
另一個經常用到的功能,獲得剛剛添加數據的自增ID
id, err := res.LastInsertId()
相關代碼截圖:
刪除
刪除和上面的增加語法一樣,只是把其中的INSERT語句改為DELETE語句
修改
修改和上面的增加語法一樣,只是把其中的INSERT語句改為UPDATE語句
查詢
查詢單條數據,QueryEow 函數
var username, departname, created string
err := db.QueryRow("SELECT username,departname,created FROM userinfo WHERE uid=?", 3).Scan(&username, &departname, &created)
代碼截圖:
查詢多條數據,並遍歷
Query 獲取數據,for xxx.Next() 遍歷數據
5.事務
在操作資料庫之前執行,db.Begin()
例:tx, err := db.Begin()
保存到資料庫:err := tx.Commit()
回滾:err := tx.Rollback()
注意設置事務以後操作資料庫就不是db了,而是tx
『貳』 SQL 中go的意義
go不是 Transact-SQL 語句,而是 osql 和 isql 實用工具及 SQL Server 查詢分析器才能識別的命令。
go其實就是個分隔符,將語句分隔開,但go又不僅僅是個分隔符,比如你給的代碼,如果沒有go有可能會執行出錯,究其原因,主要是因為其前後的語句是兩個獨立的事務。
go語句分隔的部分會被分別編譯為兩個執行計劃。
『叄』 sql中GO語句可用可不用嗎什麼時候有用以及如何使用
GO
向 SQL Server 實用工具發出一批 Transact-SQL 語句結束的信號。
例子1:
USE AdventureWorks;
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 應用程序可以將多個 Transact-SQL 語句作為一個批發送到 SQL Server 的實例來執行。然後,該批中的語句被編譯成一個執行計劃。程序員在 SQL Server 實用工具中執行特殊語句,或生成 Transact-SQL 語句的腳本在 SQL Server 實用工具中運行時,使用 GO 作為批結束的信號。
例子2
USE AdventureWorks;
GO
DECLARE @NmbrContacts int
SELECT @NmbrContacts = COUNT(*)
FROM Person.Contact
PRINT 'The number of contacts as of ' +
CAST(GETDATE() AS char(20)) + ' is ' +
CAST(@NmbrContacts AS char (10))
GO
『肆』 SQL語句中go有什麼作用
如果只是執行一條語句,有沒有GO都一樣
如果多條語句之間用GO分隔開就不一樣了
每個被GO分隔的語句都是一個單獨的事務,一個語句執行失敗不會影響其它語句執行。
例如:
首先同時執行下邊的語句
select * from sysobjects where id=a
select getdate()
你會發現會報錯,並且不會顯示任何結果集
而你再執行
select * from sysobjects where id=a
go
select getdate()
go
你會發現盡管同樣會報錯,但結果集中包含select getdate()的結果。
『伍』 SQL中GO 是用來幹嘛的
SQL Server的工具中(比如:SQL Server Management Studio) 標志著一組T-SQL語句的結尾符號。
比如說:
USEAdventureWorks2012;
GO
DECLARE@NmbrPeopleint
SELECT@NmbrPeople=COUNT(*)
FROMPerson.Person;
PRINT'Thenumberofpeopleasof'+
CAST(GETDATE()ASchar(20))+'is'+
CAST(@NmbrPeopleASchar(10));
GO
不過這個是結尾標志符號是可以自定義的,你可以改為你想要的字元。
你可以在MSDN中找到更多關於Go語句的內容
http://msdn.microsoft.com/en-us/library/ms188037.aspx
『陸』 關於SQL 「GO」用法
go就是用於一個sql語句的結束 比如說一個批處理語句是這樣的 select *from b select *from a 在後一個select後面加上一個go這樣可以一次執行兩條sql 語句
『柒』 請問SQL中,GO、use的意思
GO向 SQL Server 實用工具發出一批 Transact-SQL 語句結束的信號。go是把t-sql語句分批次執行。(一步成功了才會執行下一步,即一步一個GO)
Use 是改變 對哪個資料庫的操作
http://blog.sina.com.cn/s/blog_475689f301000bol.html
『捌』 請問SQL語句中go有什麼作用
如果只是執行一條語句,有沒有go都一樣
如果多條語句之間用go分隔開就不一樣了
每個被go分隔的語句都是一個單獨的事務,一個語句執行失敗不會影響其它語句執行。
例如:
首先同時執行下邊的語句
select
*
from
sysobjects
where
id=a
select
getdate()
你會發現會報錯,並且不會顯示任何結果集
而你再執行
select
*
from
sysobjects
where
id=a
go
select
getdate()
go
你會發現盡管同樣會報錯,但結果集中包含select
getdate()的結果。
『玖』 sql語句中go的用法
go之前的語句作為一個批處理執行,
為了區分多個批處理而設的分隔符.,代表一個批處理的結束.
批處理是包含一個或多個 Transact-SQL 語句的組
Create,Alter這些語句可能不能其他語句在同一個批處理中執行。
『拾』 關於sql 中 use go 的具體用法
SQL腳本是一種用SQL語言寫的批處理文件(.sql),SQL腳本通常可以由SQL查詢分析器來執行。
=====================================================
GO向 SQL Server 實用工具發出一批 Transact-SQL 語句結束的信號。go是把t-sql語句分批次執行。(一步成功了才會執行下一步,即一步一個GO)
語法
GO
注釋
GO 不是Transact-SQL語句;而是可為cmdsql和osql實用工具及SQL Server查詢分析器識別的命令。
SQL Server實用工具將GO解釋為應將當前的Transact-SQL批處理語句發送給SQL Server的信號。當前批處理語句是自上一GO命令後輸入的所有語句,若是第一條GO命令,則是從特殊會話或腳本的開始處到這條GO命令之間的所有語句。
GO命令和Transact-SQL語句不可在同一行上。但在GO命令行中可包含注釋。
用戶必須遵照使用批處理(.sql)的規則。
例如,在批處理(.sql)中的第一條語句後執行任何存儲過程必須包含EXECUTE關鍵字。
再有,局部(用戶定義)變數的作用域限制在一個批處理中,不可在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應用程序可將多條Transact-SQL語句作為一個批處理發給SQL Server去執行。在此批處理中的語句編譯成一個執行計劃。程序員在SQL Server實用工具中執行特定語句,或生成Transact-SQL語句腳本在SQL Server實用工具中運行,用GO來標識批處理的結束。
如果基於DB-Library、ODBC或OLE DB APIs的應用程序試圖執行GO命令時會收到語法錯誤。SQL Server實用工具永遠不會向伺服器發送GO命令。
許可權
GO 是一個不需許可權的實用工具命令。可以由任何用戶執行。
示例
下面的示例創建兩個批處理。第一個批處理只包含一條USE pubs語句,用於設置資料庫上下文。剩下的語句使用了一個局部變數,因此所有的局部變數聲明必須在一個批處理中。這一點可通過在最後一條引用此變數的語句之後才使用GO命令來做到。
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
=================================================
USE //改變當前操作資料庫
用法:
USE 資料庫名
例:
CREATE DATABASE XX1 --創建XX1資料庫
………………
GO
CREATE DATABASE XX2 --創建XX2資料庫
………………
GO
USE XX1 --轉到XX1資料庫
GO
………… --對XX1資料庫的操作
GO
USE XX2 --轉到XX2資料庫
GO
………… --對XX2資料庫的操作
GO
USE在存儲過程中不能直接使用
但可以這樣用:
create proc test
as
exec('use pubs select * from jobs') --或者exec(use pubs) exec sp_adser 'xxxx'
go
--使用Exec(ute)語句配合USE來改變當前資料庫,但資料庫環境的更改只在Execute語句結束前有效,所以必須把後面的語句和Execute放到一起
exec test