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

common.go 1.6KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. // Copyright 2022 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package db
  4. import (
  5. "strings"
  6. "code.gitea.io/gitea/modules/setting"
  7. "code.gitea.io/gitea/modules/util"
  8. "xorm.io/builder"
  9. )
  10. // BuildCaseInsensitiveLike returns a condition to check if the given value is like the given key case-insensitively.
  11. // Handles especially SQLite correctly as UPPER there only transforms ASCII letters.
  12. func BuildCaseInsensitiveLike(key, value string) builder.Cond {
  13. if setting.Database.Type.IsSQLite3() {
  14. return builder.Like{"UPPER(" + key + ")", util.ToUpperASCII(value)}
  15. }
  16. return builder.Like{"UPPER(" + key + ")", strings.ToUpper(value)}
  17. }
  18. // BuildCaseInsensitiveIn returns a condition to check if the given value is in the given values case-insensitively.
  19. // Handles especially SQLite correctly as UPPER there only transforms ASCII letters.
  20. func BuildCaseInsensitiveIn(key string, values []string) builder.Cond {
  21. uppers := make([]string, 0, len(values))
  22. if setting.Database.Type.IsSQLite3() {
  23. for _, value := range values {
  24. uppers = append(uppers, util.ToUpperASCII(value))
  25. }
  26. } else {
  27. for _, value := range values {
  28. uppers = append(uppers, strings.ToUpper(value))
  29. }
  30. }
  31. return builder.In("UPPER("+key+")", uppers)
  32. }
  33. // BuilderDialect returns the xorm.Builder dialect of the engine
  34. func BuilderDialect() string {
  35. switch {
  36. case setting.Database.Type.IsMySQL():
  37. return builder.MYSQL
  38. case setting.Database.Type.IsSQLite3():
  39. return builder.SQLITE
  40. case setting.Database.Type.IsPostgreSQL():
  41. return builder.POSTGRES
  42. case setting.Database.Type.IsMSSQL():
  43. return builder.MSSQL
  44. default:
  45. return ""
  46. }
  47. }