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

奧術大師html

作了近5年的android開發,最近項目也是不怎麼忙,空閒的時候總會思考一些事情,不過做爲移動開發,我我的以爲頗有必要學習後臺開發,因爲公司是Go語言開發的,瞭解go語言一段時間後,我發現go語言的強大。基於優雅的語法和其強大的併發性,我開啓個人go學習之旅。mysql

golang強大的數據庫驅動

Go與PHP不一樣的地方是Go沒有官方提供數據庫驅動,而是爲開發者開發數據庫驅動定義了一些標準接口,開發者能夠 根據定義的接口來開發相應的數據庫驅動,這樣作有一個好處,只要按照標準接口開發的代碼, 之後須要遷移數據 庫時,不須要任何修改android

不亂說用到MySQL仍是sqlite3,都須要提早安裝數據庫驅動git

sqlite3

32 位 windows 的安裝程序員

一、安裝 sqlite3。到 www.sqlite.org/download.ht… 的頁面中,找到 sqlite-dll-win32-x86-3071700.zip 下載解壓,並把裏面的 dll 文件複製到 windows/system32 目錄下。github

二、下載 gcc 編譯器。到 tdm-gcc.tdragon.net/download,下載 tdm-gcc-4.7.1-2。若是是 64 位的 win,下載 tdm64-gcc-4.7.1-3。運行這個 exe 文件,安裝好 gcc 編譯器。golang

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

64 位 windows 的安裝shell

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

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

MySQL

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

地址: golang.org/pkg/databas…

github地址:

github.com/go-sql-driv…

官網地址:

godoc.org/github.com/…

也能夠在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包的用法簡潔明瞭:

一、創建鏈接

首先是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()

二、基本用法

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的數據庫開啓方式:

一、打開任務管理器-->打開服務-->查找到服務名稱爲-->Mysql的服務-->啓動就ok了。

二、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。

閱讀更多

除程序員,除了寫好代碼,你更應該學會這些!

Android:四大架構的優缺點,你真的瞭解嗎?

體驗golang語言的風騷編程

NDK項目實戰—高仿360手機助手之卸載監聽

相信本身,沒有作不到的,只有想不到的

在這裏得到的不只僅是技術!

相關文章
相關標籤/搜索