Top 5.8% dependent packages on proxy.golang.org
Top 4.7% dependent repos on proxy.golang.org
Top 7.4% forks on proxy.golang.org
proxy.golang.org : github.com/issue9/orm/v5
Package orm 一个简单小巧的 orm 实现方案 目前内置了对以下数据库的支持: 其它数据库,用户可以通过实现 Dialect 接口,来实现相应的支持。 初始化: 默认情况下,orm 包并不会加载任何数据库的实例。所以想要用哪个数据库,需要手动初始化: 占位符 SQL 语句可以使用 {} 包含一个关键字,使其它成为普通列名,如: 在实际执行时,相关的占位符就会被替换成与当前环境想容的实例, 如在数据库为 mysql 时,会被替换成以下语句,然后再执行: DB.Query(),DB.Exec(),DB.Prepare().DB.Where() 及 Tx 与之对应的函数都可以使用占位符。 Model 不能指定占位符,它们默认总会使用占位符,且无法取消。 Model: orm 包通过 struct tag 来描述 model 在数据库中的结构。大概格式如下: 目前支持以下的 struct tag: ApplyModeler: 用于将一个对象转换成 Model 对象时执行的函数,给予用户修改 Model 的机会, 在 ApplyModeler 中可以修改任意模型的内容,所以也可以由 ApplyModeler 代替 struct tag 的操作。 约束名: index、unique、check 和 fk 都是可以指定约束名的,在表中,约束名必须是唯一的, 即便是不同类型的约束,比如已经有一个 unique 的约束名叫作 name,那么其它类 型的约束,就不能再取这个名称了。 部分数据库(比如 postgres)可能要求约束名是整个数据库唯一的, 为了统一,在 ORM 中所有数据都强制约束名全局(数据库)唯一。 如何使用: Create: 可以通过 DB.Create() 或是 Tx.Create() 创建一张表。 Update: Delete: Insert: Select: Query/Exec: 事务: 默认的 DB 是不支持事务的,若需要事务支持,则需要调用 DB.Begin() 返回事务对象 Tx,当然并不是所有的数据库都支持事务操作的。 Tx 拥有一组与 DB 相同的接口。
Registry
-
Source
- Documentation
- JSON
purl: pkg:golang/github.com/issue9/orm/v5
Keywords:
database
, go
, golang
, object-relational-mapper
, orm
, orm-library
License: MIT
Latest release: over 1 year ago
First release: about 3 years ago
Namespace: github.com/issue9/orm
Dependent packages: 1
Dependent repositories: 1
Stars: 11 on GitHub
Forks: 7 on GitHub
See more repository details: repos.ecosyste.ms
Last synced: 17 days ago