奧術大師
做了近5年的android開發,最近專案也是不怎麼忙,空閒的時候總會思考一些事情,不過作為移動開發,我個人覺得很有必要學習後臺開發,由於公司是Go語言開發的,瞭解go語言一段時間後,我發現go語言的強大。基於優雅的語法和其強大的併發性,我開啟我的go學習之旅。
golang強大的資料庫驅動
Go與PHP不同的地方是Go沒有官方提供資料庫驅動,而是為開發者開發資料庫驅動定義了一些標準介面,開發者可以 根據定義的介面來開發相應的資料庫驅動,這樣做有一個好處,只要按照標準介面開發的程式碼, 以後需要遷移資料 庫時,不需要任何修改
不亂說用到MySQL還是sqlite3,都需要提前安裝資料庫驅動
sqlite3
32 位 windows 的安裝
1、安裝 sqlite3。到 www.sqlite.org/download.ht… 的頁面中,找到 sqlite-dll-win32-x86-3071700.zip 下載解壓,並把裡面的 dll 檔案複製到 windows/system32 目錄下。
2、下載 gcc 編譯器。到 tdm-gcc.tdragon.net/download,下載 tdm-gcc-4.7.1-2。如果是 64 位的 win,下載 tdm64-gcc-4.7.1-3。執行這個 exe 檔案,安裝好 gcc 編譯器。
3、執行命令:go get github.com/mattn/go-sq… ,安裝 go 的 sqlite3 的驅動等。
64 位 windows 的安裝
1、下載 gcc 編譯器。到 tdm-gcc.tdragon.net/download,下載 tdm64-gcc-4.7.1-3。執行這個 exe 檔案,安裝好 gcc 編譯器。
2、執行命令:go get github.com/mattn/go-sq… ,安裝 go 的 sqlite3 的驅動等。
MySQL
下載:Go語言的 database/sql 包的一個 MySQL驅動。
github地址:
官網地址:
也可以在shell下面執行命令:
$ go get github.com/go-sql-driver/mysql
複製程式碼
開發階段
https://github.com/Go-SQL-Driver/MySQL 支援database/sql,全部採用go寫。
https://github.com/ziutek/mymysql 支援database/sql,也支援自定義的介面,全部採用go寫。
https://github.com/Philio/GoMySQL 不支援database/sql,自定義介面,全部採用go寫。
複製程式碼
以MySQL為例:
使用
sql包的用法簡潔明瞭:
1、建立連線
首先是Open,
db, err := sql.Open(“mysql”, “user:password@/dbname”)
解釋:
db 是一個*sql.DB型別的指標,在後面的操作中,都要用到db open之後,並沒有與資料庫建立實際的連線,與資料庫建立實際的連線是通過Ping方法完成。此外,db應該在整個程式的生命週期中存在,也就是說,程式一啟動,就通過Open獲得db,直到程式結束,再Close db,而不是經常Open/Close。 err = db.Ping()
2、基本用法
DB的主要方法有:
-
Query 執行資料庫的Query操作,例如一個Select語句,返回*Rows
-
QueryRow 執行資料庫至多返回1行的Query操作,返回*Row
-
PrePare 準備一個資料庫query操作,返回一個*Stmt,用於後續query或執行。這個Stmt可以被多次執行,或者併發執行
-
Exec 執行數不返回任何rows的據庫語句,例如delete操作
Stmt的主要方法:
- Exec
- Query
- QueryRow
- Close
用法與DB類似
Rows的主要方法:
- Cloumns: 返回[]string,column names
- Scan:
- Next:
- Close:
詳見:
http://golang.org/pkg/database/sql/
https://github.com/go-sql-driver/mysql/wiki/Examples
https://github.com/VividCortex/go-database-sql-tutorial
複製程式碼
備註
Mysql的資料庫開啟方式:
1、開啟工作管理員-->開啟服務-->查詢到服務名稱為-->Mysql的服務-->啟動就ok了。
2、Ctrl+R 輸入cmd 。在你的Mysql配置好的情況下,你可以輸入net start mysql命令
簡單開發測試案例
//插入
func insert(db *sql.DB) {
stmt, err := db.Prepare("INSERT INTO user(username, password) VALUES(?, ?)")
defer stmt.Close()
if err != nil {
log.Println(err)
return
}
stmt.Exec("guotie", "guotie")
stmt.Exec("testuser", "123123")
}
var CURRENT_AGE = 20
var sex = "男"
//公共類,檢查錯誤
func checkError(str string,err error) bool{
if err != nil{
fmt.Printf(str+" %s \b \n",err.Error())
panic(err)
return false
}
return true
}
func main() {
db, err := sql.Open("mysql", "root:yyh123@tcp(localhost:3306)/test?charset=utf8")
checkError("開啟一個 資料庫",err)
//建立資料庫
//createDataBase(db)
//userDb(db)
createTable(db)
insertTableContent(db)
queryFromDb(db)
updataFromDb(db)
//deleteFromTabCase(db)
//dropTab(db)
}
//刪除表
func dropTab(db *sql.DB) {
res ,erro := db.Exec("drop table tb_user")
if erro != nil{
panic(erro)
}
affect,erro := res.RowsAffected()
if erro != nil{
checkError("刪除表\n",erro)
}
fmt.Printf("\n刪除表成功 ,結果影響的行數是:%d\n",affect)
}
//刪除表週中資料
func deleteFromTabCase(db *sql.DB) {
stmt ,err := db.Prepare("delete from tb_user where name = ?")
checkError("根據條件進行刪除表",err)
res ,err := stmt.Exec("卡卡羅特")
if err!= nil{
panic(err)
}
affect, err := res.RowsAffected()
lastId, err := res.LastInsertId()
fmt.Printf("affect : %d lasetId: %d",affect,lastId)
}
//更新資料
func updataFromDb(db *sql.DB) {
stmt ,err := db.Prepare("update tb_user set name = ? where name = ?")
checkError("查詢條件資料庫",err)
result ,erro := stmt.Exec("卡卡羅特","yuer")
if erro != nil{
checkError("查詢條件資料庫",erro)
}
affect ,err := result.RowsAffected()
checkError("查詢的結果",err)
fmt.Printf("更新的資料:%d",affect)
}
//查詢資料
func queryFromDb(db *sql.DB) {
row, error := db.Query("select * from tb_user")
if checkError("查詢資料庫",error){
defer row.Close()
for row.Next(){
var id int
var name string
var age int
var sex string
var addr string
var tel string
row.Scan(&id,&name,&age,&sex,&addr,&tel)
fmt.Printf("查詢到了: id: %d %s %d %s %s %s \n",id,name,age ,sex,addr,tel)
}
}
//row, error := db.Query("select * from tb_user")
}
//增加:既插入資料
func insertTableContent(db *sql.DB) {
//var userId int = utils.GetNowtimeMD5()
stmt ,err := db.Prepare("insert tb_user set id = ?, name = ? ,age = ?, sex = ?,addr = ?,tel=?;")
//stmt, err := db.Prepare("insert userinfo set username=?,departname=?,created=?,password=?,uid=?")
checkError("準備階段,回準備要執行的sql操作,然後返回準備完畢的執行狀態。",err)
if CURRENT_AGE % 2 == 0{
sex = "男"
}else{
sex = "女 "
}
CURRENT_AGE = CURRENT_AGE+utils.Generate_Randnum()
result, err :=stmt.Exec(CURRENT_AGE,"yuer",CURRENT_AGE,sex,"河南省商水縣等城鎮林村","13011007869")
if err != nil{
panic(err)
}
fmt.Println("插入資料成功",result)
}
//建立表
func createTable(db *sql.DB) {
_, err := db.Exec("CREATE TABLE IF NOT EXISTS tb_user(id int(10) primary key,name varchar(20),age int(10),sex varchar(5),addr varchar(64),tel varchar(11));")
if err != nil {
fmt.Println("create table failed:", err.Error())
return
}
fmt.Println("建立表成功啦~~")
//第二種方式
stmt, erro := db.Prepare(userDetail)
if erro != nil {
panic(erro)
}
_, err = stmt.Exec()
if err != nil {
panic(err)
}
}
func main1() {
db, err := sql.Open("mysql", "root:yyh123@tcp(10.2.0.215:3306)/test?charset=utf8")
if err != nil {
log.Fatalf("Open database error: %s\n", err)
}
defer db.Close()
err = db.Ping()
if err != nil {
log.Fatal(err)
}
insert(db)
rows, err := db.Query("select id, username from user where id = ?", 1)
if err != nil {
log.Println(err)
}
defer rows.Close()
var id int
var name string
for rows.Next() {
err := rows.Scan(&id, &name)
if err != nil {
log.Fatal(err)
}
log.Println(id, name)
}
err = rows.Err()
if err != nil {
log.Fatal(err)
}
}
複製程式碼
總結
今天的總結go開發的冰山一角,接下來還需要學習很多。之所以學Go,公司的需要以及自己考慮到今後的職業規劃,雖然目前還是一Android開發為主,不過個人的精力很多時候放到了go上面自己也建立的有微信交流群,,如果你也有興趣,可以一起來探討go。
閱讀更多
相信自己,沒有做不到的,只有想不到的
在這裡獲得的不僅僅是技術!