開發了5年android,我開始了go學習之旅


前言

做了近5年的android開發,最近項目也是不怎么忙,空閑的時候總會思考一些事情,不過作為移動開發,我個人覺得很有必要學習后台開發,由於公司是Go語言開發的,了解go語言一段時間后,我發現go語言的強大。基於優雅的語法和其強大的並發性,我開啟我的go學習之旅。

golang強大的數據庫驅動

Go與PHP不同的地方是Go沒有官方提供數據庫驅動,而是為開發者開發數據庫驅動定義了一些標准接口,開發者可以
根據定義的接口來開發相應的數據庫驅動,這樣做有一個好處,只要按照標准接口開發的代碼, 以后需要遷移數據
庫時,不需要任何修改

不亂說用到MySQL還是sqlite3,都需要提前安裝數據庫驅動

sqlite3

32 位 windows 的安裝

1、安裝 sqlite3。到 http://www.sqlite.org/download.html 的頁面中,找到 sqlite-dll-win32-x86-3071700.zip 下載解壓,並把里面的 dll 文件復制到 windows/system32 目錄下。

2、下載 gcc 編譯器。到 http://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-sqlite3 ,安裝 go 的 sqlite3 的驅動等。

64 位 windows 的安裝

1、下載 gcc 編譯器。到 http://tdm-gcc.tdragon.net/download,下載 tdm64-gcc-4.7.1-3。運行這個 exe 文件,安裝好 gcc 編譯器。

2、運行命令:go get github.com/mattn/go-sqlite3 ,安裝 go 的 sqlite3 的驅動等。

MySQL

下載:Go語言的 database/sql 包的一個 MySQL驅動。

地址: https://golang.org/pkg/database/sql/

github地址:

https://github.com/go-sql-driver/mysql

官網地址:

http://godoc.org/github.com/go-sql-driver/mysql

也可以在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。

參考:

閱讀更多

體驗golang語言的風騷編程

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM