Avoid Object Initialization and sql.ErrNoRows Judgment in Queries

When executing SQL queries, avoid initializing query results in advance to prevent the influence of default values in the struct objects and unnecessary object memory creation. By judging a return object pointer as nil, avoid using sql.ErrNoRows, thereby reducing the code’s complexity in handling error and unifying the project’s logic for handling empty query results.

A counterexample:

  1. func (s *sTask) GetOne(ctx context.Context, id uint64) (out *entity.ResourceTask, err error) {
  2. out = new(model.TaskDetail)
  3. err = dao.ResourceTask.Ctx(ctx).WherePri(id).Scan(out)
  4. if err != nil {
  5. if err == sql.ErrNoRows {
  6. err = gerror.Newf(`record not found for "%d"`, id)
  7. }
  8. return
  9. }
  10. return
  11. }

In this example, the returned out object actually has default values due to object initialization (regardless of whether the SQL query retrieves data), and the judgment of sql.ErrNoRows adds complexity to error handling logic in the code.

Recommended improvement:

  1. func (s *sTask) GetOne(ctx context.Context, id uint64) (out *entity.ResourceTask, err error) {
  2. err = dao.ResourceTask.Ctx(ctx).WherePri(id).Scan(&out)
  3. if err != nil {
  4. return
  5. }
  6. if out == nil {
  7. err = gerror.Newf(`record not found for "%d"`, id)
  8. }
  9. return
  10. }

Avoid Object Initialization and sql.ErrNoRows Judgment in Queries - 图1warning

Note the use of &out in the code.

For more information, please refer to: ORM Result - Empty Check