国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

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

JinB / 544人閱讀

摘要:基于優雅的語法和其強大的并發性,我開啟我的學習之旅。男女河南省商水縣等城鎮林村插入數據成功創建表創建表成功啦第二種方式總結今天的總結開發的冰山一角,接下來還需要學習很多。

奧術大師

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

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

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

sqlite3

32 位 windows 的安裝

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

2、下載 gcc 編譯器。到 http://tdm-gcc.tdragon.net/do...,下載 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/do...,下載 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/databa...

github地址:

https://github.com/go-sql-dri...

官網地址:

http://godoc.org/github.com/g...。

也可以在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  
",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("刪除表
",erro)
    }
    fmt.Printf("
刪除表成功 ,結果影響的行數是:%d
",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 
",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
", 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手機助手之卸載監聽

相信自己,沒有做不到的,只有想不到的

在這里獲得的不僅僅是技術!

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/24385.html

相關文章

  • 再見,Python!你好,Go語言

    摘要:語言誕生于谷歌,由計算機領域的三位宗師級大牛和寫成。作者華為云技術宅基地鏈接谷歌前員工認為,比起大家熟悉的,語言其實有很多優良特性,很多時候都可以代替,他已經在很多任務中使用語言替代了。 Go 語言誕生于谷歌,由計算機領域的三位宗師級大牛 Rob Pike、Ken Thompson 和 Robert Griesemer 寫成。由于出身名門,Go 在誕生之初就吸引了大批開發者的關注。誕生...

    zhaot 評論0 收藏0
  • 類的加載機制 - 收藏集 - 掘金

    摘要:是現在廣泛流行的代從開始學習系列之向提交代碼掘金讀完本文大概需要分鐘。為了進行高效的垃圾回收,虛擬機把堆內存劃分成新生代老年代和永久代中無永久代,使用實現三塊區域。 React Native 開源項目 - 仿美團客戶端 (Android、iOS 雙適配) - Android - 掘金推薦 React Native 學習好項目,仿照美團客戶端... 極簡 GitHub 上手教程 - 工具...

    Gilbertat 評論0 收藏0
  • Android重構之旅:架構篇

    摘要:是的架構的實現。是在年提出的一種前端架構,主要用來處理復雜的邏輯的一致性問題當時是為了解決頁面的消息通知問題。 去年10月底來到了新公司,剛開始接手 Android 項目時,發現該項目真的是一團遭,項目開發上沒有任何架構可言,開發人員連簡單的 MVC、MVP 都不了解,Activity 及其臃腫,業務邊界也不明確,因此我決定重新分析一下當前主流的幾種開發架構,選出適合當前項目的架構形式...

    mylxsw 評論0 收藏0

發表評論

0條評論

JinB

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<