safe_file_dao.go 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /*
  2. * @description: 安全巡检数据库操作相关
  3. * @Author: LanJianRong
  4. * @Date: 2020-11-20
  5. * @FilePath: \construction_management\dao\safe_dao.go
  6. */
  7. package dao
  8. import (
  9. "github.com/go-xorm/xorm"
  10. "go.mod/models"
  11. )
  12. // 数据库操作引擎
  13. type SafeFileDao struct {
  14. engine *xorm.Engine
  15. }
  16. // 获得一个DAO对象
  17. func NewSafeFileDao(engine *xorm.Engine) *SafeFileDao {
  18. return &SafeFileDao{
  19. engine: engine,
  20. }
  21. }
  22. // 通过safe_id获得数据
  23. func (d *SafeFileDao) GetListBySid(id int) []models.CmSafeFile {
  24. dataList := make([]models.CmSafeFile, 0)
  25. err := d.engine.
  26. Asc("create_time").
  27. Sql("select f.`create_time`, f.`file_name`, f.`file_path`, a.`name`from `cm_safe_file` as f, `cm_project_acount` as a where f.`uid` = a.`id` and f.`safe_id` = ?", id).
  28. Find(&dataList)
  29. if err != nil {
  30. return dataList
  31. }
  32. return dataList
  33. }
  34. // 获取总数
  35. func (d *SafeFileDao) GetCount(id int) int64 {
  36. file := models.CmSafeFile{}
  37. total, err := d.engine.
  38. Where("safe_id=?", id).
  39. Count(file)
  40. if err != nil {
  41. return 0
  42. }
  43. return total
  44. }
  45. // 批量插入数据
  46. func (d *SafeFileDao) InsertByList(data []models.CmSafeFile) error {
  47. _, err := d.engine.Insert(data)
  48. return err
  49. }