summaryrefslogtreecommitdiffstats
path: root/Bugzilla
diff options
context:
space:
mode:
authorFrédéric Buclin <LpSolit@gmail.com>2016-04-28 20:32:04 +0200
committerFrédéric Buclin <LpSolit@gmail.com>2016-04-28 20:32:04 +0200
commitacf611b178afd1bdeed8383a9647bc73a4e10d05 (patch)
treef46a5b9aafb430ee97693ef6cc70ebadd60c60b7 /Bugzilla
parent86facf92f2346a817f7e7399718a66dd4fab7f8e (diff)
downloadbugzilla-acf611b178afd1bdeed8383a9647bc73a4e10d05.tar.gz
bugzilla-acf611b178afd1bdeed8383a9647bc73a4e10d05.tar.xz
Bug 1268174 - [PostgreSQL] $dbh->bz_add_column() fails to create new columns with the NOT NULL constraint if there is no DEFAULT value
r=gerv
Diffstat (limited to 'Bugzilla')
-rw-r--r--Bugzilla/DB/Schema.pm34
-rw-r--r--Bugzilla/DB/Schema/Oracle.pm10
2 files changed, 36 insertions, 8 deletions
diff --git a/Bugzilla/DB/Schema.pm b/Bugzilla/DB/Schema.pm
index 76ea3c0c8..8b00e627e 100644
--- a/Bugzilla/DB/Schema.pm
+++ b/Bugzilla/DB/Schema.pm
@@ -2336,13 +2336,21 @@ sub get_add_column_ddl {
my ($self, $table, $column, $definition, $init_value) = @_;
my @statements;
+ # If DEFAULT is undefined and the column is enforced to be NOT NULL,
+ # then we use the init value as a temporary default value.
+ my $temp_default = 0;
+ if ($definition->{NOTNULL} && !exists $definition->{DEFAULT} && defined $init_value) {
+ $temp_default = 1;
+ $definition->{DEFAULT} = $init_value;
+ }
+
push(@statements, "ALTER TABLE $table ". $self->ADD_COLUMN ." $column " .
$self->get_type_ddl($definition));
- # XXX - Note that although this works for MySQL, most databases will fail
- # before this point, if we haven't set a default.
- (push(@statements, "UPDATE $table SET $column = $init_value"))
- if defined $init_value;
+ if ($temp_default) {
+ push(@statements, $self->get_drop_default_ddl($table, $column));
+ delete $definition->{DEFAULT};
+ }
if (defined $definition->{REFERENCES}) {
push(@statements, $self->get_add_fks_sql($table, { $column =>
@@ -2352,6 +2360,21 @@ sub get_add_column_ddl {
return (@statements);
}
+sub get_drop_default_ddl {
+
+=item C<get_drop_default_ddl>
+
+ Description: Gets SQL to drop the default value of a column.
+ Params: $table - The table containing the column.
+ $column - The name of the column whose default value must be dropped.
+ Returns: A string containing the SQL to drop the default value.
+
+=cut
+
+ my ($self, $table, $column) = @_;
+ return "ALTER TABLE $table ALTER COLUMN $column DROP DEFAULT";
+}
+
sub get_add_index_ddl {
=item C<get_add_index_ddl>
@@ -2431,8 +2454,7 @@ sub get_alter_column_ddl {
}
# If we went from having a default to not having one
elsif (!defined $default && defined $default_old) {
- push(@statements, "ALTER TABLE $table ALTER COLUMN $column"
- . " DROP DEFAULT");
+ push(@statements, $self->get_drop_default_ddl($table, $column));
}
# If we went from no default to a default, or we changed the default.
elsif ( (defined $default && !defined $default_old) ||
diff --git a/Bugzilla/DB/Schema/Oracle.pm b/Bugzilla/DB/Schema/Oracle.pm
index c3868ad44..8d237d27e 100644
--- a/Bugzilla/DB/Schema/Oracle.pm
+++ b/Bugzilla/DB/Schema/Oracle.pm
@@ -215,6 +215,11 @@ sub get_add_column_ddl {
return @sql;
}
+sub get_drop_default_ddl {
+ my ($self, $table, $column) = @_;
+ return "ALTER TABLE $table MODIFY $column DEFAULT NULL";
+}
+
sub get_alter_column_ddl {
my ($self, $table, $column, $new_def, $set_nulls_to) = @_;
@@ -240,8 +245,7 @@ sub get_alter_column_ddl {
}
# If we went from having a default to not having one
elsif (!defined $default && defined $default_old) {
- push(@statements, "ALTER TABLE $table MODIFY $column"
- . " DEFAULT NULL");
+ push(@statements, $self->get_drop_default_ddl($table, $column));
}
# If we went from no default to a default, or we changed the default.
elsif ( (defined $default && !defined $default_old) ||
@@ -524,6 +528,8 @@ sub get_set_serial_sql {
=item get_drop_column_ddl
+=item get_drop_default_ddl
+
=item get_drop_table_ddl
=item get_drop_fk_sql