成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

go語言數(shù)據(jù)庫orm GO語言數(shù)據(jù)庫環(huán)境配置

Golang database/sql源碼分析

Gorm是Go語言開發(fā)用的比較多的一個(gè)ORM。它的功能比較全:

創(chuàng)新互聯(lián)成立與2013年,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站設(shè)計(jì)、做網(wǎng)站網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元吉首做網(wǎng)站,已為上家服務(wù),為吉首各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:18982081108

但是這篇文章中并不會(huì)直接看Gorm的源碼,我們會(huì)先從database/sql分析。原因是Gorm也是基于這個(gè)包來封裝的一些功能。所以只有先了解了database/sql包才能更加好的理解Gorm源碼。

database/sql 其實(shí)也是一個(gè)對(duì)于mysql驅(qū)動(dòng)的上層封裝?!眊ithub.com/go-sql-driver/mysql”就是一個(gè)對(duì)于mysql的驅(qū)動(dòng),database/sql 就是在這個(gè)基礎(chǔ)上做的基本封裝包含連接池的使用

下面這個(gè)是最基本的增刪改查操作

操作分下面幾個(gè)步驟:

因?yàn)镚orm的連接池就是使用database/sql包中的連接池,所以這里我們需要學(xué)習(xí)一下包里的連接池的源碼實(shí)現(xiàn)。其實(shí)所有連接池最重要的就是連接池對(duì)象、獲取函數(shù)、釋放函數(shù)下面來看一下database/sql中的連接池。

DB對(duì)象

獲取方法

釋放連接方法

連接池的實(shí)現(xiàn)有很多方法,在database/sql包中使用的是chan阻塞 使用map記錄等待列表,等到有連接釋放的時(shí)候再把連接傳入等待列表中的chan 不在阻塞返回連接。

之前我們看到的Redigo是使用一個(gè)chan 來阻塞,然后釋放的時(shí)候放入空閑列表,在往這一個(gè)chan中傳入struct{}{},讓程序繼續(xù) 獲取的時(shí)候再從空閑列表中獲取。并且使用的是鏈表的結(jié)構(gòu)來存儲(chǔ)空閑列表。

database/sql 是對(duì)于mysql驅(qū)動(dòng)的封裝,然而Gorm則是對(duì)于database/sql的再次封裝。讓我們可以更加簡(jiǎn)單的實(shí)現(xiàn)對(duì)于mysql數(shù)據(jù)庫的操作。

如何使用go語言的beego框架的orm

models.go

============================

package main

import (

"github.com/astaxie/beego/orm"

)

type User struct {

Id int

Name string

Profile *Profile `orm:"rel(one)"` // OneToOne relation

}

type Profile struct {

Id int

Age int16

User *User `orm:"reverse(one)"` // 設(shè)置反向關(guān)系(可選)

}

func init() {

// 需要在init中注冊(cè)定義的model

orm.RegisterModel(new(User), new(Profile))

}

main.go

==============

package main

import (

"fmt"

"github.com/astaxie/beego/orm"

_ "github.com/go-sql-driver/mysql"

)

func init() {

//orm.RegisterModel(new(User))

orm.RegisterDataBase("default", "mysql", "ta3:ta3@/ta3?charset=utf8")

orm.RunSyncdb("default", false, true) // true 改成false,如果表存在則會(huì)給出提示,如果改成false則不會(huì)提示 , 這句話沒有會(huì)報(bào)主鍵不存在的錯(cuò)誤

}

func main() {

o := orm.NewOrm()

o.Using("default") // 默認(rèn)使用 default,你可以指定為其他數(shù)據(jù)庫

user := User{Id: 1}

err := o.Read(user)

if err == orm.ErrNoRows {

fmt.Println("查詢不到")

} else if err == orm.ErrMissPK {

fmt.Println("找不到主鍵")

} else {

fmt.Println(user.Id, user.Name)

}

}

執(zhí)行結(jié)果:

create table `user`

-- --------------------------------------------------

-- Table Structure for `main.User`

-- --------------------------------------------------

CREATE TABLE IF NOT EXISTS `user` (

`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY,

`name` varchar(255) NOT NULL,

`profile_id` integer NOT NULL UNIQUE

) ENGINE=InnoDB;

create table `profile`

-- --------------------------------------------------

-- Table Structure for `main.Profile`

-- --------------------------------------------------

CREATE TABLE IF NOT EXISTS `profile` (

`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY,

`age` smallint NOT NULL

) ENGINE=InnoDB;

查詢不到

第二次再執(zhí)行:

table `user` already exists, skip

table `profile` already exists, skip

查詢不到

如果 orm.RunSyncdb("default", false, true)改成 orm.RunSyncdb("default", false, false)

則執(zhí)行結(jié)果不會(huì)提示。

Golang 項(xiàng)目中 ORM 選擇,gorm xorm 對(duì)比

之前用 beego 中自帶的 orm,感覺有一些不是很滿足需求的地方,而且想要嘗試一些新的 orm,寫一篇記錄一下。

在 xorm 和 gorm 之間對(duì)比了一下:

p.s. 需要說明的是,對(duì)比非常初級(jí),而且項(xiàng)目處于很早期,也抱著嘗試一下不行再改的心理,并沒有想要得到一個(gè)孰優(yōu)孰劣的結(jié)論。

想來想去,對(duì)于一個(gè)成熟的項(xiàng)目可能 gorm 更適合,但是 xorm 好像近期在頻繁 commit,有一種想要追趕的意思。

那我先試試 xorm ,不知道為什么選的這個(gè),可能是想試試看新款吧。(大霧

2017/07/04

可怕,xorm 不支持外鍵關(guān)系。一對(duì)一啥的。

當(dāng)前題目:go語言數(shù)據(jù)庫orm GO語言數(shù)據(jù)庫環(huán)境配置
本文URL:http://jinyejixie.com/article46/dosedhg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)、品牌網(wǎng)站設(shè)計(jì)小程序開發(fā)、商城網(wǎng)站、網(wǎng)站改版、標(biāo)簽優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站
临朐县| 天气| 清水县| 土默特右旗| 天津市| 申扎县| 株洲县| 当雄县| 陵水| 古丈县| 瓮安县| 滨海县| 东乡| 盘山县| 内乡县| 江安县| 开阳县| 江孜县| 盐津县| 哈巴河县| 桃园市| 桃园市| 新津县| 枝江市| 大同县| 基隆市| 永福县| 无锡市| 米脂县| 婺源县| 武乡县| 郸城县| 临漳县| 阜阳市| 岐山县| 张北县| 闽侯县| 毕节市| 天镇县| 阿城市| 邵阳市|