mysql.go 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. package mysql
  2. import (
  3. "fmt"
  4. "github.com/xinliangnote/go-gin-api/pkg/errors"
  5. "gorm.io/driver/mysql"
  6. "gorm.io/gorm"
  7. "gorm.io/gorm/schema"
  8. )
  9. var _ Repo = (*dbRepo)(nil)
  10. type Repo interface {
  11. i()
  12. GetDb() *gorm.DB
  13. DbClose() error
  14. }
  15. type dbRepo struct {
  16. DbConn *gorm.DB
  17. }
  18. func New(dbAddr, dbUser, dbPass, dbName string) (Repo, error) {
  19. dsn := fmt.Sprintf("%s:%s@tcp(%s)/%s?charset=utf8mb4&parseTime=%t&loc=%s",
  20. dbUser,
  21. dbPass,
  22. dbAddr,
  23. dbName,
  24. true,
  25. "Local")
  26. db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{
  27. NamingStrategy: schema.NamingStrategy{
  28. SingularTable: true,
  29. },
  30. //Logger: logger.Default.LogMode(logger.Info), // 日志配置
  31. })
  32. if err != nil {
  33. return nil, errors.Wrap(err, fmt.Sprintf("[db connection failed] Database name: %s", dbName))
  34. }
  35. db.Set("gorm:table_options", "CHARSET=utf8mb4")
  36. return &dbRepo{
  37. DbConn: db,
  38. }, nil
  39. }
  40. func (d *dbRepo) i() {}
  41. func (d *dbRepo) GetDb() *gorm.DB {
  42. return d.DbConn
  43. }
  44. func (d *dbRepo) DbClose() error {
  45. sqlDB, err := d.DbConn.DB()
  46. if err != nil {
  47. return err
  48. }
  49. return sqlDB.Close()
  50. }