You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

db.go 1.9 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. package db
  2. import (
  3. _ "github.com/go-sql-driver/mysql"
  4. "github.com/sirupsen/logrus"
  5. "gorm.io/driver/mysql"
  6. "gorm.io/gorm"
  7. )
  8. type DB struct {
  9. db *gorm.DB
  10. }
  11. func NewDB(cfg *Config) (*DB, error) {
  12. mydb, err := gorm.Open(mysql.Open(cfg.MakeSourceString()), &gorm.Config{})
  13. if err != nil {
  14. logrus.Fatalf("failed to connect to database: %v", err)
  15. }
  16. return &DB{
  17. db: mydb,
  18. }, nil
  19. }
  20. func (db *DB) DoTx(do func(tx SQLContext) error) error {
  21. return db.db.Transaction(func(tx *gorm.DB) error {
  22. return do(SQLContext{tx})
  23. })
  24. }
  25. func DoTx01[R any](db *DB, do func(tx SQLContext) (R, error)) (R, error) {
  26. var ret R
  27. err := db.db.Transaction(func(tx *gorm.DB) error {
  28. var err error
  29. ret, err = do(SQLContext{tx})
  30. return err
  31. })
  32. return ret, err
  33. }
  34. func DoTx02[R any](db *DB, do func(tx SQLContext) (R, error)) (R, error) {
  35. var ret R
  36. err := db.db.Transaction(func(tx *gorm.DB) error {
  37. var err error
  38. ret, err = do(SQLContext{tx})
  39. return err
  40. })
  41. return ret, err
  42. }
  43. func DoTx12[T any, R any](db *DB, do func(tx SQLContext, t T) (R, error), t T) (R, error) {
  44. var ret R
  45. err := db.db.Transaction(func(tx *gorm.DB) error {
  46. var err error
  47. ret, err = do(SQLContext{tx}, t)
  48. return err
  49. })
  50. return ret, err
  51. }
  52. func DoTx22[T1 any, T2 any, R any](db *DB, do func(tx SQLContext, t1 T1, t2 T2) (R, error), t1 T1, t2 T2) (R, error) {
  53. var ret R
  54. err := db.db.Transaction(func(tx *gorm.DB) error {
  55. var err error
  56. ret, err = do(SQLContext{tx}, t1, t2)
  57. return err
  58. })
  59. return ret, err
  60. }
  61. func DoTx32[T1 any, T2 any, T3 any, R any](db *DB, do func(tx SQLContext, t1 T1, t2 T2, t3 T3) (R, error), t1 T1, t2 T2, t3 T3) (R, error) {
  62. var ret R
  63. err := db.db.Transaction(func(tx *gorm.DB) error {
  64. var err error
  65. ret, err = do(SQLContext{tx}, t1, t2, t3)
  66. return err
  67. })
  68. return ret, err
  69. }
  70. type SQLContext struct {
  71. *gorm.DB
  72. }
  73. func (db *DB) DefCtx() SQLContext {
  74. return SQLContext{db.db}
  75. }

本项目旨在将云际存储公共基础设施化,使个人及企业可低门槛使用高效的云际存储服务(安装开箱即用云际存储客户端即可,无需关注其他组件的部署),同时支持用户灵活便捷定制云际存储的功能细节。