checkHome/struct/itemtag.go

75 lines
1.8 KiB
Go

package ckh
import ()
type ItemTag struct {
IdItem int64 `json:"iditem"`
IdTag int64 `json:"idtag"`
}
func (i Item) AddTag(t Tag) (ItemTag, error) {
if _, err := DBExec("INSERT INTO item_tag (id_item, id_tag) VALUES (?, ?)", i.Id, t.Id); err != nil {
return ItemTag{}, err
} else {
return ItemTag{i.Id, t.Id}, nil
}
}
func (t Tag) AddItem(i Item) (ItemTag, error) {
if _, err := DBExec("INSERT INTO item_tag (id_item, id_tag) VALUES (?, ?)", i.Id, t.Id); err != nil {
return ItemTag{}, err
} else {
return ItemTag{i.Id, t.Id}, nil
}
}
func (i Item) DeleteTag(t Tag) (int64, error) {
if res, err := DBExec("DELETE FROM item_tag WHERE id_item = ? AND id_tag = ?", i.Id, t.Id); err != nil {
return 0, err
} else if nb, err := res.RowsAffected(); err != nil {
return 0, err
} else {
return nb, err
}
}
func (t Tag) DeleteItem(i Item) (int64, error) {
if res, err := DBExec("DELETE FROM item_tag WHERE id_item = ? AND id_tag = ?", i.Id, t.Id); err != nil {
return 0, err
} else if nb, err := res.RowsAffected(); err != nil {
return 0, err
} else {
return nb, err
}
}
func ClearItemTags() (int64, error) {
if res, err := DBExec("DELETE FROM item_tag"); err != nil {
return 0, err
} else if nb, err := res.RowsAffected(); err != nil {
return 0, err
} else {
return nb, err
}
}
func (i Item) ClearItemTags() (int64, error) {
if res, err := DBExec("DELETE FROM item_tag WHERE id_item = ?", i.Id); err != nil {
return 0, err
} else if nb, err := res.RowsAffected(); err != nil {
return 0, err
} else {
return nb, err
}
}
func (t Tag) ClearItemTags() (int64, error) {
if res, err := DBExec("DELETE FROM item_tag WHERE id_tag = ?", t.Id); err != nil {
return 0, err
} else if nb, err := res.RowsAffected(); err != nil {
return 0, err
} else {
return nb, err
}
}