亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Go語言O(shè)RM包中使用worm構(gòu)造查詢條件的實例詳解

 更新時間:2022年07月18日 14:22:31   作者:haming  
worm是一款方便易用的Go語言O(shè)RM庫。worm支Model方式(持結(jié)構(gòu)體字段映射)、原生SQL以及SQLBuilder三種模式來操作數(shù)據(jù)庫,并且Model方式、原生SQL以及SQLBuilder可混合使用,本文通過一些例子來說明如何使用worm來構(gòu)造查詢條件,感興趣的朋友一起看看吧

構(gòu)造查詢條件

worm是一款方便易用的Go語言O(shè)RM庫。worm支Model方式(持結(jié)構(gòu)體字段映射)、原生SQL以及SQLBuilder三種模式來操作數(shù)據(jù)庫,并且Model方式、原生SQL以及SQLBuilder可混合使用。

Model方式、SQL builder支持鏈?zhǔn)紸PI,可使用Where, And, Or, ID, In, Limit, GroupBy, OrderBy, Having等函數(shù)構(gòu)造查詢條件。也可以可通過Join、LeftJoin、RightJoin來進(jìn)行數(shù)據(jù)庫表之間的關(guān)聯(lián)查詢。

本文通過一些例子來說明如何使用worm來構(gòu)造查詢條件。

main函數(shù)

package main
import (
    "database/sql"
    _ "github.com/go-sql-driver/mysql"
    log "github.com/haming123/wego/dlog"
    "github.com/haming123/wego/worm"
)
func mysql_open(cnnstr string) (*sql.DB, error) {
    db, err := sql.Open("mysql", cnnstr)
    if err != nil {
        return nil, err
    }
    err = db.Ping()
    if err != nil {
        return nil, err
    }
    return db, nil
}
func main() {
    //創(chuàng)建數(shù)據(jù)連接池
    cnnstr := "user:passwd@tcp(127.0.0.1:3306)/dbname?charset=utf8&parseTime=True"
    db_cnn, err := mysql_open(cnnstr)
    if err != nil {
        log.Error(err)
        return
    }
    //初始化ORM
    worm.InitMysql(db_cnn)
    //顯示SQL語句log
    worm.ShowSqlLog(true)
}

說明:

  • worm代碼的下載
    go get github.com/haming123/wego
  • worm.ShowSqlLog
    worm.ShowSqlLog用于控制sql日志的顯示,建議測試環(huán)境下打開sql日志的顯示的開關(guān),這樣可以看到每個數(shù)據(jù)庫操作的sql語句以及執(zhí)行時間,方便快速定位問題。
  • 數(shù)據(jù)庫的支持
    目前worm支持的數(shù)據(jù)庫有:mysql、postgres、sqlite、sqlserver, 本文的例子中采用了mysql數(shù)據(jù)庫。

數(shù)據(jù)庫表與數(shù)據(jù)模型

//建表語句
CREATE TABLE `user` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `name` varchar(30) DEFAULT NULL,
  `age` int(11) DEFAULT NULL,
  `passwd` varchar(32) DEFAULT NULL,
  `created` datetime DEFAULT NULL,
  PRIMARY KEY (`id`)
);

數(shù)據(jù)庫表user對應(yīng)的實體類的定義如下:

type User struct {
    Id          int64       `db:"id;autoincr"`
    Name        string      `db:"name"`
    Age         int64       `db:"age"`
    Passwd      string      `db:"passwd"`
    Created     time.Time    `db:"created;n_update"`
}
func (ent *User) TableName() string {
    return "user"
}

說明:

  • worm使用名稱為"db"的Tag映射數(shù)據(jù)庫字段,"db"后面是字段的名稱,autoincr用于說明該字段是自增ID,n_update用于說明該字段不可用于update語句中。

通過ID來查詢數(shù)據(jù)

若數(shù)據(jù)庫表存在 id 字段,則可以通過ID函數(shù)來查詢一條數(shù)據(jù)據(jù)記錄:

func DemoGetById() {
    var user model.User
    _, err := worm.Model(&user).ID(1).Get()
    if err != nil {
        log.Error(err)
        return
    }
    log.Debug(user)
}
//select id,name,age,passwd,created from user where id=? limit 1

執(zhí)行該函數(shù)后的sql日志為:

[S] select id,name,age,passwd,created from user where id=1 limit 1
[S] DB: time=18.816ms

通過Where函數(shù)來查詢數(shù)據(jù)

Where函數(shù)的使用類似Sprintf函數(shù),函數(shù)的第一個參數(shù)是sql語句(where語句)模板,后面的參數(shù)是模板變量的值。

func DemoWhere() {
    var users []model.User
    err := worm.Model(&model.User{}).Where("id>? and age>?", 1, 10).Find(&users)
    if err != nil {
        log.Error(err)
        return
    }
}
//對應(yīng)的sql語句為:
//select id,name,age,passwd,created from user where id>? and age>?

說明:

  • worm占位符統(tǒng)一使用?,worm會根據(jù)數(shù)據(jù)庫類型,自動替換占位符,例如postgresql數(shù)據(jù)庫把?替換成$1,$2...
  • 可以在Where函數(shù)使用多個變量進(jìn)行查詢,這種方式比較直觀,與數(shù)據(jù)庫查詢中的sql語句的寫法比較類似。但是當(dāng)查詢條件比較多時,建議使用And、OR函數(shù)進(jìn)行適當(dāng)?shù)姆指?,防止將查詢變量與變量的值對應(yīng)錯誤。例如:
func DemoWhere2() {
    var users []model.User
    err := worm.Model(&model.User{}).Where("id>?", 1).And("age>?", 10).Find(&users)
    if err != nil {
        log.Error(err)
        return
    }
}
//對應(yīng)的sql語句為:
//select id,name,age,passwd,created from user where id>? and age>?
  • like查詢的寫法

例如查詢用戶的姓名中包含: demo 的數(shù)據(jù)庫記錄:

func DemoWhereLike() {
  var users []model.User
  err := worm.Model(&model.User{}).Where("name like ?", "%demo%").Find(&users)
  if err != nil {
      log.Error(err)
      return
  }
}
//對應(yīng)的sql語句為:
//select id,name,age,passwd,created from user where name like '%demo%'

XXXIf查詢

有些情況加我們會根據(jù)變量的值來判斷使用使用一個變量來作為查詢條件來查詢書庫,例如,若用戶的姓名不為空時通過用戶姓名來查詢數(shù)據(jù)庫。常規(guī)的寫法如下:

func DemoWhereIf(name string) {
    var users []model.User
    var err error
    if name == "" {
        err = worm.Model(&model.User{}).Find(&users)
    } else {
        err = worm.Model(&model.User{}).Where("name=?", name).Find(&users)
    }
    if err != nil {
        log.Error(err)
        return
    }
}

worm提供了更為簡單的方法(提供了WhereIf、AndIf、OrIf函數(shù))來支持這種查詢需求:

func DemoWhereIf(name string) {
    var users []model.User
    err := worm.Model(&model.User{}).WhereIf(name != "", "name=?", name).Find(&users)
    if err != nil {
        log.Error(err)
        return
    }
}

說明:

  • WhereIf函數(shù)的第一個參數(shù)時一個bool變量,若該變量為true,則會添加查詢條件,否則忽略該查詢條件。

in、not in查詢

worm提供了AndIn、AndNotIn、OrIn、OrNotIn函數(shù)來支持sql語句中的in、not in查詢。例如:

func DemoWhereIn() {
    var users []model.User
    err := worm.Model(&model.User{}).Where("").AndIn("id", 11, 12, 13, 14).Find(&users)
    if err != nil {
        log.Error(err)
        return
    }
}
//對應(yīng)的sql語句為:
select id,name,age,passwd,created from user where id in (?,?,?,?)

XXXIn、XXXNotIn的第二個參數(shù)時一個變長參數(shù),您可以將需要查詢的值作為變長參數(shù)傳入,也可以將查詢的值放到一個數(shù)組中進(jìn)行查詢:

func DemoWhereIn() {
    var users []model.User
    arr_id := []int64{11, 12, 13, 14}
    err := worm.Model(&model.User{}).Where("").AndIn("id", arr_id).Find(&users)
    if err != nil {
        log.Error(err)
        return
    }
}

說明:

  • 若使用數(shù)組方式,則可變長參數(shù)智能時一個參數(shù),并且該參數(shù)為數(shù)組類型。

嵌套查詢語句

worm支持嵌套查詢語句,例如查詢?yōu)椋?nbsp;age>10 and (name='demo1' or name='demo2') , 則使用worm的方式如下:

func DemoWhereExp() {
    var users []model.User
    sqlw := worm.SQLW("name=?", "demo1").Or("name=?", "demo2")
    err := worm.Model(&model.User{}).Where("age>?", 10).AndExp(sqlw).Find(&users)
    if err != nil {
        log.Error(err)
        return
    }
}
//對應(yīng)的sql語句為:
//select id,name,age,passwd,created from user where age>? and (name=? or name=?)

Limit與Offset

在MySQL語句中可以使用Limit與Offset來查詢數(shù)據(jù)庫,這種查詢通常用于WEB的分頁查詢中。worm也支持mysql的Limit與Offset語句:

