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.

utils.go 1.3 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. package db
  2. import (
  3. "database/sql"
  4. "github.com/jmoiron/sqlx"
  5. "gitlink.org.cn/cloudream/common/utils/math2"
  6. )
  7. const (
  8. maxPlaceholderCount = 65535
  9. )
  10. func BatchNamedExec[T any](ctx SQLContext, sql string, argCnt int, arr []T, callback func(sql.Result) bool) error {
  11. if argCnt == 0 {
  12. ret, err := ctx.NamedExec(sql, arr)
  13. if err != nil {
  14. return err
  15. }
  16. if callback != nil {
  17. callback(ret)
  18. }
  19. return nil
  20. }
  21. batchSize := maxPlaceholderCount / argCnt
  22. for len(arr) > 0 {
  23. curBatchSize := math2.Min(batchSize, len(arr))
  24. ret, err := ctx.NamedExec(sql, arr[:curBatchSize])
  25. if err != nil {
  26. return err
  27. }
  28. if callback != nil && !callback(ret) {
  29. return nil
  30. }
  31. arr = arr[curBatchSize:]
  32. }
  33. return nil
  34. }
  35. func BatchNamedQuery[T any](ctx SQLContext, sql string, argCnt int, arr []T, callback func(*sqlx.Rows) bool) error {
  36. if argCnt == 0 {
  37. ret, err := ctx.NamedQuery(sql, arr)
  38. if err != nil {
  39. return err
  40. }
  41. if callback != nil {
  42. callback(ret)
  43. }
  44. return nil
  45. }
  46. batchSize := maxPlaceholderCount / argCnt
  47. for len(arr) > 0 {
  48. curBatchSize := math2.Min(batchSize, len(arr))
  49. ret, err := ctx.NamedQuery(sql, arr[:curBatchSize])
  50. if err != nil {
  51. return err
  52. }
  53. if callback != nil && !callback(ret) {
  54. return nil
  55. }
  56. arr = arr[curBatchSize:]
  57. }
  58. return nil
  59. }

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