Go 语言实现的 ORM 库 Toyorm

码农软件 · 软件分类 · ORM/持久层框架 · 2019-09-22 18:44:28

软件介绍

使用 go 实现的 orm 库,用 go 的结构体与数据库表关联,来简化各种数据库操作。

特性:

  1. 语句与查询:支持Insert/Replace/Find/Delete/Update等操作

  2. 条件:支持Limit/Offset/Where/Group by/Order by 

  3. 支持事务

  4. 预加载:基于表主键的关联查询 支持BelongTo/OneToOne/OneToMany/ManyToMany 4种模式

  5. 预加载条件:操作预加载的表和操作基本表一样

  6. 预加载查询聚合:对于预加载字段会优化成Where id in [...]的查询,一个预加载字段永远只占一个Select

  7. Result:生成数据库语句报告和语句导致的错误,支持预加载模式

  8. 上下文结构,可以在数据库语句逻辑中插入自定义逻辑

  9. Collection:多数据库操作,该模式下的数据必须拥有主键,auto_increment模式失效

  10. toy-doctor(检查FieldSelection参数错误)

支持 mysql, sqlite3

go版本 >1.9

安装

go get github.com/bigpigeon/toyorm

快速开始

package main

import (
"github.com/bigpigeon/toyorm"
_ "github.com/mattn/go-sqlite3"
. "unsafe"
)

type Product struct {
toyorm.ModelDefault
Name  string
Price int
}

func panicErr(err error) {
if err != nil {
panic(err)
}
}

func main() {
toy, err := toyorm.Open("sqlite3", "mydb.db")
panicErr(err)
defer func() {
err := toy.Close()
panicErr(err)
}()
// create ToyBrick
brick := toy.Model(&Product{}).Debug()
// create table
_, err = brick.CreateTable()
panicErr(err)

// insert product
_, err = brick.Insert(&Product{
Name:  "apple",
Price: 22,
})
panicErr(err)
// update product
_, err = brick.Where("=", Offsetof(Product{}.Name), "apple").Update(Product{Price: 23})
panicErr(err)
var product Product
// find
_, err = brick.Find(&product)
panicErr(err)
// delete
_, err = brick.Delete(&product)
panicErr(err)
}

本文地址:https://codercto.com/soft/d/15175.html

B端产品经理必修课

B端产品经理必修课

李宽 / 电子工业出版社 / 2018-9 / 59

《B端产品经理必修课:从业务逻辑到产品构建全攻略》主要讲述了“单个产品管理流程”,以展示B 端产品经理的工作方法及B 端产品的设计方法。《B端产品经理必修课:从业务逻辑到产品构建全攻略》分为三个部分。第一部分主要讲述的是B 端产品经理的工作流程和定义(即单个产品管理流程),以及从事B 端产品经理的职业现状和规划,还包括设计B 端产品时需要了解的指导思想。第二部分是通过各个章节来讲述单个产品管理流程......一起来看看 《B端产品经理必修课》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具