forked from ebhomengo/niki
🔥 fix(repository) multiple insert data & remove prepare statement (#28)
Reviewed-on: ebhomengo/niki#28 Co-authored-by: Abolfazl Nourzad <abolfazlnorzad78@gmail.com> Co-committed-by: Abolfazl Nourzad <abolfazlnorzad78@gmail.com>
This commit is contained in:
parent
3b3815ccec
commit
4943e90d77
|
@ -4,64 +4,25 @@ import (
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
"git.gocasts.ir/ebhomengo/niki/entity"
|
"git.gocasts.ir/ebhomengo/niki/entity"
|
||||||
"git.gocasts.ir/ebhomengo/niki/logger"
|
|
||||||
errmsg "git.gocasts.ir/ebhomengo/niki/pkg/err_msg"
|
errmsg "git.gocasts.ir/ebhomengo/niki/pkg/err_msg"
|
||||||
richerror "git.gocasts.ir/ebhomengo/niki/pkg/rich_error"
|
richerror "git.gocasts.ir/ebhomengo/niki/pkg/rich_error"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (d DB) AddBatchKindBox(ctx context.Context, kindBoxes []entity.KindBox) error {
|
func (d DB) AddBatchKindBox(ctx context.Context, kindBoxes []entity.KindBox) error {
|
||||||
const op = "mysqlkindbox.AddBatchKindBoxConcurrentlyRollback"
|
const op = "mysqlkindbox.AddBatchKindBoxConcurrentlyRollback"
|
||||||
errCh := make(chan error, len(kindBoxes))
|
|
||||||
resultCh := make(chan entity.KindBox, len(kindBoxes))
|
queryStr := "INSERT INTO kind_boxes (kind_box_req_id, benefactor_id, type, serial_number, status) VALUES "
|
||||||
tx, tErr := d.conn.Conn().Begin()
|
values := []any{}
|
||||||
if tErr != nil {
|
|
||||||
return richerror.New(op).WithErr(tErr).
|
for _, kb := range kindBoxes {
|
||||||
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
queryStr += "(?, ?, ?, ?, ?),"
|
||||||
|
values = append(values, kb.KindBoxReqID, kb.BenefactorID, kb.Type, kb.SerialNumber, kb.Status.String())
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, kindBox := range kindBoxes {
|
// trim the last ,
|
||||||
go func(kb entity.KindBox) {
|
queryStr = queryStr[0 : len(queryStr)-1]
|
||||||
_, err := tx.ExecContext(ctx,
|
|
||||||
"insert into kind_boxes (kind_box_req_id, benefactor_id, type, serial_number, status) values (?, ?, ?, ?, ?);",
|
|
||||||
kb.KindBoxReqID, kb.BenefactorID, kb.Type.String(), kb.SerialNumber, kb.Status.String(),
|
|
||||||
)
|
|
||||||
if err != nil {
|
|
||||||
errCh <- richerror.New(op).WithErr(err).
|
|
||||||
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
|
||||||
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
resultCh <- kb
|
|
||||||
errCh <- nil
|
|
||||||
}(kindBox)
|
|
||||||
}
|
|
||||||
|
|
||||||
for i := 0; i < len(kindBoxes); i++ {
|
|
||||||
select {
|
|
||||||
case err := <-errCh:
|
|
||||||
if err != nil {
|
|
||||||
if err := tx.Rollback(); err != nil {
|
|
||||||
logger.L().Error("Rollback error: ", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
case <-resultCh:
|
|
||||||
|
|
||||||
case <-ctx.Done():
|
|
||||||
if err := tx.Rollback(); err != nil {
|
|
||||||
logger.L().Error("Rollback error: ", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
return richerror.New(op).WithErr(ctx.Err()).
|
|
||||||
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := tx.Commit(); err != nil {
|
|
||||||
logger.L().Error("Commit error: ", err)
|
|
||||||
|
|
||||||
|
if _, err := d.conn.Conn().ExecContext(ctx, queryStr, values...); err != nil {
|
||||||
return richerror.New(op).WithErr(err).
|
return richerror.New(op).WithErr(err).
|
||||||
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,27 +28,14 @@ func (d DB) AddKindBoxReq(ctx context.Context, kindBoxReq entity.KindBoxReq) (en
|
||||||
return kindBoxReq, nil
|
return kindBoxReq, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d DB) AcceptKindBoxReq(ctx context.Context, kindBoxReqID, countAccepted uint) (finalErr error) {
|
func (d DB) AcceptKindBoxReq(ctx context.Context, kindBoxReqID, countAccepted uint) error {
|
||||||
op := richerror.Op("mysqlkindboxreq.AcceptKindBoxReq")
|
op := richerror.Op("mysqlkindboxreq.AcceptKindBoxReq")
|
||||||
statement, err := d.conn.Conn().
|
_, err := d.conn.Conn().ExecContext(ctx, `update kind_box_reqs set count_accepted = ? , status = ? where id = ?`,
|
||||||
Prepare(`update kind_box_reqs set count_accepted = ? , status = ? where id = ?`)
|
countAccepted, entity.KindBoxReqAcceptedStatus.String(), kindBoxReqID)
|
||||||
|
|
||||||
defer func() {
|
|
||||||
cErr := statement.Close()
|
|
||||||
if cErr != nil {
|
|
||||||
finalErr = cErr
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return richerror.New(op).WithErr(err).
|
return richerror.New(op).WithErr(err).
|
||||||
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
||||||
}
|
}
|
||||||
_, eErr := statement.ExecContext(ctx, countAccepted, entity.KindBoxReqAcceptedStatus.String(), kindBoxReqID)
|
|
||||||
if eErr != nil {
|
|
||||||
return richerror.New(op).WithErr(eErr).
|
|
||||||
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -81,48 +68,25 @@ func (d DB) KindBoxRequestExist(id uint) (bool, error) {
|
||||||
return true, nil
|
return true, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d DB) RejectKindBoxReq(ctx context.Context, kindBoxReqID uint, description string) (finalErr error) {
|
func (d DB) RejectKindBoxReq(ctx context.Context, kindBoxReqID uint, description string) error {
|
||||||
op := richerror.Op("mysqlkindboxreq.RejectKindBoxReq")
|
op := richerror.Op("mysqlkindboxreq.RejectKindBoxReq")
|
||||||
statement, err := d.conn.Conn().
|
_, err := d.conn.Conn().ExecContext(ctx, `update kind_box_reqs set description = ? , status = ? where id = ?`,
|
||||||
Prepare(`update kind_box_reqs set description = ? , status = ? where id = ?`)
|
description, entity.KindBoxReqRejectedStatus.String(), kindBoxReqID)
|
||||||
defer func() {
|
|
||||||
cErr := statement.Close()
|
|
||||||
if cErr != nil {
|
|
||||||
finalErr = cErr
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return richerror.New(op).WithErr(err).
|
return richerror.New(op).WithErr(err).
|
||||||
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
||||||
}
|
}
|
||||||
_, eErr := statement.ExecContext(ctx, description, entity.KindBoxReqRejectedStatus.String(), kindBoxReqID)
|
|
||||||
if eErr != nil {
|
|
||||||
return richerror.New(op).WithErr(eErr).
|
|
||||||
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d DB) RollbackKindBoxRequestStatus(ctx context.Context, id uint) (finalErr error) {
|
func (d DB) RollbackKindBoxRequestStatus(ctx context.Context, id uint) error {
|
||||||
op := richerror.Op("mysqlkindboxreq.RollbackKindBoxRequestStatus")
|
op := richerror.Op("mysqlkindboxreq.RollbackKindBoxRequestStatus")
|
||||||
statement, err := d.conn.Conn().
|
_, err := d.conn.Conn().ExecContext(ctx, `update kind_box_reqs set status = ? where id = ?`, entity.KindBoxReqPendingStatus.String(), id)
|
||||||
Prepare(`update kind_box_reqs set status = ? where id = ?`)
|
|
||||||
defer func() {
|
|
||||||
cErr := statement.Close()
|
|
||||||
if cErr != nil {
|
|
||||||
finalErr = cErr
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return richerror.New(op).WithErr(err).
|
return richerror.New(op).WithErr(err).
|
||||||
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
||||||
}
|
}
|
||||||
_, eErr := statement.ExecContext(ctx, entity.KindBoxReqPendingStatus.String(), id)
|
|
||||||
if eErr != nil {
|
|
||||||
return richerror.New(op).WithErr(eErr).
|
|
||||||
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue