memo_relation.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. package sqlite
  2. import (
  3. "context"
  4. "database/sql"
  5. "strings"
  6. "github.com/usememos/memos/store"
  7. )
  8. func (d *DB) UpsertMemoRelation(ctx context.Context, create *store.MemoRelation) (*store.MemoRelation, error) {
  9. stmt := `
  10. INSERT INTO memo_relation (
  11. memo_id,
  12. related_memo_id,
  13. type
  14. )
  15. VALUES (?, ?, ?)
  16. ON CONFLICT (memo_id, related_memo_id, type) DO UPDATE SET
  17. type = EXCLUDED.type
  18. RETURNING memo_id, related_memo_id, type
  19. `
  20. memoRelation := &store.MemoRelation{}
  21. if err := d.db.QueryRowContext(
  22. ctx,
  23. stmt,
  24. create.MemoID,
  25. create.RelatedMemoID,
  26. create.Type,
  27. ).Scan(
  28. &memoRelation.MemoID,
  29. &memoRelation.RelatedMemoID,
  30. &memoRelation.Type,
  31. ); err != nil {
  32. return nil, err
  33. }
  34. return memoRelation, nil
  35. }
  36. func (d *DB) ListMemoRelations(ctx context.Context, find *store.FindMemoRelation) ([]*store.MemoRelation, error) {
  37. where, args := []string{"TRUE"}, []any{}
  38. if find.MemoID != nil {
  39. where, args = append(where, "memo_id = ?"), append(args, find.MemoID)
  40. }
  41. if find.RelatedMemoID != nil {
  42. where, args = append(where, "related_memo_id = ?"), append(args, find.RelatedMemoID)
  43. }
  44. if find.Type != nil {
  45. where, args = append(where, "type = ?"), append(args, find.Type)
  46. }
  47. rows, err := d.db.QueryContext(ctx, `
  48. SELECT
  49. memo_id,
  50. related_memo_id,
  51. type
  52. FROM memo_relation
  53. WHERE `+strings.Join(where, " AND "), args...)
  54. if err != nil {
  55. return nil, err
  56. }
  57. defer rows.Close()
  58. list := []*store.MemoRelation{}
  59. for rows.Next() {
  60. memoRelation := &store.MemoRelation{}
  61. if err := rows.Scan(
  62. &memoRelation.MemoID,
  63. &memoRelation.RelatedMemoID,
  64. &memoRelation.Type,
  65. ); err != nil {
  66. return nil, err
  67. }
  68. list = append(list, memoRelation)
  69. }
  70. if err := rows.Err(); err != nil {
  71. return nil, err
  72. }
  73. return list, nil
  74. }
  75. func (d *DB) DeleteMemoRelation(ctx context.Context, delete *store.DeleteMemoRelation) error {
  76. where, args := []string{"TRUE"}, []any{}
  77. if delete.MemoID != nil {
  78. where, args = append(where, "memo_id = ?"), append(args, delete.MemoID)
  79. }
  80. if delete.RelatedMemoID != nil {
  81. where, args = append(where, "related_memo_id = ?"), append(args, delete.RelatedMemoID)
  82. }
  83. if delete.Type != nil {
  84. where, args = append(where, "type = ?"), append(args, delete.Type)
  85. }
  86. stmt := `
  87. DELETE FROM memo_relation
  88. WHERE ` + strings.Join(where, " AND ")
  89. result, err := d.db.ExecContext(ctx, stmt, args...)
  90. if err != nil {
  91. return err
  92. }
  93. if _, err = result.RowsAffected(); err != nil {
  94. return err
  95. }
  96. return nil
  97. }
  98. func vacuumMemoRelations(ctx context.Context, tx *sql.Tx) error {
  99. if _, err := tx.ExecContext(ctx, `
  100. DELETE FROM memo_relation
  101. WHERE memo_id NOT IN (SELECT id FROM memo) OR related_memo_id NOT IN (SELECT id FROM memo)
  102. `); err != nil {
  103. return err
  104. }
  105. return nil
  106. }