func DemoQueryPage(plen int64, pcur int64) {
    var users []model.User
    err := worm.Model(&model.User{}).Where("age>?", 10).Limit(plen).Offset(plen * pcur).Find(&users)
    if err != nil {
        log.Error(err)
        return
    }
}
//對應(yīng)的sql語句為:
//select id,name,age,passwd,created from user where age>? limit ?, ?

orderby查詢

OrderBy函數(shù)對應(yīng)sql語句中的order by語句:

func DemoQueryOrderBy(orderby string) {
    var users []model.User
    err := worm.Model(&model.User{}).Where("age>?", 10).OrderBy(orderby).Find(&users)
    if err != nil {
        log.Error(err)
        return
    }
}
//對應(yīng)的sql語句為:
//select id,name,age,passwd,created from user where age>? order by created desc

到此這篇關(guān)于Go語言O(shè)RM包中使用worm構(gòu)造查詢條件的文章就介紹到這了,更多相關(guān)Go語言O(shè)RM內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Go語言操作MySql數(shù)據(jù)庫的詳細(xì)指南

    Go語言操作MySql數(shù)據(jù)庫的詳細(xì)指南

    數(shù)據(jù)的持久化是程序中必不可少的,所以編程語言中對數(shù)據(jù)庫的操作是非常重要的一塊,這篇文章主要給大家介紹了關(guān)于Go語言操作MySql數(shù)據(jù)庫的相關(guān)資料,需要的朋友可以參考下
    2023-10-10
  • Golang測試框架goconvey進(jìn)行單元測試流程介紹

    Golang測試框架goconvey進(jìn)行單元測試流程介紹

    goconvey是一款針對Golang的測試框架,可以管理和運(yùn)行測試用例,同時提供了豐富的斷言函數(shù),并支持很多Web界面特性,這篇文章主要介紹了使用goconvey進(jìn)行單元測試流程,感興趣的同學(xué)可以參考下文
    2023-05-05
  • Go語言到底有沒有引用傳參(對比 C++ )

    Go語言到底有沒有引用傳參(對比 C++ )

    這篇文章主要介紹了Go 到底有沒有引用傳參(對比 C++ ),需要的朋友可以參考下
    2017-09-09
  • golang并發(fā)編程的實現(xiàn)

    golang并發(fā)編程的實現(xiàn)

    這篇文章主要介紹了golang并發(fā)編程的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • Golang文件讀寫操作詳情

    Golang文件讀寫操作詳情

    這篇文章主要介紹了Golang文件讀寫操作詳情,文件是數(shù)據(jù)源(保存數(shù)據(jù)的地方)的一種,文件最主要的作用就是保存數(shù)據(jù),文件在程序中是以流的形式來操作的,更多詳細(xì)內(nèi)容需要的朋友可以參考一下
    2022-07-07
  • Golang使用JWT進(jìn)行認(rèn)證和加密的示例詳解

    Golang使用JWT進(jìn)行認(rèn)證和加密的示例詳解

    JWT是一個簽名的JSON對象,通常用作Oauth2的Bearer?token,JWT包括三個用.分割的部分。本文將利用JWT進(jìn)行認(rèn)證和加密,感興趣的可以了解一下
    2023-02-02
  • Go語言安裝和GoLand2021最全超詳細(xì)安裝教程

    Go語言安裝和GoLand2021最全超詳細(xì)安裝教程

    Go語言和GoLand的關(guān)系好比于java和idea、python和pycharm,因此我們需要先安裝好Go語言后才能安裝GoLand。它的安裝和java,python的安裝大同小異,好了,下面給大家?guī)砹薌oLand2021安裝教程,需要的朋友參考下吧
    2021-08-08
  • 淺談Golang 切片(slice)擴(kuò)容機(jī)制的原理

    淺談Golang 切片(slice)擴(kuò)容機(jī)制的原理

    我們知道 Golang 切片在容量不足的情況下會進(jìn)行擴(kuò)容,擴(kuò)容的原理是怎樣的呢,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • 解決golang中container/list包中的坑

    解決golang中container/list包中的坑

    這篇文章主要介紹了解決golang中container/list包中的坑,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • 在Go語言項目中使用Zap日志庫的操作過程

    在Go語言項目中使用Zap日志庫的操作過程

    本文將先介紹Go語言原生的日志庫的使用,然后詳細(xì)介紹非常流行的Uber開源的zap日志庫,同時會介紹如何搭配·Lumberjack·實現(xiàn)日志的切割和歸檔,對Go使用Zap日志庫相關(guān)知識感興趣的朋友一起看看吧
    2024-03-03

最新評論