diff --git a/contrib/drivers/pgsql/pgsql_do_insert.go b/contrib/drivers/pgsql/pgsql_do_insert.go index 8adb44a21..4134da659 100644 --- a/contrib/drivers/pgsql/pgsql_do_insert.go +++ b/contrib/drivers/pgsql/pgsql_do_insert.go @@ -34,7 +34,7 @@ func (d *Driver) DoInsert( return nil, gerror.WrapCode( gcode.CodeInternalError, err, - `failed to get primary keys for SaReplace operation`, + `failed to get primary keys for Save/Replace operation`, ) } foundPrimaryKey := false diff --git a/contrib/drivers/pgsql/pgsql_z_unit_upsert_test.go b/contrib/drivers/pgsql/pgsql_z_unit_upsert_test.go index aff3f7081..edefab632 100644 --- a/contrib/drivers/pgsql/pgsql_z_unit_upsert_test.go +++ b/contrib/drivers/pgsql/pgsql_z_unit_upsert_test.go @@ -219,8 +219,8 @@ func Test_FormatUpsert_NoOnConflict(t *testing.T) { }).Insert() t.AssertNil(err) - // Try Save without OnConflict - should fail for pgsql - // PostgreSQL requires OnConflict() for Save() operations, unlike MySQL + // Try Save without OnConflict and without primary key in data - should fail + // because driver cannot auto-detect conflict columns when primary key is missing _, err = db.Model(table).Data(g.Map{ // "id": 1, "passport": "no_conflict_user",