转供电电费服务系统(后端项目)
Go to file
2022-09-28 17:13:26 +08:00
.vscode build(debug):增加允许在VSCode中使用jsoniter进行编译的功能。 2022-09-19 08:52:25 +08:00
assets enhance(model):调整物业附加费、公示报表部分的数据结构模型,以及数据库迁移脚本。 2022-09-21 15:36:03 +08:00
cache refactor(db):切换数据库驱动为pq,数据控制库为bun,更改Redis连接的名称。 2022-09-15 10:11:27 +08:00
config fix(settings):改进一个配置中的类型定义,方便在其他函数中使用。 2022-08-12 14:45:19 +08:00
controller refactor(controller):完成部分控制器向fiber框架的迁移。 2022-09-28 17:13:26 +08:00
excel enhance(model):调整物业附加费、公示报表部分的数据结构模型,以及数据库迁移脚本。 2022-09-21 15:36:03 +08:00
exceptions feat(report):完成获取公示用数据接口的功能。 2022-08-24 11:26:17 +08:00
global refactor(db):切换底层数据库驱动。 2022-09-21 08:47:24 +08:00
logger refactor(app):基本完成基础服务框架的功能构建。 2022-09-28 16:01:16 +08:00
migration fix(migrate):修正数据库迁移脚本中的错误。 2022-09-21 16:49:30 +08:00
model enhance(enduser):精简终端表计统计所使用的查询语句。 2022-09-23 10:26:36 +08:00
response refactor(controller):完成部分控制器向fiber框架的迁移。 2022-09-28 17:13:26 +08:00
router refactor(app):基本完成基础服务框架的功能构建。 2022-09-28 16:01:16 +08:00
security refactor(app):基本完成基础服务框架的功能构建。 2022-09-28 16:01:16 +08:00
service fix(deprecates):继续清理已经删除的表计摊薄字段。 2022-09-23 15:53:56 +08:00
tools enhance(utils):增加对切片进行分区的工具函数。 2022-09-20 17:12:20 +08:00
.gitignore chore(project):增加版本库文件屏蔽,加入运行配置。 2022-09-15 09:05:38 +08:00
Dockerfile enhance(docker):容器化配置增加日志保存目录卷。 2022-09-08 16:16:02 +08:00
go.mod refactor(app):基本完成基础服务框架的功能构建。 2022-09-28 16:01:16 +08:00
go.sum refactor(app):基本完成基础服务框架的功能构建。 2022-09-28 16:01:16 +08:00
main.go refactor(app):基本完成基础服务框架的功能构建。 2022-09-28 16:01:16 +08:00
Readme.md doc(readme):更新数据嵌套的说明。 2022-09-19 14:38:48 +08:00
regions.csv feat(region):完成行政区划获取的功能。 2022-08-13 20:11:16 +08:00
settings.yaml enhance(config):调整数据库连接池配置。 2022-09-19 22:26:27 +08:00

转供电电费服务项目(后端项目)

该项目为华昌宝能发布的采用众包模式承接的小型Web服务系统项目。

项目采用以下技术框架:

  • Golang 1.19
  • Gin
  • Xorm

项目详细设计方案见详细设计方案,该设计方案未经许可,禁止私自修改。

项目任务分配与状态概览表见任务概况

项目代码编写要点

数据库访问

项目所式的数据库框架采用的是Bun该框架采用贴近SQL语句的数据库方式但是在使用过程中需注意以下几点。

  1. 要执行一个语句,必须提供一个context.Context类型的上下文,推荐采用context.WithTimeout()生成。上下文中携带的超时时间应该能覆盖超时时间所需要运行的全部语句。
  2. 语句中用来指定操作目标数据表的Model()方法其接受的是一个目标变量的地址如果传入的是一个slice那么就一定需要使用&获取其地址,如果是使用&struct{}或者new()初始化的,则可以直接作为参数传入。
  3. 数据库中的时间字段都是带有时区的但是bun中都是使用UTC时间的对于数据库中timestamptz类型的字段,可以正常的按照数据库配置的时区保存时间,但是对于没有携带时区的date类型,就不能直接向其中传入time.Time类型的参数了,必须手工将其转化为字符串形式。
  4. 使用Relation关联获取其他数据表内容的时候Relation()提及的数据表中配置的alias名称将不起作用语句中的数据别名实际上是被关联字段名称的snake_case形式。
  5. 需要进行嵌套Relation选择的时候嵌套的Relation可以采用Relation("A.B")的形式来指示使用数据模型A中的Relation B。
  6. 如果需要只从Relation关联数据表中选择一部分字段不能直接在主查询语句中使用Column()方法,必须在Relation()方法的第二个参数中声明。
  7. 如果需要对Relation关联表中的字段设置Where条件子句,那么就必须使用relation_name__column_name的双下划线字段选择形式,直接在Relation()方法中设定Where子句行不通。
  8. 定义数据模型的时候数据字段尽可能不要提供默认值如果确实需要默认值要首先考虑在数据库中定义默认值约束其次选择使用Hook来赋予默认值。直接定义在struct tag中的默认值可能会造成bun形成查询语句时意外的空值。