2003-01-16 02:04:50 +02:00
|
|
|
--disable_warnings
|
|
|
|
drop table if exists t1;
|
|
|
|
--enable_warnings
|
|
|
|
|
|
|
|
CREATE TABLE `t1` (
|
|
|
|
a int not null auto_increment,
|
|
|
|
`pseudo` varchar(35) character set latin2 NOT NULL default '',
|
|
|
|
`email` varchar(60) character set latin2 NOT NULL default '',
|
|
|
|
PRIMARY KEY (a),
|
|
|
|
UNIQUE KEY `email` USING BTREE (`email`)
|
2003-12-10 04:31:42 +00:00
|
|
|
) ENGINE=HEAP CHARSET=latin1 ROW_FORMAT DYNAMIC;
|
2003-01-16 02:04:50 +02:00
|
|
|
set @@sql_mode="";
|
|
|
|
show variables like 'sql_mode';
|
|
|
|
show create table t1;
|
|
|
|
set @@sql_mode="ansi_quotes";
|
|
|
|
show variables like 'sql_mode';
|
|
|
|
show create table t1;
|
|
|
|
set @@sql_mode="no_table_options";
|
|
|
|
show variables like 'sql_mode';
|
|
|
|
show create table t1;
|
|
|
|
set @@sql_mode="no_key_options";
|
|
|
|
show variables like 'sql_mode';
|
|
|
|
show create table t1;
|
|
|
|
set @@sql_mode="no_field_options,mysql323,mysql40";
|
|
|
|
show variables like 'sql_mode';
|
|
|
|
show create table t1;
|
2003-10-15 14:50:36 +05:00
|
|
|
set sql_mode="postgresql,oracle,mssql,db2,maxdb";
|
2003-06-04 18:28:51 +03:00
|
|
|
select @@sql_mode;
|
2003-01-16 02:04:50 +02:00
|
|
|
show create table t1;
|
|
|
|
drop table t1;
|
2004-09-14 13:49:08 +02:00
|
|
|
|
2004-11-04 08:50:07 +04:00
|
|
|
#
|
|
|
|
# Check that a binary collation adds 'binary'
|
|
|
|
# suffix into a char() column definition in
|
|
|
|
# mysql40 and mysql2323 modes. This allows
|
|
|
|
# not to lose the column's case sensitivity
|
|
|
|
# when loading the dump in pre-4.1 servers.
|
|
|
|
#
|
|
|
|
# Thus, in 4.0 and 3.23 modes we dump:
|
|
|
|
#
|
|
|
|
# 'char(10) collate xxx_bin' as 'char(10) binary'
|
|
|
|
# 'binary(10)' as 'binary(10)'
|
|
|
|
#
|
|
|
|
# In mysql-4.1 these types are different, and they will
|
|
|
|
# be recreated differently.
|
|
|
|
#
|
|
|
|
# In mysqld-4.0 the the above two types were the same,
|
|
|
|
# so it will create a 'char(10) binary' column for both definitions.
|
|
|
|
#
|
|
|
|
CREATE TABLE t1 (
|
|
|
|
a char(10),
|
|
|
|
b char(10) collate latin1_bin,
|
|
|
|
c binary(10)
|
|
|
|
) character set latin1;
|
|
|
|
set @@sql_mode="";
|
|
|
|
show create table t1;
|
|
|
|
set @@sql_mode="mysql323";
|
|
|
|
show create table t1;
|
|
|
|
set @@sql_mode="mysql40";
|
|
|
|
show create table t1;
|
|
|
|
drop table t1;
|
|
|
|
|
2004-09-14 13:49:08 +02:00
|
|
|
#
|
|
|
|
# BUG#5318 - failure: 'IGNORE_SPACE' affects numeric values after DEFAULT
|
|
|
|
#
|
|
|
|
# Force the usage of the default
|
|
|
|
set session sql_mode = '';
|
|
|
|
# statement for comparison, value starts with '.'
|
|
|
|
create table t1 ( min_num dec(6,6) default .000001);
|
|
|
|
show create table t1;
|
|
|
|
drop table t1 ;
|
|
|
|
#
|
|
|
|
set session sql_mode = 'IGNORE_SPACE';
|
|
|
|
# statement for comparison, value starts with '0'
|
|
|
|
create table t1 ( min_num dec(6,6) default 0.000001);
|
|
|
|
show create table t1;
|
|
|
|
drop table t1 ;
|
|
|
|
# This statement fails, value starts with '.'
|
|
|
|
create table t1 ( min_num dec(6,6) default .000001);
|
|
|
|
show create table t1;
|
|
|
|
drop table t1 ;
|
|
|
|
|
2005-06-09 14:39:29 +05:00
|
|
|
#
|
|
|
|
# Bug #10732: Set SQL_MODE to NULL gives garbled error message
|
|
|
|
#
|
|
|
|
--error 1231
|
|
|
|
set @@SQL_MODE=NULL;
|
2005-07-28 03:22:47 +03:00
|
|
|
|
2005-09-29 16:17:45 +05:00
|
|
|
#
|
|
|
|
# Bug #797: in sql_mode=ANSI, show create table ignores auto_increment
|
|
|
|
#
|
|
|
|
set session sql_mode=ansi;
|
|
|
|
create table t1
|
|
|
|
(f1 integer auto_increment primary key,
|
|
|
|
f2 timestamp default current_timestamp on update current_timestamp);
|
|
|
|
show create table t1;
|
|
|
|
set session sql_mode=no_field_options;
|
|
|
|
show create table t1;
|
|
|
|
drop table t1;
|
|
|
|
|
2005-07-28 03:22:47 +03:00
|
|
|
# End of 4.1 tests
|