upsertRow method

Future<EmailAccountRequest?> upsertRow(
  1. DatabaseSession session,
  2. EmailAccountRequest row, {
  3. required ColumnSelections<EmailAccountRequestTable> conflictColumns,
  4. ColumnSelections<EmailAccountRequestTable>? updateColumns,
  5. WhereExpressionBuilder<EmailAccountRequestTable>? updateWhere,
  6. Transaction? transaction,
})

Upserts a single EmailAccountRequest and returns the resulting row.

If the row conflicts on the given conflictColumns, the existing row is updated. Otherwise, a new row is inserted.

If updateColumns is provided, only those columns will be updated on conflict. If null, all non-conflict, non-id columns are updated.

If updateWhere is provided, the update only applies when the existing row matches the expression. Returns null if no row was affected — for example when updateWhere does not match the conflicting row.

The returned EmailAccountRequest will have its id field set.

Implementation

Future<EmailAccountRequest?> upsertRow(
  _i1.DatabaseSession session,
  EmailAccountRequest row, {
  required _i1.ColumnSelections<EmailAccountRequestTable> conflictColumns,
  _i1.ColumnSelections<EmailAccountRequestTable>? updateColumns,
  _i1.WhereExpressionBuilder<EmailAccountRequestTable>? updateWhere,
  _i1.Transaction? transaction,
}) async {
  return session.db.upsertRow<EmailAccountRequest>(
    row,
    conflictColumns: conflictColumns(EmailAccountRequest.t),
    updateColumns: updateColumns?.call(EmailAccountRequest.t),
    updateWhere: updateWhere?.call(EmailAccountRequest.t),
    transaction: transaction,
  );
}