Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
cc6ad16b
Commit
cc6ad16b
authored
Apr 29, 2006
by
kent@mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge kboortz@bk-internal.mysql.com:/home/bk/mysql-4.1
into mysql.com:/Users/kent/mysql/bk/mysql-4.1-new
parents
18b3a2c9
604b5836
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
127 additions
and
13 deletions
+127
-13
acinclude.m4
acinclude.m4
+5
-3
mysql-test/r/null.result
mysql-test/r/null.result
+42
-0
mysql-test/t/null.test
mysql-test/t/null.test
+41
-0
sql/sql_table.cc
sql/sql_table.cc
+39
-10
No files found.
acinclude.m4
View file @
cc6ad16b
...
...
@@ -311,8 +311,9 @@ case $SYSTEM_TYPE in
;;
*)
# Just to be safe, we test for ".so" anyway
eval shrexts=\"$shrext_cmds\"
if test \( -f "$mysql_zlib_dir/lib/libz.a" -o -f "$mysql_zlib_dir/lib/libz.so" -o \
-f "$mysql_zlib_dir/lib/libz$shrext
_cmd
s" \) \
-f "$mysql_zlib_dir/lib/libz$shrexts" \) \
-a -f "$mysql_zlib_dir/include/zlib.h"; then
ZLIB_INCLUDES="-I$mysql_zlib_dir/include"
ZLIB_LIBS="-L$mysql_zlib_dir/lib -lz"
...
...
@@ -967,6 +968,7 @@ AC_DEFUN([MYSQL_CHECK_VIO], [
AC_DEFUN([MYSQL_FIND_OPENSSL], [
incs="$1"
libs="$2"
eval shrexts=\"$shrext_cmds\"
case "$incs---$libs" in
---)
for d in /usr/ssl/include /usr/local/ssl/include /usr/include \
...
...
@@ -981,7 +983,7 @@ AC_DEFUN([MYSQL_FIND_OPENSSL], [
/usr/lib /usr/lib64 /opt/ssl/lib /opt/openssl/lib \
/usr/freeware/lib32 /usr/local/lib/ ; do
# Just to be safe, we test for ".so" anyway
if test -f $d/libssl.a || test -f $d/libssl.so || test -f $d/libssl$shrext
_cmd
s ; then
if test -f $d/libssl.a || test -f $d/libssl.so || test -f $d/libssl$shrexts ; then
OPENSSL_LIB=$d
fi
done
...
...
@@ -994,7 +996,7 @@ AC_DEFUN([MYSQL_FIND_OPENSSL], [
OPENSSL_INCLUDE=-I$incs
fi
# Just to be safe, we test for ".so" anyway
if test -f $libs/libssl.a || test -f $libs/libssl.so || test -f
$libs/libssl$shrext_cmds
; then
if test -f $libs/libssl.a || test -f $libs/libssl.so || test -f
"$libs/libssl$shrexts"
; then
OPENSSL_LIB=$libs
fi
;;
...
...
mysql-test/r/null.result
View file @
cc6ad16b
...
...
@@ -269,3 +269,45 @@ field('str1', null, 'STR1') as c05,
c01 c02 c03 c04 c05 c08 c09
str str 0 1 2 1 1
set names latin1;
create table bug19145a (e enum('a','b','c') default 'b' , s set('x', 'y', 'z') default 'y' ) engine=MyISAM;
create table bug19145b (e enum('a','b','c') default null, s set('x', 'y', 'z') default null) engine=MyISAM;
create table bug19145c (e enum('a','b','c') not null default 'b' , s set('x', 'y', 'z') not null default 'y' ) engine=MyISAM;
create table bug19145setnotnulldefaultnull (e enum('a','b','c') default null, s set('x', 'y', 'z') not null default null) engine=MyISAM;
ERROR 42000: Invalid default value for 's'
create table bug19145enumnotnulldefaultnull (e enum('a','b','c') not null default null, s set('x', 'y', 'z') default null) engine=MyISAM;
ERROR 42000: Invalid default value for 'e'
alter table bug19145a alter column e set default null;
alter table bug19145a alter column s set default null;
alter table bug19145a add column (i int);
alter table bug19145b alter column e set default null;
alter table bug19145b alter column s set default null;
alter table bug19145b add column (i int);
alter table bug19145c alter column e set default null;
ERROR 42000: Invalid default value for 'e'
alter table bug19145c alter column s set default null;
ERROR 42000: Invalid default value for 's'
alter table bug19145c add column (i int);
show create table bug19145a;
Table Create Table
bug19145a CREATE TABLE `bug19145a` (
`e` enum('a','b','c') default NULL,
`s` set('x','y','z') default NULL,
`i` int(11) default NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
show create table bug19145b;
Table Create Table
bug19145b CREATE TABLE `bug19145b` (
`e` enum('a','b','c') default NULL,
`s` set('x','y','z') default NULL,
`i` int(11) default NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
show create table bug19145c;
Table Create Table
bug19145c CREATE TABLE `bug19145c` (
`e` enum('a','b','c') NOT NULL default 'b',
`s` set('x','y','z') NOT NULL default 'y',
`i` int(11) default NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
drop table bug19145a;
drop table bug19145b;
drop table bug19145c;
mysql-test/t/null.test
View file @
cc6ad16b
...
...
@@ -187,4 +187,45 @@ select
# Restore charset to the default value.
set
names
latin1
;
#
# Bug#19145: mysqld crashes if you set the default value of an enum field to NULL
#
create
table
bug19145a
(
e
enum
(
'a'
,
'b'
,
'c'
)
default
'b'
,
s
set
(
'x'
,
'y'
,
'z'
)
default
'y'
)
engine
=
MyISAM
;
create
table
bug19145b
(
e
enum
(
'a'
,
'b'
,
'c'
)
default
null
,
s
set
(
'x'
,
'y'
,
'z'
)
default
null
)
engine
=
MyISAM
;
create
table
bug19145c
(
e
enum
(
'a'
,
'b'
,
'c'
)
not
null
default
'b'
,
s
set
(
'x'
,
'y'
,
'z'
)
not
null
default
'y'
)
engine
=
MyISAM
;
# Invalid default value for 's'
--
error
1067
create
table
bug19145setnotnulldefaultnull
(
e
enum
(
'a'
,
'b'
,
'c'
)
default
null
,
s
set
(
'x'
,
'y'
,
'z'
)
not
null
default
null
)
engine
=
MyISAM
;
# Invalid default value for 'e'
--
error
1067
create
table
bug19145enumnotnulldefaultnull
(
e
enum
(
'a'
,
'b'
,
'c'
)
not
null
default
null
,
s
set
(
'x'
,
'y'
,
'z'
)
default
null
)
engine
=
MyISAM
;
alter
table
bug19145a
alter
column
e
set
default
null
;
alter
table
bug19145a
alter
column
s
set
default
null
;
alter
table
bug19145a
add
column
(
i
int
);
alter
table
bug19145b
alter
column
e
set
default
null
;
alter
table
bug19145b
alter
column
s
set
default
null
;
alter
table
bug19145b
add
column
(
i
int
);
# Invalid default value for 'e'
--
error
1067
alter
table
bug19145c
alter
column
e
set
default
null
;
# Invalid default value for 's'
--
error
1067
alter
table
bug19145c
alter
column
s
set
default
null
;
alter
table
bug19145c
add
column
(
i
int
);
show
create
table
bug19145a
;
show
create
table
bug19145b
;
show
create
table
bug19145c
;
drop
table
bug19145a
;
drop
table
bug19145b
;
drop
table
bug19145c
;
# End of 4.1 tests
sql/sql_table.cc
View file @
cc6ad16b
...
...
@@ -601,7 +601,7 @@ int mysql_prepare_table(THD *thd, HA_CREATE_INFO *create_info,
if
(
need_to_change_arena
)
thd
->
restore_backup_item_arena
(
thd
->
current_arena
,
&
backup_arena
);
if
(
!
sql_field
->
def
)
if
(
sql_field
->
def
==
NULL
)
{
/* Could not convert */
my_error
(
ER_INVALID_DEFAULT
,
MYF
(
0
),
sql_field
->
field_name
);
...
...
@@ -611,15 +611,30 @@ int mysql_prepare_table(THD *thd, HA_CREATE_INFO *create_info,
if
(
sql_field
->
sql_type
==
FIELD_TYPE_SET
)
{
if
(
sql_field
->
def
)
if
(
sql_field
->
def
!=
NULL
)
{
char
*
not_used
;
uint
not_used2
;
bool
not_found
=
0
;
String
str
,
*
def
=
sql_field
->
def
->
val_str
(
&
str
);
def
->
length
(
cs
->
cset
->
lengthsp
(
cs
,
def
->
ptr
(),
def
->
length
()));
if
(
def
==
NULL
)
/* SQL "NULL" maps to NULL */
{
if
((
sql_field
->
flags
&
NOT_NULL_FLAG
)
!=
0
)
{
my_error
(
ER_INVALID_DEFAULT
,
MYF
(
0
),
sql_field
->
field_name
);
DBUG_RETURN
(
-
1
);
}
/* else, NULL is an allowed value */
(
void
)
find_set
(
interval
,
NULL
,
0
,
cs
,
&
not_used
,
&
not_used2
,
&
not_found
);
}
else
/* not NULL */
{
(
void
)
find_set
(
interval
,
def
->
ptr
(),
def
->
length
(),
cs
,
&
not_used
,
&
not_used2
,
&
not_found
);
}
if
(
not_found
)
{
my_error
(
ER_INVALID_DEFAULT
,
MYF
(
0
),
sql_field
->
field_name
);
...
...
@@ -631,16 +646,30 @@ int mysql_prepare_table(THD *thd, HA_CREATE_INFO *create_info,
}
else
/* FIELD_TYPE_ENUM */
{
if
(
sql_field
->
def
)
DBUG_ASSERT
(
sql_field
->
sql_type
==
FIELD_TYPE_ENUM
);
if
(
sql_field
->
def
!=
NULL
)
{
String
str
,
*
def
=
sql_field
->
def
->
val_str
(
&
str
);
if
(
def
==
NULL
)
/* SQL "NULL" maps to NULL */
{
if
((
sql_field
->
flags
&
NOT_NULL_FLAG
)
!=
0
)
{
my_error
(
ER_INVALID_DEFAULT
,
MYF
(
0
),
sql_field
->
field_name
);
DBUG_RETURN
(
-
1
);
}
/* else, the defaults yield the correct length for NULLs. */
}
else
/* not NULL */
{
def
->
length
(
cs
->
cset
->
lengthsp
(
cs
,
def
->
ptr
(),
def
->
length
()));
if
(
!
find_type2
(
interval
,
def
->
ptr
(),
def
->
length
(),
cs
))
if
(
find_type2
(
interval
,
def
->
ptr
(),
def
->
length
(),
cs
)
==
0
)
/* not found */
{
my_error
(
ER_INVALID_DEFAULT
,
MYF
(
0
),
sql_field
->
field_name
);
DBUG_RETURN
(
-
1
);
}
}
}
calculate_interval_lengths
(
cs
,
interval
,
&
sql_field
->
length
,
&
dummy
);
}
set_if_smaller
(
sql_field
->
length
,
MAX_FIELD_WIDTH
-
1
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment