mdm.go 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199
  1. package gn
  2. import (
  3. "eta_gn/eta_bridge/global"
  4. "eta_gn/eta_bridge/utils"
  5. "fmt"
  6. "strings"
  7. "time"
  8. )
  9. type MDM_COMSTRU struct {
  10. Id int `gorm:"column:Id;primaryKey;autoIncrement" json:"-"`
  11. MainFieldComstruCode string `gorm:"column:Main_Field_Comstru_Code" json:"Main_Field_Comstru_Code"`
  12. MainFieldComstruCodeHR string `gorm:"column:Main_Field_Comstru_Code_HR" json:"Main_Field_Comstru_Code_HR"`
  13. MainFieldComstruTypeHR string `gorm:"column:Main_Field_Comstru_Type_HR" json:"Main_Field_Comstru_Type_HR"`
  14. ZDWLX string `gorm:"column:ZDWLX" json:"ZDWLX"`
  15. MainFieldComstruNameHR string `gorm:"column:Main_Field_Comstru_Name_HR" json:"Main_Field_Comstru_Name_HR"`
  16. MainFieldComstruShortNameHR string `gorm:"column:Main_Field_Comstru_Short_Name_HR" json:"Main_Field_Comstru_Short_Name_HR"`
  17. MainFieldParentAdminComstruCodeHR string `gorm:"column:Main_Field_ParentAdmin_Comstru_Code_HR" json:"Main_Field_ParentAdmin_Comstru_Code_HR"`
  18. MainFieldParentAdminComstruCode string `gorm:"column:Main_Field_ParentAdmin_Comstru_Code" json:"Main_Field_ParentAdmin_Comstru_Code"`
  19. MainFieldParentAdminComstruName string `gorm:"column:Main_Field_ParentAdmin_Comstru_Name" json:"Main_Field_ParentAdmin_Comstru_Name"`
  20. MainFieldCompanyLevel string `gorm:"column:Main_Field_Company_Level" json:"Main_Field_Company_Level"`
  21. MainFieldSecondcomstrucodehr string `gorm:"column:Main_Field_Secondcomstrucodehr" json:"Main_Field_Secondcomstrucodehr"`
  22. MainFieldShBusinessType string `gorm:"column:Main_Field_Sh_Business_Type" json:"Main_Field_Sh_Business_Type"`
  23. MainFieldYZGDWZCNDGX string `gorm:"column:Main_Field_YZGDWZCNDGX" json:"Main_Field_YZGDWZCNDGX"`
  24. MainFieldOrderHR string `gorm:"column:Main_Field_Order_HR" json:"Main_Field_Order_HR"`
  25. MainFieldCompanyCode string `gorm:"column:Main_Field_Company_Code" json:"Main_Field_Company_Code"`
  26. MainFieldCompanyChain string `gorm:"column:Main_Field_Company_Chain" json:"Main_Field_Company_Chain"`
  27. MainFieldPARENTCOMPANYVIRTUAL string `gorm:"column:Main_Field_PARENTCOMPANYVIRTUAL" json:"Main_Field_PARENTCOMPANYVIRTUAL"`
  28. ZQYZT string `gorm:"column:ZQYZT" json:"ZQYZT"`
  29. CreateTime time.Time `gorm:"column:create_time" json:"create_time"`
  30. ModifyTime time.Time `gorm:"column:modify_time" json:"modify_time"`
  31. }
  32. func (m *MDM_COMSTRU) TableName() string {
  33. return "MDM_COMSTRU"
  34. }
  35. func (m *MDM_COMSTRU) Create() (err error) {
  36. err = global.MYSQL["hz_eta"].Create(m).Error
  37. return
  38. }
  39. func (m *MDM_COMSTRU) Update(cols []string) (err error) {
  40. err = global.MYSQL["hz_eta"].Select(cols).Updates(m).Error
  41. return
  42. }
  43. func (m *MDM_COMSTRU) GetItemByCondition(condition string, pars []interface{}) (item *MDM_COMSTRU, err error) {
  44. sql := fmt.Sprintf(`SELECT * FROM %s WHERE 1=1 %s LIMIT 1`, m.TableName(), condition)
  45. err = global.MYSQL["hz_eta"].Raw(sql, pars...).First(&item).Error
  46. return
  47. }
  48. func (m *MDM_COMSTRU) GetItemsByCondition(condition string, pars []interface{}, fieldArr []string, orderRule string) (items []*MDM_COMSTRU, err error) {
  49. fields := strings.Join(fieldArr, ",")
  50. if len(fieldArr) == 0 {
  51. fields = `*`
  52. }
  53. order := ``
  54. if orderRule != "" {
  55. order = ` ORDER BY ` + orderRule
  56. }
  57. sql := fmt.Sprintf(`SELECT %s FROM %s WHERE 1=1 %s %s`, fields, m.TableName(), condition, order)
  58. err = global.MYSQL["hz_eta"].Raw(sql, pars...).Find(&items).Error
  59. return
  60. }
  61. type MDM_EMPLOYEE struct {
  62. Id int `gorm:"column:Id;primaryKey;autoIncrement" json:"-"`
  63. MainFieldEmployeeCode string `gorm:"column:Main_Field_Employee_Code" json:"Main_Field_Employee_Code"`
  64. MainFieldEmployeeFirstName string `gorm:"column:Main_Field_Employee_FirstName" json:"Main_Field_Employee_FirstName"`
  65. MainFieldEmployeeLastName string `gorm:"column:Main_Field_Employee_LastName" json:"Main_Field_Employee_LastName"`
  66. MainFieldGender string `gorm:"column:Main_Field_Gender" json:"Main_Field_Gender"`
  67. MainFieldEmpolyeeGroup string `gorm:"column:Main_Field_Empolyee_Group" json:"Main_Field_Empolyee_Group"`
  68. MainFieldOfficeTelephone string `gorm:"column:Main_Field_Office_Telephone" json:"Main_Field_Office_Telephone"`
  69. MainFieldDateType string `gorm:"column:Main_Field_Date_Type" json:"Main_Field_Date_Type"`
  70. MainFieldEmployeeStatus string `gorm:"column:Main_Field_Employee_Status" json:"Main_Field_Employee_Status"`
  71. MainFieldDeleteFlag string `gorm:"column:Main_Field_Delete_Flag" json:"Main_Field_Delete_Flag"`
  72. MainFieldEmail string `gorm:"column:Main_Field_Email" json:"Main_Field_Email"`
  73. MainFieldCompanyCode string `gorm:"column:Main_Field_Company_code" json:"Main_Field_Company_code"`
  74. MainFieldSecondcomstrucodehr string `gorm:"column:Main_Field_Secondcomstrucodehr" json:"Main_Field_Secondcomstrucodehr"`
  75. MainFieldCompanyChain string `gorm:"column:Main_Field_Company_Chain" json:"Main_Field_Company_Chain"`
  76. CreateTime time.Time `gorm:"column:create_time" json:"create_time"`
  77. ModifyTime time.Time `gorm:"column:modify_time" json:"modify_time"`
  78. }
  79. func (m *MDM_EMPLOYEE) TableName() string {
  80. return "MDM_EMPLOYEE"
  81. }
  82. func (m *MDM_EMPLOYEE) Create() (err error) {
  83. err = global.MYSQL["hz_eta"].Create(m).Error
  84. return
  85. }
  86. func (m *MDM_EMPLOYEE) Update(cols []string) (err error) {
  87. err = global.MYSQL["hz_eta"].Select(cols).Updates(m).Error
  88. return
  89. }
  90. func (m *MDM_EMPLOYEE) GetItemByCondition(condition string, pars []interface{}) (item *MDM_EMPLOYEE, err error) {
  91. sql := fmt.Sprintf(`SELECT * FROM %s WHERE 1=1 %s LIMIT 1`, m.TableName(), condition)
  92. err = global.MYSQL["hz_eta"].Raw(sql, pars...).First(&item).Error
  93. return
  94. }
  95. func (m *MDM_EMPLOYEE) GetItemsByCondition(condition string, pars []interface{}, fieldArr []string, orderRule string) (items []*MDM_EMPLOYEE, err error) {
  96. fields := strings.Join(fieldArr, ",")
  97. if len(fieldArr) == 0 {
  98. fields = `*`
  99. }
  100. order := ``
  101. if orderRule != "" {
  102. order = ` ORDER BY ` + orderRule
  103. }
  104. sql := fmt.Sprintf(`SELECT %s FROM %s WHERE 1=1 %s %s`, fields, m.TableName(), condition, order)
  105. err = global.MYSQL["hz_eta"].Raw(sql, pars...).Find(&items).Error
  106. return
  107. }
  108. func (m *MDM_EMPLOYEE) CreateEmployee(employee *MDM_EMPLOYEE, employeeRelation []*MDM_RELA_COMSTRU_EMPLOYEE) (err error) {
  109. if employee == nil {
  110. err = fmt.Errorf("employee is nil")
  111. return
  112. }
  113. tx := global.MYSQL["hz_eta"].Begin()
  114. defer func() {
  115. if err != nil {
  116. _ = tx.Rollback()
  117. return
  118. }
  119. _ = tx.Commit()
  120. }()
  121. if e := tx.Create(employee).Error; e != nil {
  122. err = fmt.Errorf("create employee err, %v", e)
  123. return
  124. }
  125. if len(employeeRelation) == 0 {
  126. return
  127. }
  128. if e := tx.CreateInBatches(employeeRelation, utils.MultiAddNum).Error; e != nil {
  129. err = fmt.Errorf("create employee relations err, %v", e)
  130. return
  131. }
  132. return
  133. }
  134. func (m *MDM_EMPLOYEE) UpdateEmployee(employee *MDM_EMPLOYEE, updateCols []string, employeeRelation []*MDM_RELA_COMSTRU_EMPLOYEE) (err error) {
  135. if employee == nil {
  136. err = fmt.Errorf("employee is nil")
  137. return
  138. }
  139. tx := global.MYSQL["hz_eta"].Begin()
  140. defer func() {
  141. if err != nil {
  142. _ = tx.Rollback()
  143. return
  144. }
  145. _ = tx.Commit()
  146. }()
  147. if e := tx.Select(updateCols).Updates(employee).Error; e != nil {
  148. err = fmt.Errorf("update employee err, %v", e)
  149. return
  150. }
  151. sql := `DELETE FROM MDM_RELA_COMSTRU_EMPLOYEE WHERE Main_Field_Employee_Code = ?`
  152. if e := tx.Exec(sql, employee.MainFieldEmployeeCode); e != nil {
  153. err = fmt.Errorf("delete employee relations err, %v", e)
  154. return
  155. }
  156. if len(employeeRelation) == 0 {
  157. return
  158. }
  159. if e := tx.CreateInBatches(employeeRelation, utils.MultiAddNum).Error; e != nil {
  160. err = fmt.Errorf("create employee relations err, %v", e)
  161. return
  162. }
  163. return
  164. }
  165. type MDM_RELA_COMSTRU_EMPLOYEE struct {
  166. Id int `gorm:"column:Id;primaryKey;autoIncrement" json:"-"`
  167. Main_Field_Employee_Code string `gorm:"column:Main_Field_Employee_Code" json:"Main_Field_Employee_Code"`
  168. TuplesFieldCompanyCode string `gorm:"column:Tuples_Field_Company_Code" json:"Tuples_Field_Company_Code"`
  169. TuplesFieldCompanyName string `gorm:"column:Tuples_Field_Company_Name" json:"Tuples_Field_Company_Name"`
  170. TuplesFieldDepartmentCode string `gorm:"column:Tuples_Field_Department_Code" json:"Tuples_Field_Department_Code"`
  171. TuplesFieldDepartmentName string `gorm:"column:Tuples_Field_Department_Name" json:"Tuples_Field_Department_Name"`
  172. TuplesFieldPositionCode string `gorm:"column:Tuples_Field_Position_Code" json:"Tuples_Field_Position_Code"`
  173. TuplesFieldPositionName string `gorm:"column:Tuples_Field_Position_Name" json:"Tuples_Field_Position_Name"`
  174. TuplesFieldPostFlag string `gorm:"column:Tuples_Field_Post_Flag" json:"Tuples_Field_Post_Flag"`
  175. CreateTime time.Time `gorm:"column:create_time" json:"create_time"`
  176. ModifyTime time.Time `gorm:"column:modify_time" json:"modify_time"`
  177. }
  178. func (m *MDM_RELA_COMSTRU_EMPLOYEE) TableName() string {
  179. return "MDM_RELA_COMSTRU_EMPLOYEE"
  180. }