摘要:基于優(yōu)雅的語(yǔ)法和其強(qiáng)大的并發(fā)性,我開啟我的學(xué)習(xí)之旅。男女河南省商水縣等城鎮(zhèn)林村插入數(shù)據(jù)成功創(chuàng)建表創(chuàng)建表成功啦第二種方式總結(jié)今天的總結(jié)開發(fā)的冰山一角,接下來(lái)還需要學(xué)習(xí)很多。
奧術(shù)大師
做了近5年的android開發(fā),最近項(xiàng)目也是不怎么忙,空閑的時(shí)候總會(huì)思考一些事情,不過作為移動(dòng)開發(fā),我個(gè)人覺得很有必要學(xué)習(xí)后臺(tái)開發(fā),由于公司是Go語(yǔ)言開發(fā)的,了解go語(yǔ)言一段時(shí)間后,我發(fā)現(xiàn)go語(yǔ)言的強(qiáng)大。基于優(yōu)雅的語(yǔ)法和其強(qiáng)大的并發(fā)性,我開啟我的go學(xué)習(xí)之旅。golang強(qiáng)大的數(shù)據(jù)庫(kù)驅(qū)動(dòng)
Go與PHP不同的地方是Go沒有官方提供數(shù)據(jù)庫(kù)驅(qū)動(dòng),而是為開發(fā)者開發(fā)數(shù)據(jù)庫(kù)驅(qū)動(dòng)定義了一些標(biāo)準(zhǔn)接口,開發(fā)者可以
根據(jù)定義的接口來(lái)開發(fā)相應(yīng)的數(shù)據(jù)庫(kù)驅(qū)動(dòng),這樣做有一個(gè)好處,只要按照標(biāo)準(zhǔn)接口開發(fā)的代碼, 以后需要遷移數(shù)據(jù)
庫(kù)時(shí),不需要任何修改
不亂說(shuō)用到MySQL還是sqlite3,都需要提前安裝數(shù)據(jù)庫(kù)驅(qū)動(dòng)
sqlite332 位 windows 的安裝
1、安裝 sqlite3。到 http://www.sqlite.org/downloa... 的頁(yè)面中,找到 sqlite-dll-win32-x86-3071700.zip 下載解壓,并把里面的 dll 文件復(fù)制到 windows/system32 目錄下。
2、下載 gcc 編譯器。到 http://tdm-gcc.tdragon.net/do...,下載 tdm-gcc-4.7.1-2。如果是 64 位的 win,下載 tdm64-gcc-4.7.1-3。運(yùn)行這個(gè) exe 文件,安裝好 gcc 編譯器。
3、運(yùn)行命令:go get github.com/mattn/go-sqlite3 ,安裝 go 的 sqlite3 的驅(qū)動(dòng)等。
64 位 windows 的安裝
1、下載 gcc 編譯器。到 http://tdm-gcc.tdragon.net/do...,下載 tdm64-gcc-4.7.1-3。運(yùn)行這個(gè) exe 文件,安裝好 gcc 編譯器。
2、運(yùn)行命令:go get github.com/mattn/go-sqlite3 ,安裝 go 的 sqlite3 的驅(qū)動(dòng)等。
MySQL下載:Go語(yǔ)言的 database/sql 包的一個(gè) MySQL驅(qū)動(dòng)。地址: https://golang.org/pkg/databa...
github地址:
https://github.com/go-sql-dri...
官網(wǎng)地址:
http://godoc.org/github.com/g...。
也可以在shell下面執(zhí)行命令:
$ go get github.com/go-sql-driver/mysql
##### 開發(fā)階段
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包的用法簡(jiǎn)潔明了:
首先是Open,
db, err := sql.Open(“mysql”, “user:password@/dbname”)
解釋:
db 是一個(gè)*sql.DB類型的指針,在后面的操作中,都要用到db open之后,并沒有與數(shù)據(jù)庫(kù)建立實(shí)際的連接,與數(shù)據(jù)庫(kù)建立實(shí)際的連接是通過Ping方法完成。此外,db應(yīng)該在整個(gè)程序的生命周期中存在,也就是說(shuō),程序一啟動(dòng),就通過Open獲得db,直到程序結(jié)束,再Close db,而不是經(jīng)常Open/Close。
err = db.Ping()
DB的主要方法有:
Query 執(zhí)行數(shù)據(jù)庫(kù)的Query操作,例如一個(gè)Select語(yǔ)句,返回*Rows
QueryRow 執(zhí)行數(shù)據(jù)庫(kù)至多返回1行的Query操作,返回*Row
PrePare 準(zhǔn)備一個(gè)數(shù)據(jù)庫(kù)query操作,返回一個(gè)*Stmt,用于后續(xù)query或執(zhí)行。這個(gè)Stmt可以被多次執(zhí)行,或者并發(fā)執(zhí)行
Exec 執(zhí)行數(shù)不返回任何rows的據(jù)庫(kù)語(yǔ)句,例如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的數(shù)據(jù)庫(kù)開啟方式:
1、打開任務(wù)管理器-->打開服務(wù)-->查找到服務(wù)名稱為-->Mysql的服務(wù)-->啟動(dòng)就ok了。
2、Ctrl+R 輸入cmd 。在你的Mysql配置好的情況下,你可以輸入net start mysql命令
簡(jiǎn)單開發(fā)測(cè)試案例//插入 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 = "男" //公共類,檢查錯(cuò)誤 func checkError(str string,err error) bool{ if err != nil{ fmt.Printf(str+" %s ",err.Error()) panic(err) return false } return true } func main() { db, err := sql.Open("mysql", "root:yyh123@tcp(localhost:3306)/test?charset=utf8") checkError("打開一個(gè) 數(shù)據(jù)庫(kù)",err) //創(chuàng)建數(shù)據(jù)庫(kù) //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("刪除表 ",erro) } fmt.Printf(" 刪除表成功 ,結(jié)果影響的行數(shù)是:%d ",affect) } //刪除表周中數(shù)據(jù) func deleteFromTabCase(db *sql.DB) { stmt ,err := db.Prepare("delete from tb_user where name = ?") checkError("根據(jù)條件進(jìn)行刪除表",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) } //更新數(shù)據(jù) func updataFromDb(db *sql.DB) { stmt ,err := db.Prepare("update tb_user set name = ? where name = ?") checkError("查詢條件數(shù)據(jù)庫(kù)",err) result ,erro := stmt.Exec("卡卡羅特","yuer") if erro != nil{ checkError("查詢條件數(shù)據(jù)庫(kù)",erro) } affect ,err := result.RowsAffected() checkError("查詢的結(jié)果",err) fmt.Printf("更新的數(shù)據(jù):%d",affect) } //查詢數(shù)據(jù) func queryFromDb(db *sql.DB) { row, error := db.Query("select * from tb_user") if checkError("查詢數(shù)據(jù)庫(kù)",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 ",id,name,age ,sex,addr,tel) } } //row, error := db.Query("select * from tb_user") } //增加:既插入數(shù)據(jù) 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("準(zhǔn)備階段,回準(zhǔn)備要執(zhí)行的sql操作,然后返回準(zhǔn)備完畢的執(zhí)行狀態(tài)。",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,"河南省商水縣等城鎮(zhèn)林村","13011007869") if err != nil{ panic(err) } fmt.Println("插入數(shù)據(jù)成功",result) } //創(chuàng)建表 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("創(chuàng)建表成功啦~~") //第二種方式 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 ", 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) } }總結(jié)
今天的總結(jié)go開發(fā)的冰山一角,接下來(lái)還需要學(xué)習(xí)很多。之所以學(xué)Go,公司的需要以及自己考慮到今后的職業(yè)規(guī)劃,雖然目前還是一Android開發(fā)為主,不過個(gè)人的精力很多時(shí)候放到了go上面自己也建立的有微信交流群,,如果你也有興趣,可以一起來(lái)探討go。
閱讀更多除程序員,除了寫好代碼,你更應(yīng)該學(xué)會(huì)這些!
Android:四大架構(gòu)的優(yōu)缺點(diǎn),你真的了解嗎?
體驗(yàn)golang語(yǔ)言的風(fēng)騷編程
NDK項(xiàng)目實(shí)戰(zhàn)—高仿360手機(jī)助手之卸載監(jiān)聽
相信自己,沒有做不到的,只有想不到的在這里獲得的不僅僅是技術(shù)!
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/24385.html
摘要:語(yǔ)言誕生于谷歌,由計(jì)算機(jī)領(lǐng)域的三位宗師級(jí)大牛和寫成。作者華為云技術(shù)宅基地鏈接谷歌前員工認(rèn)為,比起大家熟悉的,語(yǔ)言其實(shí)有很多優(yōu)良特性,很多時(shí)候都可以代替,他已經(jīng)在很多任務(wù)中使用語(yǔ)言替代了。 Go 語(yǔ)言誕生于谷歌,由計(jì)算機(jī)領(lǐng)域的三位宗師級(jí)大牛 Rob Pike、Ken Thompson 和 Robert Griesemer 寫成。由于出身名門,Go 在誕生之初就吸引了大批開發(fā)者的關(guān)注。誕生...
摘要:是現(xiàn)在廣泛流行的代從開始學(xué)習(xí)系列之向提交代碼掘金讀完本文大概需要分鐘。為了進(jìn)行高效的垃圾回收,虛擬機(jī)把堆內(nèi)存劃分成新生代老年代和永久代中無(wú)永久代,使用實(shí)現(xiàn)三塊區(qū)域。 React Native 開源項(xiàng)目 - 仿美團(tuán)客戶端 (Android、iOS 雙適配) - Android - 掘金推薦 React Native 學(xué)習(xí)好項(xiàng)目,仿照美團(tuán)客戶端... 極簡(jiǎn) GitHub 上手教程 - 工具...
摘要:是的架構(gòu)的實(shí)現(xiàn)。是在年提出的一種前端架構(gòu),主要用來(lái)處理復(fù)雜的邏輯的一致性問題當(dāng)時(shí)是為了解決頁(yè)面的消息通知問題。 去年10月底來(lái)到了新公司,剛開始接手 Android 項(xiàng)目時(shí),發(fā)現(xiàn)該項(xiàng)目真的是一團(tuán)遭,項(xiàng)目開發(fā)上沒有任何架構(gòu)可言,開發(fā)人員連簡(jiǎn)單的 MVC、MVP 都不了解,Activity 及其臃腫,業(yè)務(wù)邊界也不明確,因此我決定重新分析一下當(dāng)前主流的幾種開發(fā)架構(gòu),選出適合當(dāng)前項(xiàng)目的架構(gòu)形式...
閱讀 2652·2021-09-09 09:33
閱讀 2810·2019-08-30 15:54
閱讀 2867·2019-08-30 14:21
閱讀 2356·2019-08-29 17:15
閱讀 3580·2019-08-29 16:13
閱讀 2759·2019-08-29 14:21
閱讀 3422·2019-08-26 13:25
閱讀 2028·2019-08-26 12:14