db.go 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. package mokuai
  2. import (
  3. "fmt"
  4. "github.com/gohouse/converter"
  5. )
  6. //转换数据库schema到go struct
  7. //dsn 数据库格式:"user:password@/dbname 如 user:mima@tcp(127.0.0.1:3306)/dbname"
  8. //path 生成的结构体保存路径
  9. //pacName 生成struct的包名(默认为空的话, 则取名为: package model)
  10. func GormT(dsn string, path string, pacName string) bool {
  11. // 初始化
  12. t2t := converter.NewTable2Struct()
  13. // 个性化配置
  14. t2t.Config(&converter.T2tConfig{
  15. // 如果字段首字母本来就是大写, 就不添加tag, 默认false添加, true不添加
  16. RmTagIfUcFirsted: false,
  17. // tag的字段名字是否转换为小写, 如果本身有大写字母的话, 默认false不转
  18. TagToLower: false,
  19. // 字段首字母大写的同时, 是否要把其他字母转换为小写,默认false不转换
  20. UcFirstOnly: false,
  21. //// 每个struct放入单独的文件,默认false,放入同一个文件(暂未提供)
  22. })
  23. // 开始迁移转换
  24. err := t2t.
  25. // 是否添加json tag
  26. EnableJsonTag(true).
  27. // 生成struct的包名(默认为空的话, 则取名为: package model)
  28. PackageName(pacName).
  29. // tag字段的key值,默认是orm
  30. TagKey("gorm").
  31. // 生成的结构体保存路径
  32. SavePath(path).
  33. // 数据库dsn,这里可以使用 t2t.DB() 代替,参数为 *sql.DB 对象
  34. Dsn(dsn).
  35. // 执行
  36. Run()
  37. if err != nil {
  38. fmt.Println(err)
  39. return false
  40. }
  41. return true
  42. }