upsertRow method
Future<AuthUser?>
upsertRow(
- DatabaseSession session,
- AuthUser row, {
- required ColumnSelections<
AuthUserTable> conflictColumns, - ColumnSelections<
AuthUserTable> ? updateColumns, - WhereExpressionBuilder<
AuthUserTable> ? updateWhere, - Transaction? transaction,
Upserts a single AuthUser 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 AuthUser will have its id field set.
Implementation
Future<AuthUser?> upsertRow(
_i1.DatabaseSession session,
AuthUser row, {
required _i1.ColumnSelections<AuthUserTable> conflictColumns,
_i1.ColumnSelections<AuthUserTable>? updateColumns,
_i1.WhereExpressionBuilder<AuthUserTable>? updateWhere,
_i1.Transaction? transaction,
}) async {
return session.db.upsertRow<AuthUser>(
row,
conflictColumns: conflictColumns(AuthUser.t),
updateColumns: updateColumns?.call(AuthUser.t),
updateWhere: updateWhere?.call(AuthUser.t),
transaction: transaction,
);
}