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

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  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[R1, R2 any](db *DB, do func(tx SQLContext) (R1, R2, error)) (R1, R2, error) {
  35. var r1 R1
  36. var r2 R2
  37. err := db.db.Transaction(func(tx *gorm.DB) error {
  38. var err error
  39. r1, r2, err = do(SQLContext{tx})
  40. return err
  41. })
  42. return r1, r2, err
  43. }
  44. func DoTx12[T any, R any](db *DB, do func(tx SQLContext, t T) (R, error), t T) (R, error) {
  45. var ret R
  46. err := db.db.Transaction(func(tx *gorm.DB) error {
  47. var err error
  48. ret, err = do(SQLContext{tx}, t)
  49. return err
  50. })
  51. return ret, err
  52. }
  53. 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) {
  54. var ret R
  55. err := db.db.Transaction(func(tx *gorm.DB) error {
  56. var err error
  57. ret, err = do(SQLContext{tx}, t1, t2)
  58. return err
  59. })
  60. return ret, err
  61. }
  62. 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) {
  63. var ret R
  64. err := db.db.Transaction(func(tx *gorm.DB) error {
  65. var err error
  66. ret, err = do(SQLContext{tx}, t1, t2, t3)
  67. return err
  68. })
  69. return ret, err
  70. }
  71. type SQLContext struct {
  72. *gorm.DB
  73. }
  74. func (db *DB) DefCtx() SQLContext {
  75. return SQLContext{db.db}
  76. }

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