update.go 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. // Copyright 2018 Huan Du. All rights reserved.
  2. // Licensed under the MIT license that can be found in the LICENSE file.
  3. package sqlbuilder
  4. import (
  5. "bytes"
  6. "fmt"
  7. "strings"
  8. )
  9. // NewUpdateBuilder creates a new UPDATE builder.
  10. func NewUpdateBuilder() *UpdateBuilder {
  11. return DefaultFlavor.NewUpdateBuilder()
  12. }
  13. func newUpdateBuilder() *UpdateBuilder {
  14. args := &Args{}
  15. return &UpdateBuilder{
  16. Cond: Cond{
  17. Args: args,
  18. },
  19. args: args,
  20. }
  21. }
  22. // UpdateBuilder is a builder to build UPDATE.
  23. type UpdateBuilder struct {
  24. Cond
  25. table string
  26. assignments []string
  27. whereExprs []string
  28. args *Args
  29. }
  30. // Update sets table name in UPDATE.
  31. func (ub *UpdateBuilder) Update(table string) *UpdateBuilder {
  32. ub.table = Escape(table)
  33. return ub
  34. }
  35. // Set sets the assignements in SET.
  36. func (ub *UpdateBuilder) Set(assignment ...string) *UpdateBuilder {
  37. ub.assignments = assignment
  38. return ub
  39. }
  40. // SetMore appends the assignements in SET.
  41. func (ub *UpdateBuilder) SetMore(assignment ...string) *UpdateBuilder {
  42. ub.assignments = append(ub.assignments, assignment...)
  43. return ub
  44. }
  45. // Where sets expressions of WHERE in UPDATE.
  46. func (ub *UpdateBuilder) Where(andExpr ...string) *UpdateBuilder {
  47. ub.whereExprs = append(ub.whereExprs, andExpr...)
  48. return ub
  49. }
  50. // Assign represents SET "field = value" in UPDATE.
  51. func (ub *UpdateBuilder) Assign(field string, value interface{}) string {
  52. return fmt.Sprintf("%s = %s", Escape(field), ub.args.Add(value))
  53. }
  54. // Incr represents SET "field = field + 1" in UPDATE.
  55. func (ub *UpdateBuilder) Incr(field string) string {
  56. f := Escape(field)
  57. return fmt.Sprintf("%s = %s + 1", f, f)
  58. }
  59. // Decr represents SET "field = field - 1" in UPDATE.
  60. func (ub *UpdateBuilder) Decr(field string) string {
  61. f := Escape(field)
  62. return fmt.Sprintf("%s = %s - 1", f, f)
  63. }
  64. // Add represents SET "field = field + value" in UPDATE.
  65. func (ub *UpdateBuilder) Add(field string, value interface{}) string {
  66. f := Escape(field)
  67. return fmt.Sprintf("%s = %s + %s", f, f, ub.args.Add(value))
  68. }
  69. // Sub represents SET "field = field - value" in UPDATE.
  70. func (ub *UpdateBuilder) Sub(field string, value interface{}) string {
  71. f := Escape(field)
  72. return fmt.Sprintf("%s = %s - %s", f, f, ub.args.Add(value))
  73. }
  74. // Mul represents SET "field = field * value" in UPDATE.
  75. func (ub *UpdateBuilder) Mul(field string, value interface{}) string {
  76. f := Escape(field)
  77. return fmt.Sprintf("%s = %s * %s", f, f, ub.args.Add(value))
  78. }
  79. // Div represents SET "field = field / value" in UPDATE.
  80. func (ub *UpdateBuilder) Div(field string, value interface{}) string {
  81. f := Escape(field)
  82. return fmt.Sprintf("%s = %s / %s", f, f, ub.args.Add(value))
  83. }
  84. // String returns the compiled UPDATE string.
  85. func (ub *UpdateBuilder) String() string {
  86. s, _ := ub.Build()
  87. return s
  88. }
  89. // Build returns compiled UPDATE string and args.
  90. // They can be used in `DB#Query` of package `database/sql` directly.
  91. func (ub *UpdateBuilder) Build() (sql string, args []interface{}) {
  92. return ub.BuildWithFlavor(ub.args.Flavor)
  93. }
  94. // BuildWithFlavor returns compiled UPDATE string and args with flavor and initial args.
  95. // They can be used in `DB#Query` of package `database/sql` directly.
  96. func (ub *UpdateBuilder) BuildWithFlavor(flavor Flavor, initialArg ...interface{}) (sql string, args []interface{}) {
  97. buf := &bytes.Buffer{}
  98. buf.WriteString("UPDATE ")
  99. buf.WriteString(ub.table)
  100. buf.WriteString(" SET ")
  101. buf.WriteString(strings.Join(ub.assignments, ", "))
  102. if len(ub.whereExprs) > 0 {
  103. buf.WriteString(" WHERE ")
  104. buf.WriteString(strings.Join(ub.whereExprs, " AND "))
  105. }
  106. return ub.args.CompileWithFlavor(buf.String(), flavor, initialArg...)
  107. }
  108. // SetFlavor sets the flavor of compiled sql.
  109. func (ub *UpdateBuilder) SetFlavor(flavor Flavor) (old Flavor) {
  110. old = ub.args.Flavor
  111. ub.args.Flavor = flavor
  112. return
  113. }