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
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
9657cddd
Commit
9657cddd
authored
Dec 16, 2002
by
walrus@mysql.com
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add log lines to crash-me result file
parent
8a46cc38
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
293 additions
and
116 deletions
+293
-116
sql-bench/crash-me.sh
sql-bench/crash-me.sh
+280
-104
sql-bench/server-cfg.sh
sql-bench/server-cfg.sh
+13
-12
No files found.
sql-bench/crash-me.sh
View file @
9657cddd
#!@PERL@
#!@PERL@
# -*- perl -*-
# Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
# Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
#
#
# This library is free software; you can redistribute it and/or
# This library is free software; you can redistribute it and/or
...
@@ -68,6 +69,10 @@ usage() if ($opt_help || $opt_Information);
...
@@ -68,6 +69,10 @@ usage() if ($opt_help || $opt_Information);
$opt_suffix
=
'-'
.
$opt_suffix
if
(
length
(
$opt_suffix
)
!=
0
)
;
$opt_suffix
=
'-'
.
$opt_suffix
if
(
length
(
$opt_suffix
)
!=
0
)
;
$opt_config_file
=
"
$pwd
/
$opt_dir
/
$opt_server$opt_suffix
.cfg"
if
(
length
(
$opt_config_file
)
==
0
)
;
$opt_config_file
=
"
$pwd
/
$opt_dir
/
$opt_server$opt_suffix
.cfg"
if
(
length
(
$opt_config_file
)
==
0
)
;
$log_prefix
=
' ###'
;
# prefix for log lines in result file
$safe_query_log
=
''
;
$safe_query_result_log
=
''
;
$log
{
"crash-me"
}=
""
;
#!!!
#!!!
...
@@ -167,11 +172,11 @@ $prompt="drop table require cascade/restrict";
...
@@ -167,11 +172,11 @@ $prompt="drop table require cascade/restrict";
$drop_attr
=
""
;
$drop_attr
=
""
;
$dbh
->do
(
"drop table crash_me"
)
;
$dbh
->do
(
"drop table crash_me"
)
;
$dbh
->do
(
"drop table crash_me cascade"
)
;
$dbh
->do
(
"drop table crash_me cascade"
)
;
if
(!
safe_query
(
[
"create table crash_me (a integer not null)"
,
if
(!
safe_query
_l
(
'drop_requires_cascade'
,
[
"create table crash_me (a integer not null)"
,
"drop table crash_me"
]))
"drop table crash_me"
]))
{
{
$dbh
->do
(
"drop table crash_me cascade"
)
;
$dbh
->do
(
"drop table crash_me cascade"
)
;
if
(
safe_query
(
[
"create table crash_me (a integer not null)"
,
if
(
safe_query
_l
(
'drop_requires_cascade'
,
[
"create table crash_me (a integer not null)"
,
"drop table crash_me cascade"
]))
"drop table crash_me cascade"
]))
{
{
save_config_data
(
'drop_requires_cascade'
,
"yes"
,
"
$prompt
"
)
;
save_config_data
(
'drop_requires_cascade'
,
"yes"
,
"
$prompt
"
)
;
...
@@ -196,10 +201,10 @@ $dbh->do("drop table crash_q $drop_attr");
...
@@ -196,10 +201,10 @@ $dbh->do("drop table crash_q $drop_attr");
$dbh
->do
(
"drop table crash_q1
$drop_attr
"
)
;
$dbh
->do
(
"drop table crash_q1
$drop_attr
"
)
;
$prompt
=
"Tables without primary key"
;
$prompt
=
"Tables without primary key"
;
if
(!
safe_query
(
[
"create table crash_me (a integer not null,b char(10) not null)"
,
if
(!
safe_query
_l
(
'no_primary_key'
,
[
"create table crash_me (a integer not null,b char(10) not null)"
,
"insert into crash_me (a,b) values (1,'a')"
]))
"insert into crash_me (a,b) values (1,'a')"
]))
{
{
if
(!
safe_query
(
[
"create table crash_me (a integer not null,b char(10) not null, primary key (a))"
,
if
(!
safe_query
_l
(
'no_primary_key'
,
[
"create table crash_me (a integer not null,b char(10) not null, primary key (a))"
,
"insert into crash_me (a,b) values (1,'a')"
]))
"insert into crash_me (a,b) values (1,'a')"
]))
{
{
die
"Can't create table 'crash_me' with one record:
$DBI
::errstr
\n
"
;
die
"Can't create table 'crash_me' with one record:
$DBI
::errstr
\n
"
;
...
@@ -421,9 +426,9 @@ check_and_report("Group on column with null values",'group_by_null',
...
@@ -421,9 +426,9 @@ check_and_report("Group on column with null values",'group_by_null',
$prompt
=
"Having"
;
$prompt
=
"Having"
;
if
(!
defined
(
$limits
{
'having'
}))
if
(!
defined
(
$limits
{
'having'
}))
{
# Complicated because of postgreSQL
{
# Complicated because of postgreSQL
if
(!
safe_query_result
(
"select a from crash_me group by a having a > 0"
,1,0
))
if
(!
safe_query_result
_l
(
"having"
,
"select a from crash_me group by a having a > 0"
,1,0
))
{
{
if
(!
safe_query_result
(
"select a from crash_me group by a having a < 0"
,
if
(!
safe_query_result
_l
(
"having"
,
"select a from crash_me group by a having a < 0"
,
1,0
))
1,0
))
{
save_config_data
(
"having"
,
"error"
,
$prompt
)
;
}
{
save_config_data
(
"having"
,
"error"
,
$prompt
)
;
}
else
else
...
@@ -465,7 +470,7 @@ $logical_value= $limits{'logical_value'};
...
@@ -465,7 +470,7 @@ $logical_value= $limits{'logical_value'};
$false
=
0
;
$false
=
0
;
$result
=
"no"
;
$result
=
"no"
;
if
(
$res
=
safe_query
(
"select (1=1)=true
$end_query
"
))
{
if
(
$res
=
safe_query
_l
(
'has_true_false'
,
"select (1=1)=true
$end_query
"
))
{
$false
=
"false"
;
$false
=
"false"
;
$result
=
"yes"
;
$result
=
"yes"
;
}
}
...
@@ -730,33 +735,33 @@ if (($limits{'type_extra_float(2_arg)'} eq "yes" ||
...
@@ -730,33 +735,33 @@ if (($limits{'type_extra_float(2_arg)'} eq "yes" ||
my
$type
=
$limits
{
'type_extra_float(2_arg)'
}
eq
"yes"
?
"float(4,1)"
:
my
$type
=
$limits
{
'type_extra_float(2_arg)'
}
eq
"yes"
?
"float(4,1)"
:
"decimal(4,1)"
;
"decimal(4,1)"
;
my
$result
=
"undefined"
;
my
$result
=
"undefined"
;
if
(
execute_and_check
([
"create table crash_q (q1
$type
)"
,
if
(
execute_and_check
(
"storage_of_float"
,
[
"create table crash_q (q1
$type
)"
,
"insert into crash_q values(1.14)"
]
,
"insert into crash_q values(1.14)"
]
,
"select q1 from crash_q"
,
"select q1 from crash_q"
,
[
"drop table crash_q
$drop_attr
"
]
,1.1,0
)
&&
[
"drop table crash_q
$drop_attr
"
]
,1.1,0
)
&&
execute_and_check
([
"create table crash_q (q1
$type
)"
,
execute_and_check
(
"storage_of_float"
,
[
"create table crash_q (q1
$type
)"
,
"insert into crash_q values(1.16)"
]
,
"insert into crash_q values(1.16)"
]
,
"select q1 from crash_q"
,
"select q1 from crash_q"
,
[
"drop table crash_q
$drop_attr
"
]
,1.1,0
))
[
"drop table crash_q
$drop_attr
"
]
,1.1,0
))
{
{
$result
=
"truncate"
;
$result
=
"truncate"
;
}
}
elsif
(
execute_and_check
([
"create table crash_q (q1
$type
)"
,
elsif
(
execute_and_check
(
"storage_of_float"
,
[
"create table crash_q (q1
$type
)"
,
"insert into crash_q values(1.14)"
]
,
"insert into crash_q values(1.14)"
]
,
"select q1 from crash_q"
,
"select q1 from crash_q"
,
[
"drop table crash_q
$drop_attr
"
]
,1.1,0
)
&&
[
"drop table crash_q
$drop_attr
"
]
,1.1,0
)
&&
execute_and_check
([
"create table crash_q (q1
$type
)"
,
execute_and_check
(
"storage_of_float"
,
[
"create table crash_q (q1
$type
)"
,
"insert into crash_q values(1.16)"
]
,
"insert into crash_q values(1.16)"
]
,
"select q1 from crash_q"
,
"select q1 from crash_q"
,
[
"drop table crash_q
$drop_attr
"
]
,1.2,0
))
[
"drop table crash_q
$drop_attr
"
]
,1.2,0
))
{
{
$result
=
"round"
;
$result
=
"round"
;
}
}
elsif
(
execute_and_check
([
"create table crash_q (q1
$type
)"
,
elsif
(
execute_and_check
(
"storage_of_float"
,
[
"create table crash_q (q1
$type
)"
,
"insert into crash_q values(1.14)"
]
,
"insert into crash_q values(1.14)"
]
,
"select q1 from crash_q"
,
"select q1 from crash_q"
,
[
"drop table crash_q
$drop_attr
"
]
,1.14,0
)
&&
[
"drop table crash_q
$drop_attr
"
]
,1.14,0
)
&&
execute_and_check
([
"create table crash_q (q1
$type
)"
,
execute_and_check
(
"storage_of_float"
,
[
"create table crash_q (q1
$type
)"
,
"insert into crash_q values(1.16)"
]
,
"insert into crash_q values(1.16)"
]
,
"select q1 from crash_q"
,
"select q1 from crash_q"
,
[
"drop table crash_q
$drop_attr
"
]
,1.16,0
))
[
"drop table crash_q
$drop_attr
"
]
,1.16,0
))
...
@@ -1202,6 +1207,7 @@ if ($limits{'functions'} eq 'yes')
...
@@ -1202,6 +1207,7 @@ if ($limits{'functions'} eq 'yes')
"select
$tmp
$end_query
"
,[], undef
()
,4
)
;
"select
$tmp
$end_query
"
,[], undef
()
,4
)
;
}
}
$prompt
=
"Need to cast NULL for arithmetic"
;
$prompt
=
"Need to cast NULL for arithmetic"
;
add_log
(
"Need_cast_for_null"
,
" Check if numeric_null (
$numeric_null
) is 'NULL'"
)
;
save_config_data
(
"Need_cast_for_null"
,
save_config_data
(
"Need_cast_for_null"
,
(
$numeric_null
eq
"NULL"
)
?
"no"
:
"yes"
,
(
$numeric_null
eq
"NULL"
)
?
"no"
:
"yes"
,
$prompt
)
;
$prompt
)
;
...
@@ -1220,15 +1226,15 @@ else
...
@@ -1220,15 +1226,15 @@ else
save_incomplete
(
'func_extra_noround'
,
'Function NOROUND'
)
;
save_incomplete
(
'func_extra_noround'
,
'Function NOROUND'
)
;
# 1) check if noround() function is supported
# 1) check if noround() function is supported
$error
=
safe_query
(
"select noround(22.6)
$end_query
"
)
;
$error
=
safe_query
_l
(
'func_extra_noround'
,
"select noround(22.6)
$end_query
"
)
;
if
(
$error
ne 1
)
# syntax error -- noround is not supported
if
(
$error
ne 1
)
# syntax error -- noround is not supported
{
{
$resultat
=
'no'
$resultat
=
'no'
}
else
# Ok, now check if it really works
}
else
# Ok, now check if it really works
{
{
$error
=
safe_query
(
"create table crash_me_nr (a int)"
,
$error
=
safe_query
_l
(
'func_extra_noround'
,
[
"create table crash_me_nr (a int)"
,
"insert into crash_me_nr values(noround(10.2))"
,
"insert into crash_me_nr values(noround(10.2))"
,
"drop table crash_me_nr
$drop_attr
"
)
;
"drop table crash_me_nr
$drop_attr
"
]
)
;
if
(
$error
eq 1
)
{
if
(
$error
eq 1
)
{
$resultat
=
"syntax only"
;
$resultat
=
"syntax only"
;
}
else
{
}
else
{
...
@@ -1246,26 +1252,23 @@ check_parenthesis("func_sql_","USER");
...
@@ -1246,26 +1252,23 @@ check_parenthesis("func_sql_","USER");
# Test: WEEK()
# Test: WEEK()
{
{
my
$explain
=
""
;
my
$resultat
=
"no"
;
my
$resultat
=
"no"
;
my
$error
;
my
$error
;
print
"WEEK:"
;
print
"WEEK:"
;
save_incomplete
(
'func_odbc_week'
,
'WEEK'
)
;
save_incomplete
(
'func_odbc_week'
,
'WEEK'
)
;
$error
=
safe_query_result
(
"select week(DATE '1997-02-01')
$end_query
"
,5,0
)
;
$error
=
safe_query_result
_l
(
'func_odbc_week'
,
"select week(DATE '1997-02-01')
$end_query
"
,5,0
)
;
# actually this query must return 4 or 5 in the $last_result,
# actually this query must return 4 or 5 in the $last_result,
# $error can be 1 (not supported at all) , -1 ( probably USA weeks)
# $error can be 1 (not supported at all) , -1 ( probably USA weeks)
# and 0 - EURO weeks
# and 0 - EURO weeks
if
(
$error
==
-1
)
{
if
(
$error
==
-1
)
{
if
(
$last_result
==
4
)
{
if
(
$last_result
==
4
)
{
$resultat
=
'USA'
;
$resultat
=
'USA'
;
$explain
=
' started from Sunday'
;
}
else
{
}
else
{
$resultat
=
'error'
;
$resultat
=
'error'
;
$explain
=
" must return 4 or 5, but
$last_error
"
;
add_log
(
'func_odbc_week'
,
" must return 4 or 5, but
$last_result
"
)
;
}
}
}
elsif
(
$error
==
0
)
{
}
elsif
(
$error
==
0
)
{
$resultat
=
'EURO'
;
$resultat
=
'EURO'
;
$explain
=
' started from Monday'
;
}
}
print
"
$resultat
\n
"
;
print
"
$resultat
\n
"
;
save_config_data
(
'func_odbc_week'
,
$resultat
,
"WEEK
$explain
"
)
;
save_config_data
(
'func_odbc_week'
,
$resultat
,
"WEEK
$explain
"
)
;
...
@@ -1486,27 +1489,27 @@ report("index in create table",'index_in_create',
...
@@ -1486,27 +1489,27 @@ report("index in create table",'index_in_create',
# later
# later
if
(!(
defined
(
$limits
{
'create_index'
})
&&
defined
(
$limits
{
'drop_index'
})))
if
(!(
defined
(
$limits
{
'create_index'
})
&&
defined
(
$limits
{
'drop_index'
})))
{
{
if
(
$res
=
safe_query
(
"create index crash_q on crash_me (a)"
))
if
(
$res
=
safe_query
_l
(
'create_index'
,
"create index crash_q on crash_me (a)"
))
{
{
$res
=
"yes"
;
$res
=
"yes"
;
$drop_res
=
"yes"
;
$drop_res
=
"yes"
;
$end_drop_keyword
=
""
;
$end_drop_keyword
=
""
;
if
(!
safe_query
(
"drop index crash_q"
))
if
(!
safe_query
_l
(
'drop_index'
,
"drop index crash_q"
))
{
{
# Can't drop the standard way; Check if mSQL
# Can't drop the standard way; Check if mSQL
if
(
safe_query
(
"drop index crash_q from crash_me"
))
if
(
safe_query
_l
(
'drop_index'
,
"drop index crash_q from crash_me"
))
{
{
$drop_res
=
"with 'FROM'"
;
# Drop is not ANSI SQL
$drop_res
=
"with 'FROM'"
;
# Drop is not ANSI SQL
$end_drop_keyword
=
"drop index %i from %t"
;
$end_drop_keyword
=
"drop index %i from %t"
;
}
}
# else check if Access or MySQL
# else check if Access or MySQL
elsif
(
safe_query
(
"drop index crash_q on crash_me"
))
elsif
(
safe_query
_l
(
'drop_index'
,
"drop index crash_q on crash_me"
))
{
{
$drop_res
=
"with 'ON'"
;
# Drop is not ANSI SQL
$drop_res
=
"with 'ON'"
;
# Drop is not ANSI SQL
$end_drop_keyword
=
"drop index %i on %t"
;
$end_drop_keyword
=
"drop index %i on %t"
;
}
}
# else check if MS-SQL
# else check if MS-SQL
elsif
(
safe_query
(
"drop index crash_me.crash_q"
))
elsif
(
safe_query
_l
(
'drop_index'
,
"drop index crash_me.crash_q"
))
{
{
$drop_res
=
"with 'table.index'"
;
# Drop is not ANSI SQL
$drop_res
=
"with 'table.index'"
;
# Drop is not ANSI SQL
$end_drop_keyword
=
"drop index %t.%i"
;
$end_drop_keyword
=
"drop index %t.%i"
;
...
@@ -1516,7 +1519,7 @@ if (!(defined($limits{'create_index'}) && defined($limits{'drop_index'})))
...
@@ -1516,7 +1519,7 @@ if (!(defined($limits{'create_index'}) && defined($limits{'drop_index'})))
{
{
# Old MySQL 3.21 supports only the create index syntax
# Old MySQL 3.21 supports only the create index syntax
# This means that the second create doesn't give an error.
# This means that the second create doesn't give an error.
$res
=
safe_query
(
[
"create index crash_q on crash_me (a)"
,
$res
=
safe_query
_l
(
'create_index'
,
[
"create index crash_q on crash_me (a)"
,
"create index crash_q on crash_me (a)"
,
"create index crash_q on crash_me (a)"
,
"drop index crash_q"
])
;
"drop index crash_q"
])
;
$res
=
$res
?
'ignored'
:
'yes'
;
$res
=
$res
?
'ignored'
:
'yes'
;
...
@@ -1760,17 +1763,17 @@ report("views","views",
...
@@ -1760,17 +1763,17 @@ report("views","views",
save_incomplete
(
'foreign_key'
,
'foreign keys'
)
;
save_incomplete
(
'foreign_key'
,
'foreign keys'
)
;
# 1) check if foreign keys are supported
# 1) check if foreign keys are supported
safe_query
(
create_table
(
"crash_me_qf"
,[
"a integer not null"
]
,
safe_query
_l
(
'foreign_key'
,
create_table
(
"crash_me_qf"
,[
"a integer not null"
]
,
[
"primary key (a)"
]))
;
[
"primary key (a)"
]))
;
$error
=
safe_query
(
create_table
(
"crash_me_qf2"
,[
"a integer not null"
,
$error
=
safe_query
_l
(
'foreign_key'
,
create_table
(
"crash_me_qf2"
,[
"a integer not null"
,
"foreign key (a) references crash_me_qf (a)"
]
,
[]))
;
"foreign key (a) references crash_me_qf (a)"
]
,
[]))
;
if
(
$error
eq 1
)
# OK -- syntax is supported
if
(
$error
eq 1
)
# OK -- syntax is supported
{
{
$resultat
=
'error'
;
$resultat
=
'error'
;
# now check if foreign key really works
# now check if foreign key really works
safe_query
(
"insert into crash_me_qf values (1)"
)
;
safe_query
_l
(
'foreign_key'
,
"insert into crash_me_qf values (1)"
)
;
if
(
safe_query
(
"insert into crash_me_qf2 values (2)"
)
eq 1
)
{
if
(
safe_query
_l
(
'foreign_key'
,
"insert into crash_me_qf2 values (2)"
)
eq 1
)
{
$resultat
=
'syntax only'
;
$resultat
=
'syntax only'
;
}
else
{
}
else
{
$resultat
=
'yes'
;
$resultat
=
'yes'
;
...
@@ -1779,7 +1782,7 @@ report("views","views",
...
@@ -1779,7 +1782,7 @@ report("views","views",
}
else
{
}
else
{
$resultat
=
"no"
;
$resultat
=
"no"
;
}
}
safe_query
(
"drop table crash_me_qf2
$drop_attr
"
,
"drop table crash_me_qf
$drop_attr
"
)
;
safe_query
_l
(
'foreign_key'
,
"drop table crash_me_qf2
$drop_attr
"
,
"drop table crash_me_qf
$drop_attr
"
)
;
print
"
$resultat
\n
"
;
print
"
$resultat
\n
"
;
save_config_data
(
'foreign_key'
,
$resultat
,
"foreign keys"
)
;
save_config_data
(
'foreign_key'
,
$resultat
,
"foreign keys"
)
;
}
}
...
@@ -2056,6 +2059,7 @@ if ($limits{'create_index'} ne 'no')
...
@@ -2056,6 +2059,7 @@ if ($limits{'create_index'} ne 'no')
if
(
$limits
{
'create_index'
}
eq
'ignored'
||
if
(
$limits
{
'create_index'
}
eq
'ignored'
||
$limits
{
'unique_in_create'
}
eq
'yes'
)
$limits
{
'unique_in_create'
}
eq
'yes'
)
{
# This should be true
{
# This should be true
add_log
(
'max_index'
,
" max_unique_index=
$limits
{'max_unique_index'} ,so max_index must be same"
)
;
save_config_data
(
'max_index'
,
$limits
{
'max_unique_index'
}
,
"max index"
)
;
save_config_data
(
'max_index'
,
$limits
{
'max_unique_index'
}
,
"max index"
)
;
print
"indexes:
$limits
{'max_index'}
\n
"
;
print
"indexes:
$limits
{'max_index'}
\n
"
;
}
}
...
@@ -2063,10 +2067,10 @@ if ($limits{'create_index'} ne 'no')
...
@@ -2063,10 +2067,10 @@ if ($limits{'create_index'} ne 'no')
{
{
if
(!
defined
(
$limits
{
'max_index'
}))
if
(!
defined
(
$limits
{
'max_index'
}))
{
{
assert
(
"create table crash_q (
$key_definitions
)"
)
;
safe_query_l
(
'max_index'
,
"create table crash_q (
$key_definitions
)"
)
;
for
(
$i
=
1
;
$i
<
=
min
(
$limits
{
'max_columns'
}
,
$max_keys
)
;
$i
++
)
for
(
$i
=
1
;
$i
<
=
min
(
$limits
{
'max_columns'
}
,
$max_keys
)
;
$i
++
)
{
{
last
if
(!
safe_query
(
"create index crash_q
$i
on crash_q (q
$i
)"
))
;
last
if
(!
safe_query
_l
(
'max_index'
,
"create index crash_q
$i
on crash_q (q
$i
)"
))
;
}
}
save_config_data
(
'max_index'
,
$i
==
$max_keys
?
$max_keys
:
$i
,
save_config_data
(
'max_index'
,
$i
==
$max_keys
?
$max_keys
:
$i
,
"max index"
)
;
"max index"
)
;
...
@@ -2082,10 +2086,10 @@ if ($limits{'create_index'} ne 'no')
...
@@ -2082,10 +2086,10 @@ if ($limits{'create_index'} ne 'no')
print
"indexs:
$limits
{'max_index'}
\n
"
;
print
"indexs:
$limits
{'max_index'}
\n
"
;
if
(!
defined
(
$limits
{
'max_unique_index'
}))
if
(!
defined
(
$limits
{
'max_unique_index'
}))
{
{
assert
(
"create table crash_q (
$key_definitions
)"
)
;
safe_query_l
(
'max_unique_index'
,
"create table crash_q (
$key_definitions
)"
)
;
for
(
$i
=
0
;
$i
< min
(
$limits
{
'max_columns'
}
,
$max_keys
)
;
$i
++
)
for
(
$i
=
0
;
$i
< min
(
$limits
{
'max_columns'
}
,
$max_keys
)
;
$i
++
)
{
{
last
if
(!
safe_query
(
"create unique index crash_q
$i
on crash_q (q
$i
)"
))
;
last
if
(!
safe_query
_l
(
'max_unique_index'
,
"create unique index crash_q
$i
on crash_q (q
$i
)"
))
;
}
}
save_config_data
(
'max_unique_index'
,
$i
==
$max_keys
?
$max_keys
:
$i
,
save_config_data
(
'max_unique_index'
,
$i
==
$max_keys
?
$max_keys
:
$i
,
"max unique index"
)
;
"max unique index"
)
;
...
@@ -2101,7 +2105,7 @@ if ($limits{'create_index'} ne 'no')
...
@@ -2101,7 +2105,7 @@ if ($limits{'create_index'} ne 'no')
print
"unique indexes:
$limits
{'max_unique_index'}
\n
"
;
print
"unique indexes:
$limits
{'max_unique_index'}
\n
"
;
if
(!
defined
(
$limits
{
'max_index_parts'
}))
if
(!
defined
(
$limits
{
'max_index_parts'
}))
{
{
assert
(
"create table crash_q (
$key_definitions
)"
)
;
safe_query_l
(
'max_index_parts'
,
"create table crash_q (
$key_definitions
)"
)
;
$end_drop
=
$end_drop_keyword
;
$end_drop
=
$end_drop_keyword
;
$end_drop
=
~ s/%i/crash_q1%d/
;
$end_drop
=
~ s/%i/crash_q1%d/
;
$end_drop
=
~ s/%t/crash_q/
;
$end_drop
=
~ s/%t/crash_q/
;
...
@@ -2182,23 +2186,23 @@ if (!defined($limits{$key}))
...
@@ -2182,23 +2186,23 @@ if (!defined($limits{$key}))
{
{
print
"
$prompt
="
;
print
"
$prompt
="
;
save_incomplete
(
$key
,
$prompt
)
;
save_incomplete
(
$key
,
$prompt
)
;
if
(!
safe_query
(
$server
->create
(
"crash_me_a"
,[
"a decimal(10,2)"
,
"b decimal(10,2)"
])))
if
(!
safe_query
_l
(
$key
,
$server
->create
(
"crash_me_a"
,[
"a decimal(10,2)"
,
"b decimal(10,2)"
])))
{
{
print DBI->errstr
()
;
print DBI->errstr
()
;
die
"Can't create table 'crash_me_a'
$DBI
::errstr
\n
"
;
die
"Can't create table 'crash_me_a'
$DBI
::errstr
\n
"
;
}
;
}
;
if
(!
safe_query
(
[
"insert into crash_me_a (a,b) values (11.4,18.9)"
]))
if
(!
safe_query
_l
(
$key
,
[
"insert into crash_me_a (a,b) values (11.4,18.9)"
]))
{
{
die
"Can't insert into table 'crash_me_a' a record:
$DBI
::errstr
\n
"
;
die
"Can't insert into table 'crash_me_a' a record:
$DBI
::errstr
\n
"
;
}
;
}
;
$arithmetic_safe
=
'no'
;
$arithmetic_safe
=
'no'
;
$arithmetic_safe
=
'yes'
$arithmetic_safe
=
'yes'
if
(
(
safe_query_result
(
'select count(*) from crash_me_a where a+b=30.3'
,1,0
)
==
0
)
if
(
(
safe_query_result
_l
(
$key
,
'select count(*) from crash_me_a where a+b=30.3'
,1,0
)
==
0
)
and
(
safe_query_result
(
'select count(*) from crash_me_a where a+b-30.3 = 0'
,1,0
)
==
0
)
and
(
safe_query_result
_l
(
$key
,
'select count(*) from crash_me_a where a+b-30.3 = 0'
,1,0
)
==
0
)
and
(
safe_query_result
(
'select count(*) from crash_me_a where a+b-30.3 < 0'
,0,0
)
==
0
)
and
(
safe_query_result
_l
(
$key
,
'select count(*) from crash_me_a where a+b-30.3 < 0'
,0,0
)
==
0
)
and
(
safe_query_result
(
'select count(*) from crash_me_a where a+b-30.3 > 0'
,0,0
)
==
0
)
)
;
and
(
safe_query_result
_l
(
$key
,
'select count(*) from crash_me_a where a+b-30.3 > 0'
,0,0
)
==
0
)
)
;
save_config_data
(
$key
,
$arithmetic_safe
,
$prompt
)
;
save_config_data
(
$key
,
$arithmetic_safe
,
$prompt
)
;
print
"
$arithmetic_safe
\n
"
;
print
"
$arithmetic_safe
\n
"
;
assert
(
"drop table crash_me_a
$drop_attr
"
)
;
assert
(
"drop table crash_me_a
$drop_attr
"
)
;
...
@@ -2214,11 +2218,12 @@ if (!safe_query($server->create("crash_me_n",["i integer","r integer"])))
...
@@ -2214,11 +2218,12 @@ if (!safe_query($server->create("crash_me_n",["i integer","r integer"])))
print DBI->errstr
()
;
print DBI->errstr
()
;
die
"Can't create table 'crash_me_n'
$DBI
::errstr
\n
"
;
die
"Can't create table 'crash_me_n'
$DBI
::errstr
\n
"
;
}
;
}
;
assert
(
"insert into crash_me_n (i) values(1)"
)
;
assert
(
"insert into crash_me_n values(2,2)"
)
;
safe_query_l
(
"position_of_null"
,[
"insert into crash_me_n (i) values(1)"
,
assert
(
"insert into crash_me_n values(3,3)"
)
;
"insert into crash_me_n values(2,2)"
,
assert
(
"insert into crash_me_n values(4,4)"
)
;
"insert into crash_me_n values(3,3)"
,
assert
(
"insert into crash_me_n (i) values(5)"
)
;
"insert into crash_me_n values(4,4)"
,
"insert into crash_me_n (i) values(5)"
])
;
$key
=
"position_of_null"
;
$key
=
"position_of_null"
;
$prompt
=
"Where is null values in sorted recordset"
;
$prompt
=
"Where is null values in sorted recordset"
;
...
@@ -2228,7 +2233,8 @@ if (!defined($limits{$key}))
...
@@ -2228,7 +2233,8 @@ if (!defined($limits{$key}))
print
"
$prompt
="
;
print
"
$prompt
="
;
$sth
=
$dbh
->prepare
(
"select r from crash_me_n order by r "
)
;
$sth
=
$dbh
->prepare
(
"select r from crash_me_n order by r "
)
;
$sth
->execute
;
$sth
->execute
;
$limit
=
detect_null_position
(
$sth
)
;
add_log
(
$key
,
"< select r from crash_me_n order by r "
)
;
$limit
=
detect_null_position
(
$key
,
$sth
)
;
$sth
->finish
;
$sth
->finish
;
print
"
$limit
\n
"
;
print
"
$limit
\n
"
;
save_config_data
(
$key
,
$limit
,
$prompt
)
;
save_config_data
(
$key
,
$limit
,
$prompt
)
;
...
@@ -2244,7 +2250,8 @@ if (!defined($limits{$key}))
...
@@ -2244,7 +2250,8 @@ if (!defined($limits{$key}))
print
"
$prompt
="
;
print
"
$prompt
="
;
$sth
=
$dbh
->prepare
(
"select r from crash_me_n order by r desc"
)
;
$sth
=
$dbh
->prepare
(
"select r from crash_me_n order by r desc"
)
;
$sth
->execute
;
$sth
->execute
;
$limit
=
detect_null_position
(
$sth
)
;
add_log
(
$key
,
"< select r from crash_me_n order by r desc"
)
;
$limit
=
detect_null_position
(
$key
,
$sth
)
;
$sth
->finish
;
$sth
->finish
;
print
"
$limit
\n
"
;
print
"
$limit
\n
"
;
save_config_data
(
$key
,
$limit
,
$prompt
)
;
save_config_data
(
$key
,
$limit
,
$prompt
)
;
...
@@ -2269,18 +2276,31 @@ $dbh->disconnect || warn $dbh->errstr;
...
@@ -2269,18 +2276,31 @@ $dbh->disconnect || warn $dbh->errstr;
save_all_config_data
()
;
save_all_config_data
()
;
exit
0
;
exit
0
;
# End of test
#
$dbh
->do
(
"drop table crash_me
$drop_attr
"
)
;
# Remove temporary table
print
"crash-me safe:
$limits
{'crash_me_safe'}
\n
"
;
print
"reconnected
$reconnect_count
times
\n
"
;
$dbh
->disconnect
||
warn
$dbh
->errstr
;
save_all_config_data
()
;
exit
0
;
# Check where is nulls in the sorted result (for)
# Check where is nulls in the sorted result (for)
# it expects exactly 5 rows in the result
# it expects exactly 5 rows in the result
sub detect_null_position
sub detect_null_position
{
{
my
$key
=
shift
;
my
$sth
=
shift
;
my
$sth
=
shift
;
my
(
$z
,
$r1
,
$r2
,
$r3
,
$r4
,
$r5
)
;
my
(
$z
,
$r1
,
$r2
,
$r3
,
$r4
,
$r5
)
;
$r1
=
$sth
->fetchrow_array
;
$r1
=
$sth
->fetchrow_array
;
add_log
(
$key
,
">
$r1
"
)
;
$r2
=
$sth
->fetchrow_array
;
$r2
=
$sth
->fetchrow_array
;
add_log
(
$key
,
">
$r2
"
)
;
$r3
=
$sth
->fetchrow_array
;
$r3
=
$sth
->fetchrow_array
;
add_log
(
$key
,
">
$r3
"
)
;
$r4
=
$sth
->fetchrow_array
;
$r4
=
$sth
->fetchrow_array
;
add_log
(
$key
,
">
$r4
"
)
;
$r5
=
$sth
->fetchrow_array
;
$r5
=
$sth
->fetchrow_array
;
add_log
(
$key
,
">
$r5
"
)
;
return
"first"
if
(
!
defined
(
$r1
)
&&
!
defined
(
$r2
)
&&
defined
(
$r3
))
;
return
"first"
if
(
!
defined
(
$r1
)
&&
!
defined
(
$r2
)
&&
defined
(
$r3
))
;
return
"last"
if
(
!
defined
(
$r5
)
&&
!
defined
(
$r4
)
&&
defined
(
$r3
))
;
return
"last"
if
(
!
defined
(
$r5
)
&&
!
defined
(
$r4
)
&&
defined
(
$r3
))
;
return
"random"
;
return
"random"
;
...
@@ -2291,16 +2311,24 @@ sub check_parenthesis {
...
@@ -2291,16 +2311,24 @@ sub check_parenthesis {
my
$fn
=
shift
;
my
$fn
=
shift
;
my
$resultat
=
'no'
;
my
$resultat
=
'no'
;
my
$param_name
=
$prefix
.lc
(
$fn
)
;
my
$param_name
=
$prefix
.lc
(
$fn
)
;
my
$r
;
save_incomplete
(
$param_name
,
$fn
)
;
save_incomplete
(
$param_name
,
$fn
)
;
if
(
safe_query
(
"select
$fn
$end_query
"
)
==
1
)
$r
=
safe_query
(
"select
$fn
$end_query
"
)
;
add_log
(
$param_name
,
$safe_query_log
)
;
if
(
$r
==
1
)
{
{
$resultat
=
"yes"
;
$resultat
=
"yes"
;
}
}
elsif
(
safe_query
(
"select
$fn
()
$end_query
"
)
==
1
)
else
{
$r
=
safe_query
(
"select
$fn
()
$end_query
"
)
;
add_log
(
$param_name
,
$safe_query_log
)
;
if
(
$r
==
1
)
{
{
$resultat
=
"with_parenthesis"
;
$resultat
=
"with_parenthesis"
;
}
}
}
save_config_data
(
$param_name
,
$resultat
,
$fn
)
;
save_config_data
(
$param_name
,
$resultat
,
$fn
)
;
}
}
...
@@ -2313,16 +2341,22 @@ sub check_constraint {
...
@@ -2313,16 +2341,22 @@ sub check_constraint {
save_incomplete
(
$key
,
$prompt
)
;
save_incomplete
(
$key
,
$prompt
)
;
print
"
$prompt
="
;
print
"
$prompt
="
;
my
$res
=
'no'
;
my
$res
=
'no'
;
my
$t
;
if
(
(
$t
=
safe_query
(
$create
))
==
1
)
$t
=
safe_query
(
$create
)
;
add_log
(
$key
,
$safe_query_log
)
;
if
(
$t
==
1
)
{
{
$res
=
'yes'
;
$res
=
'yes'
;
if
(
safe_query
(
$check
)
==
1
)
$t
=
safe_query
(
$check
)
;
add_log
(
$key
,
$safe_query_log
)
;
if
(
$t
==
1
)
{
{
$res
=
'syntax only'
;
$res
=
'syntax only'
;
}
}
}
}
safe_query
(
$drop
)
;
safe_query
(
$drop
)
;
add_log
(
$key
,
$safe_query_log
)
;
save_config_data
(
$key
,
$res
,
$prompt
)
;
save_config_data
(
$key
,
$res
,
$prompt
)
;
print
"
$res
\n
"
;
print
"
$res
\n
"
;
}
}
...
@@ -2633,6 +2667,15 @@ sub check_connect
...
@@ -2633,6 +2667,15 @@ sub check_connect
#
#
# print query if debugging
# print query if debugging
#
#
sub repr_query
{
my
$query
=
shift
;
if
(
length
(
$query
)
>
130
)
{
$query
=
substr
(
$query
,0,120
)
.
"...("
.
(
length
(
$query
)
-120
)
.
")"
;
}
return
$query
;
}
sub print_query
sub print_query
{
{
my
(
$query
)=
@_
;
my
(
$query
)=
@_
;
...
@@ -2652,10 +2695,19 @@ sub print_query
...
@@ -2652,10 +2695,19 @@ sub print_query
# Note that all rows are executed (to ensure that we execute drop table commands)
# Note that all rows are executed (to ensure that we execute drop table commands)
#
#
sub safe_query_l
{
my
$key
=
shift
;
my
$q
=
shift
;
my
$r
=
safe_query
(
$q
)
;
add_log
(
$key
,
$safe_query_log
)
;
return
$r
;
}
sub safe_query
sub safe_query
{
{
my
(
$queries
)=
@_
;
my
(
$queries
)=
@_
;
my
(
$query
,
$ok
,
$retry_ok
,
$retry
,@tmp,
$sth
)
;
my
(
$query
,
$ok
,
$retry_ok
,
$retry
,@tmp,
$sth
)
;
$safe_query_log
=
""
;
$ok
=
1
;
$ok
=
1
;
if
(
ref
(
$queries
)
ne
"ARRAY"
)
if
(
ref
(
$queries
)
ne
"ARRAY"
)
{
{
...
@@ -2666,9 +2718,11 @@ sub safe_query
...
@@ -2666,9 +2718,11 @@ sub safe_query
{
{
printf
"query1: %-80.80s ...(%d - %d)
\n
"
,
$query
,length
(
$query
)
,
$retry_limit
if
(
$opt_log_all_queries
)
;
printf
"query1: %-80.80s ...(%d - %d)
\n
"
,
$query
,length
(
$query
)
,
$retry_limit
if
(
$opt_log_all_queries
)
;
print LOG
"
$query
;
\n
"
if
(
$opt_log
)
;
print LOG
"
$query
;
\n
"
if
(
$opt_log
)
;
$safe_query_log
.
=
"<
$query
\n
"
;
if
(
length
(
$query
)
>
$query_size
)
if
(
length
(
$query
)
>
$query_size
)
{
{
$ok
=
0
;
$ok
=
0
;
$safe_query_log
.
=
"Query is too long
\n
"
;
next
;
next
;
}
}
...
@@ -2678,6 +2732,7 @@ sub safe_query
...
@@ -2678,6 +2732,7 @@ sub safe_query
if
(!
(
$sth
=
$dbh
->prepare
(
$query
)))
if
(!
(
$sth
=
$dbh
->prepare
(
$query
)))
{
{
print_query
(
$query
)
;
print_query
(
$query
)
;
$safe_query_log
.
=
"> couldn't prepare:"
.
$dbh
->errstr.
"
\n
"
;
$retry
=
100
if
(!
$server
->abort_if_fatal_error
())
;
$retry
=
100
if
(!
$server
->abort_if_fatal_error
())
;
# Force a reconnect because of Access drop table bug!
# Force a reconnect because of Access drop table bug!
if
(
$retry
==
$retry_limit
-2
)
if
(
$retry
==
$retry_limit
-2
)
...
@@ -2692,6 +2747,7 @@ sub safe_query
...
@@ -2692,6 +2747,7 @@ sub safe_query
if
(!
$sth
->execute
())
if
(!
$sth
->execute
())
{
{
print_query
(
$query
)
;
print_query
(
$query
)
;
$safe_query_log
.
=
"> execute error:"
.
$dbh
->errstr.
"
\n
"
;
$retry
=
100
if
(!
$server
->abort_if_fatal_error
())
;
$retry
=
100
if
(!
$server
->abort_if_fatal_error
())
;
# Force a reconnect because of Access drop table bug!
# Force a reconnect because of Access drop table bug!
if
(
$retry
==
$retry_limit
-2
)
if
(
$retry
==
$retry_limit
-2
)
...
@@ -2705,6 +2761,8 @@ sub safe_query
...
@@ -2705,6 +2761,8 @@ sub safe_query
{
{
$retry
=
$retry_limit
;
$retry
=
$retry_limit
;
$retry_ok
=
1
;
$retry_ok
=
1
;
$safe_query_log
.
=
"> OK
\n
"
;
}
}
$sth
->finish
;
$sth
->finish
;
}
}
...
@@ -2912,7 +2970,7 @@ sub check_reserved_words
...
@@ -2912,7 +2970,7 @@ sub check_reserved_words
)
;
)
;
$dbh
->do
(
"drop table crash_me10
"
)
;
safe_query
(
"drop table crash_me10
$drop_attr
"
)
;
foreach my
$keyword
(
sort
{
$a
cmp
$b
}
keys %reserved_words
)
foreach my
$keyword
(
sort
{
$a
cmp
$b
}
keys %reserved_words
)
{
{
...
@@ -2921,24 +2979,10 @@ sub check_reserved_words
...
@@ -2921,24 +2979,10 @@ sub check_reserved_words
$prompt
=
"Keyword "
.
$keyword
;
$prompt
=
"Keyword "
.
$keyword
;
$config
=
"reserved_word_"
.
$keywords_ext
[
$keyword_type
]
.
"_"
.lc
(
$keyword
)
;
$config
=
"reserved_word_"
.
$keywords_ext
[
$keyword_type
]
.
"_"
.lc
(
$keyword
)
;
$dbh
->
{
RaiseError
}=
1
;
report_fail
(
$prompt
,
$config
,
"create table crash_me10 (
$keyword
int not null)"
,
$answer
=
"yes"
;
"drop table crash_me10
$drop_attr
"
)
;
eval
{
$dbh
->do
(
"create table crash_me10 (
$keyword
int not null)"
)
;
}
;
$dbh
->
{
RaiseError
}=
0
;
if
(!
$@
)
{
$answer
=
"no"
;
$dbh
->do
(
"drop table crash_me10"
)
;
}
save_config_data
(
$config
,
$answer
,
$prompt
)
;
print
"
$prompt
: "
,
$limits
{
$config
}
,
"
\n
"
;
print
"
$prompt
: "
,
$limits
{
$config
}
,
"
\n
"
;
}
}
}
}
...
@@ -3002,7 +3046,17 @@ sub report
...
@@ -3002,7 +3046,17 @@ sub report
print
"
$prompt
: "
;
print
"
$prompt
: "
;
if
(!
defined
(
$limits
{
$limit
}))
if
(!
defined
(
$limits
{
$limit
}))
{
{
save_config_data
(
$limit
,safe_query
(
\@
queries
)
?
"yes"
:
"no"
,
$prompt
)
;
my
$queries_result
=
safe_query
(
\@
queries
)
;
add_log
(
$limit
,
$safe_query_log
)
;
my
$report_result
;
if
(
$queries_result
)
{
$report_result
=
"yes"
;
add_log
(
$limit
,
"As far as all queries returned OK, result is YES"
)
;
}
else
{
$report_result
=
"no"
;
add_log
(
$limit
,
"As far as some queries didnt return OK, result is NO"
)
;
}
save_config_data
(
$limit
,
$report_result
,
$prompt
)
;
}
}
print
"
$limits
{
$limit
}
\n
"
;
print
"
$limits
{
$limit
}
\n
"
;
return
$limits
{
$limit
}
ne
"no"
;
return
$limits
{
$limit
}
ne
"no"
;
...
@@ -3014,7 +3068,17 @@ sub report_fail
...
@@ -3014,7 +3068,17 @@ sub report_fail
print
"
$prompt
: "
;
print
"
$prompt
: "
;
if
(!
defined
(
$limits
{
$limit
}))
if
(!
defined
(
$limits
{
$limit
}))
{
{
save_config_data
(
$limit
,safe_query
(
\@
queries
)
?
"no"
:
"yes"
,
$prompt
)
;
my
$queries_result
=
safe_query
(
\@
queries
)
;
add_log
(
$limit
,
$safe_query_log
)
;
my
$report_result
;
if
(
$queries_result
)
{
$report_result
=
"no"
;
add_log
(
$limit
,
"As far as all queries returned OK, result is NO"
)
;
}
else
{
$report_result
=
"yes"
;
add_log
(
$limit
,
"As far as some queries didnt return OK, result is YES"
)
;
}
save_config_data
(
$limit
,
$report_result
,
$prompt
)
;
}
}
print
"
$limits
{
$limit
}
\n
"
;
print
"
$limits
{
$limit
}
\n
"
;
return
$limits
{
$limit
}
ne
"no"
;
return
$limits
{
$limit
}
ne
"no"
;
...
@@ -3034,7 +3098,7 @@ sub report_one
...
@@ -3034,7 +3098,7 @@ sub report_one
$result
=
"no"
;
$result
=
"no"
;
foreach
$query
(
@
$queries
)
foreach
$query
(
@
$queries
)
{
{
if
(
safe_query
(
$query
->[0]
))
if
(
safe_query
_l
(
$limit
,
$query
->[0]
))
{
{
$result
=
$query
->[1]
;
$result
=
$query
->[1]
;
last
;
last
;
...
@@ -3058,6 +3122,7 @@ sub report_result
...
@@ -3058,6 +3122,7 @@ sub report_result
{
{
save_incomplete
(
$limit
,
$prompt
)
;
save_incomplete
(
$limit
,
$prompt
)
;
$error
=
safe_query_result
(
$query
,
"1"
,2
)
;
$error
=
safe_query_result
(
$query
,
"1"
,2
)
;
add_log
(
$limit
,
$safe_query_result_log
)
;
save_config_data
(
$limit
,
$error
?
"not supported"
:
$last_result
,
$prompt
)
;
save_config_data
(
$limit
,
$error
?
"not supported"
:
$last_result
,
$prompt
)
;
}
}
print
"
$limits
{
$limit
}
\n
"
;
print
"
$limits
{
$limit
}
\n
"
;
...
@@ -3078,16 +3143,19 @@ sub report_trans
...
@@ -3078,16 +3143,19 @@ sub report_trans
$dbh
->rollback
;
$dbh
->rollback
;
$dbh
->
{
AutoCommit
}
=
1
;
$dbh
->
{
AutoCommit
}
=
1
;
if
(
safe_query_result
(
$check
,
""
,
""
))
{
if
(
safe_query_result
(
$check
,
""
,
""
))
{
add_log
(
$limit
,
$safe_query_result_log
)
;
save_config_data
(
$limit
,
"yes"
,
$limit
)
;
save_config_data
(
$limit
,
"yes"
,
$limit
)
;
}
}
safe_query
(
$clear
)
;
safe_query
(
$clear
)
;
}
else
{
}
else
{
add_log
(
$limit
,
$safe_query_log
)
;
save_config_data
(
$limit
,
"error"
,
$limit
)
;
save_config_data
(
$limit
,
"error"
,
$limit
)
;
}
}
$dbh
->
{
AutoCommit
}
=
1
;
$dbh
->
{
AutoCommit
}
=
1
;
}
}
else
else
{
{
add_log
(
$limit
,
"Couldnt undef autocommit ?? "
)
;
save_config_data
(
$limit
,
"no"
,
$limit
)
;
save_config_data
(
$limit
,
"no"
,
$limit
)
;
}
}
safe_query
(
$clear
)
;
safe_query
(
$clear
)
;
...
@@ -3106,20 +3174,26 @@ sub report_rollback
...
@@ -3106,20 +3174,26 @@ sub report_rollback
{
{
if
(
safe_query
(
\@
$queries
))
if
(
safe_query
(
\@
$queries
))
{
{
add_log
(
$limit
,
$safe_query_log
)
;
$dbh
->rollback
;
$dbh
->rollback
;
$dbh
->
{
AutoCommit
}
=
1
;
$dbh
->
{
AutoCommit
}
=
1
;
if
(
safe_query
(
$check
))
{
if
(
safe_query
(
$check
))
{
add_log
(
$limit
,
$safe_query_log
)
;
save_config_data
(
$limit
,
"no"
,
$limit
)
;
save_config_data
(
$limit
,
"no"
,
$limit
)
;
}
else
{
}
else
{
add_log
(
$limit
,
$safe_query_log
)
;
save_config_data
(
$limit
,
"yes"
,
$limit
)
;
save_config_data
(
$limit
,
"yes"
,
$limit
)
;
}
;
}
;
safe_query
(
$clear
)
;
safe_query
(
$clear
)
;
}
else
{
}
else
{
add_log
(
$limit
,
$safe_query_log
)
;
save_config_data
(
$limit
,
"error"
,
$limit
)
;
save_config_data
(
$limit
,
"error"
,
$limit
)
;
}
}
}
}
else
else
{
{
add_log
(
$limit
,
'Couldnt undef Autocommit??'
)
;
save_config_data
(
$limit
,
"error"
,
$limit
)
;
save_config_data
(
$limit
,
"error"
,
$limit
)
;
}
}
safe_query
(
$clear
)
;
safe_query
(
$clear
)
;
...
@@ -3141,8 +3215,14 @@ sub check_and_report
...
@@ -3141,8 +3215,14 @@ sub check_and_report
{
{
save_incomplete
(
$limit
,
$prompt
)
;
save_incomplete
(
$limit
,
$prompt
)
;
$tmp
=
1-safe_query
(
\@
$pre
)
;
$tmp
=
1-safe_query
(
\@
$pre
)
;
$tmp
=
safe_query_result
(
$query
,
$answer
,
$string_type
)
if
(!
$tmp
)
;
add_log
(
$limit
,
$safe_query_log
)
;
if
(!
$tmp
)
{
$tmp
=
safe_query_result
(
$query
,
$answer
,
$string_type
)
;
add_log
(
$limit
,
$safe_query_result_log
)
;
}
;
safe_query
(
\@
$post
)
;
safe_query
(
\@
$post
)
;
add_log
(
$limit
,
$safe_query_log
)
;
delete
$limits
{
$limit
}
;
delete
$limits
{
$limit
}
;
if
(
$function
==
3
)
# Report error as 'no'.
if
(
$function
==
3
)
# Report error as 'no'.
{
{
...
@@ -3180,7 +3260,7 @@ sub try_and_report
...
@@ -3180,7 +3260,7 @@ sub try_and_report
foreach
$test
(
@tests
)
foreach
$test
(
@tests
)
{
{
my
$tmp_type
=
shift
(
@
$test
)
;
my
$tmp_type
=
shift
(
@
$test
)
;
if
(
safe_query
(
\@
$test
))
if
(
safe_query
_l
(
$limit
,
\@
$test
))
{
{
$type
=
$tmp_type
;
$type
=
$tmp_type
;
goto outer
;
goto outer
;
...
@@ -3199,32 +3279,44 @@ sub try_and_report
...
@@ -3199,32 +3279,44 @@ sub try_and_report
sub execute_and_check
sub execute_and_check
{
{
my
(
$pre
,
$query
,
$post
,
$answer
,
$string_type
)=
@_
;
my
(
$
key
,
$
pre
,
$query
,
$post
,
$answer
,
$string_type
)=
@_
;
my
(
$tmp
)
;
my
(
$tmp
)
;
$tmp
=
safe_query
(
\@
$pre
)
;
$tmp
=
safe_query_l
(
$key
,
\@
$pre
)
;
$tmp
=
safe_query_result
(
$query
,
$answer
,
$string_type
)
==
0
if
(
$tmp
)
;
safe_query
(
\@
$post
)
;
$tmp
=
safe_query_result_l
(
$key
,
$query
,
$answer
,
$string_type
)
==
0
if
(
$tmp
)
;
safe_query_l
(
$key
,
\@
$post
)
;
return
$tmp
;
return
$tmp
;
}
}
# returns 0 if ok, 1 if error, -1 if wrong answer
# returns 0 if ok, 1 if error, -1 if wrong answer
# Sets $last_result to value of query
# Sets $last_result to value of query
sub safe_query_result_l
{
my
(
$key
,
$query
,
$answer
,
$result_type
)=
@_
;
my
$r
=
safe_query_result
(
$query
,
$answer
,
$result_type
)
;
add_log
(
$key
,
$safe_query_result_log
)
;
return
$r
;
}
sub safe_query_result
sub safe_query_result
{
{
my
(
$query
,
$answer
,
$result_type
)=
@_
;
my
(
$query
,
$answer
,
$result_type
)=
@_
;
my
(
$sth
,
$row
,
$result
,
$retry
)
;
my
(
$sth
,
$row
,
$result
,
$retry
)
;
undef
(
$last_result
)
;
undef
(
$last_result
)
;
$safe_query_result_log
=
""
;
printf
"
\n
query3: %-80.80s
\n
"
,
$query
if
(
$opt_log_all_queries
)
;
printf
"
\n
query3: %-80.80s
\n
"
,
$query
if
(
$opt_log_all_queries
)
;
print LOG
"
$query
;
\n
"
if
(
$opt_log
)
;
print LOG
"
$query
;
\n
"
if
(
$opt_log
)
;
$safe_query_result_log
=
"<"
.
$query
.
"
\n
"
;
for
(
$retry
=
0
;
$retry
<
$retry_limit
;
$retry
++
)
for
(
$retry
=
0
;
$retry
<
$retry_limit
;
$retry
++
)
{
{
if
(!(
$sth
=
$dbh
->prepare
(
$query
)))
if
(!(
$sth
=
$dbh
->prepare
(
$query
)))
{
{
print_query
(
$query
)
;
print_query
(
$query
)
;
$safe_query_result_log
.
=
"> prepare failed:"
.
$dbh
->errstr.
"
\n
"
;
if
(
$server
->abort_if_fatal_error
())
if
(
$server
->abort_if_fatal_error
())
{
{
check_connect
()
;
# Check that server is still up
check_connect
()
;
# Check that server is still up
...
@@ -3236,6 +3328,7 @@ sub safe_query_result
...
@@ -3236,6 +3328,7 @@ sub safe_query_result
if
(!
$sth
->execute
)
if
(!
$sth
->execute
)
{
{
print_query
(
$query
)
;
print_query
(
$query
)
;
$safe_query_result_log
.
=
"> execute failed:"
.
$dbh
->errstr.
"
\n
"
;
if
(
$server
->abort_if_fatal_error
())
if
(
$server
->abort_if_fatal_error
())
{
{
check_connect
()
;
# Check that server is still up
check_connect
()
;
# Check that server is still up
...
@@ -3252,6 +3345,7 @@ sub safe_query_result
...
@@ -3252,6 +3345,7 @@ sub safe_query_result
if
(!(
$row
=
$sth
->fetchrow_arrayref
))
if
(!(
$row
=
$sth
->fetchrow_arrayref
))
{
{
print
"
\n
query:
$query
didn't return any result
\n
"
if
(
$opt_debug
)
;
print
"
\n
query:
$query
didn't return any result
\n
"
if
(
$opt_debug
)
;
$safe_query_result_log
.
=
"> didn't return any result:"
.
$dbh
->errstr.
"
\n
"
;
$sth
->finish
;
$sth
->finish
;
return
(
$result_type
==
8
)
? 0 : 1
;
return
(
$result_type
==
8
)
? 0 : 1
;
}
}
...
@@ -3262,7 +3356,7 @@ sub safe_query_result
...
@@ -3262,7 +3356,7 @@ sub safe_query_result
}
}
$result
=
0
;
# Ok
$result
=
0
;
# Ok
$last_result
=
$row
->[0]
;
# Save for report_result;
$last_result
=
$row
->[0]
;
# Save for report_result;
$safe_query_result_log
.
=
">"
.
$last_result
.
"
\n
"
;
# Note:
# Note:
# if ($result_type == 2) We accept any return value as answer
# if ($result_type == 2) We accept any return value as answer
...
@@ -3273,34 +3367,55 @@ sub safe_query_result
...
@@ -3273,34 +3367,55 @@ sub safe_query_result
(
abs
(
$row
->[0]
)
+ abs
(
$answer
)))
>
0.01
)
(
abs
(
$row
->[0]
)
+ abs
(
$answer
)))
>
0.01
)
{
{
$result
=
-1
;
$result
=
-1
;
$safe_query_result_log
.
=
"We expected '
$answer
' but got '
$last_result
'
\n
"
;
}
}
}
}
elsif
(
$result_type
==
1
)
# Compare where end space may differ
elsif
(
$result_type
==
1
)
# Compare where end space may differ
{
{
$row
->[0]
=
~ s/
\s
+
$/
/
;
$row
->[0]
=
~ s/
\s
+
$/
/
;
$result
=
-1
if
(
$row
->[0] ne
$answer
)
;
if
(
$row
->[0] ne
$answer
)
{
$result
=
-1
;
$safe_query_result_log
.
=
"We expected '
$answer
' but got '
$last_result
'
\n
"
;
}
;
}
}
elsif
(
$result_type
==
3
)
# This should be a exact match
elsif
(
$result_type
==
3
)
# This should be a exact match
{
{
$result
=
-1
if
(
$row
->[0] ne
$answer
)
;
if
(
$row
->[0] ne
$answer
)
{
$result
=
-1
;
$safe_query_result_log
.
=
"we expected '
$answer
' but got '
$last_result
'
\n
"
;
}
;
}
}
elsif
(
$result_type
==
4
)
# If results should be NULL
elsif
(
$result_type
==
4
)
# If results should be NULL
{
{
$result
=
-1
if
(
defined
(
$row
->[0]
))
;
if
(
defined
(
$row
->[0]
))
{
$result
=
-1
;
$safe_query_result_log
.
=
"We expected NULL but got '
$last_result
'
\n
"
;
}
;
}
}
elsif
(
$result_type
==
5
)
# Result should have given prefix
elsif
(
$result_type
==
5
)
# Result should have given prefix
{
{
$result
=
-1
if
(
length
(
$row
->[0]
)
< length
(
$answer
)
&&
if
(
length
(
$row
->[0]
)
< length
(
$answer
)
&&
substr
(
$row
->[0],1,length
(
$answer
))
ne
$answer
)
;
substr
(
$row
->[0],1,length
(
$answer
))
ne
$answer
)
{
$result
=
-1
;
$safe_query_result_log
.
=
"result must have prefix '
$answer
', but '
$last_result
'
\n
"
;
}
;
}
}
elsif
(
$result_type
==
6
)
# Exact match but ignore errors
elsif
(
$result_type
==
6
)
# Exact match but ignore errors
{
{
$result
=
1
if
(
$row
->[0] ne
$answer
)
;
if
(
$row
->[0] ne
$answer
)
{
$result
=
1
;
$safe_query_result_log
.
=
"We expected '
$answer
' but got '
$last_result
'
\n
"
;
}
;
}
}
elsif
(
$result_type
==
7
)
# Compare against array of numbers
elsif
(
$result_type
==
7
)
# Compare against array of numbers
{
{
if
(
$row
->[0]
!=
$answer
->[0]
)
if
(
$row
->[0]
!=
$answer
->[0]
)
{
{
$safe_query_result_log
.
=
"must be '
$answer
->[0]'
\n
"
;
$result
=
-1
;
$result
=
-1
;
}
}
else
else
...
@@ -3309,16 +3424,20 @@ sub safe_query_result
...
@@ -3309,16 +3424,20 @@ sub safe_query_result
shift
@
$answer
;
shift
@
$answer
;
while
((
$row
=
$sth
->fetchrow_arrayref
))
while
((
$row
=
$sth
->fetchrow_arrayref
))
{
{
$safe_query_result_log
.
=
">
$row
\n
"
;
$value
=
shift
(
@
$answer
)
;
$value
=
shift
(
@
$answer
)
;
if
(!
defined
(
$value
))
if
(!
defined
(
$value
))
{
{
print
"
\n
query:
$query
returned to many results
\n
"
print
"
\n
query:
$query
returned to many results
\n
"
if
(
$opt_debug
)
;
if
(
$opt_debug
)
;
$safe_query_result_log
.
=
"It returned to many results
\n
"
;
$result
=
1
;
$result
=
1
;
last
;
last
;
}
}
if
(
$row
->[0]
!=
$value
)
if
(
$row
->[0]
!=
$value
)
{
{
$safe_query_result_log
.
=
"Must return
$value
here
\n
"
;
$result
=
-1
;
$result
=
-1
;
last
;
last
;
}
}
...
@@ -3327,6 +3446,7 @@ sub safe_query_result
...
@@ -3327,6 +3446,7 @@ sub safe_query_result
{
{
print
"
\n
query:
$query
returned too few results
\n
"
print
"
\n
query:
$query
returned too few results
\n
"
if
(
$opt_debug
)
;
if
(
$opt_debug
)
;
$safe_query_result_log
.
=
"It returned too few results
\n
"
;
$result
=
1
;
$result
=
1
;
}
}
}
}
...
@@ -3345,7 +3465,7 @@ sub safe_query_result
...
@@ -3345,7 +3465,7 @@ sub safe_query_result
sub find_limit
()
sub find_limit
()
{
{
my
(
$prompt
,
$limit
,
$query
)=
@_
;
my
(
$prompt
,
$limit
,
$query
)=
@_
;
my
(
$first
,
$end
,
$i
,
$tmp
)
;
my
(
$first
,
$end
,
$i
,
$tmp
,@tmp_array,
$queries
)
;
print
"
$prompt
: "
;
print
"
$prompt
: "
;
if
(
defined
(
$end
=
$limits
{
$limit
}))
if
(
defined
(
$end
=
$limits
{
$limit
}))
{
{
...
@@ -3353,10 +3473,30 @@ sub find_limit()
...
@@ -3353,10 +3473,30 @@ sub find_limit()
return
$end
;
return
$end
;
}
}
save_incomplete
(
$limit
,
$prompt
)
;
save_incomplete
(
$limit
,
$prompt
)
;
add_log
(
$limit
,
"We are trying (example with N=5):"
)
;
$queries
=
$query
->query
(
5
)
;
if
(
ref
(
$queries
)
ne
"ARRAY"
)
{
push
(
@tmp_array,
$queries
)
;
$queries
=
\@
tmp_array
;
}
foreach
$tmp
(
@
$queries
)
{
add_log
(
$limit
,repr_query
(
$tmp
))
;
}
if
(
defined
(
$queries
=
$query
->check_query
()))
{
if
(
ref
(
$queries
)
ne
"ARRAY"
)
{
@tmp_array
=()
;
push
(
@tmp_array,
$queries
)
;
$queries
=
\@
tmp_array
;
}
foreach
$tmp
(
@
$queries
)
{
add_log
(
$limit
,repr_query
(
$tmp
))
;
}
}
if
(
defined
(
$query
->
{
'init'
})
&&
!
defined
(
$end
=
$limits
{
'restart'
}{
'tohigh'
}))
if
(
defined
(
$query
->
{
'init'
})
&&
!
defined
(
$end
=
$limits
{
'restart'
}{
'tohigh'
}))
{
{
if
(!
safe_query
(
$query
->
{
'init'
}))
if
(!
safe_query
_l
(
$limit
,
$query
->
{
'init'
}))
{
{
$query
->cleanup
()
;
$query
->cleanup
()
;
return
"error"
;
return
"error"
;
...
@@ -3384,7 +3524,7 @@ sub find_limit()
...
@@ -3384,7 +3524,7 @@ sub find_limit()
$end
=
$query
->max_limit
()
;
$end
=
$query
->max_limit
()
;
$i
=
int
((
$end
+
$first
)
/2
)
;
$i
=
int
((
$end
+
$first
)
/2
)
;
}
}
my
$log_str
=
""
;
unless
(
limit_query
(
$query
,0+
$end
))
{
unless
(
limit_query
(
$query
,0+
$end
))
{
while
(
$first
<
$end
)
while
(
$first
<
$end
)
{
{
...
@@ -3393,11 +3533,13 @@ sub find_limit()
...
@@ -3393,11 +3533,13 @@ sub find_limit()
if
(
limit_query
(
$query
,
$i
))
if
(
limit_query
(
$query
,
$i
))
{
{
$first
=
$i
;
$first
=
$i
;
$log_str
.
=
"
$i
:OK"
;
$i
=
$first
+int
((
$end
-
$first
+1
)
/2
)
;
# to be a bit faster to go up
$i
=
$first
+int
((
$end
-
$first
+1
)
/2
)
;
# to be a bit faster to go up
}
}
else
else
{
{
$end
=
$i
-1
;
$end
=
$i
-1
;
$log_str
.
=
"
$i
:FAIL"
;
$i
=
$first
+int
((
$end
-
$first
+4
)
/5
)
;
# Prefere lower on errors
$i
=
$first
+int
((
$end
-
$first
+4
)
/5
)
;
# Prefere lower on errors
}
}
}
}
...
@@ -3409,6 +3551,7 @@ sub find_limit()
...
@@ -3409,6 +3551,7 @@ sub find_limit()
$end
=
$query
->
{
'max_limit'
}
;
$end
=
$query
->
{
'max_limit'
}
;
}
}
print
"
$end
\n
"
;
print
"
$end
\n
"
;
add_log
(
$limit
,
$log_str
)
;
save_config_data
(
$limit
,
$end
,
$prompt
)
;
save_config_data
(
$limit
,
$end
,
$prompt
)
;
delete
$limits
{
'restart'
}
;
delete
$limits
{
'restart'
}
;
return
$end
;
return
$end
;
...
@@ -3460,6 +3603,7 @@ sub read_config_data
...
@@ -3460,6 +3603,7 @@ sub read_config_data
{
{
$limits
{
$key
}=
$limit
eq
"null"
? undef :
$limit
;
$limits
{
$key
}=
$limit
eq
"null"
? undef :
$limit
;
$prompts
{
$key
}=
length
(
$prompt
)
? substr
(
$prompt
,2
)
:
""
;
$prompts
{
$key
}=
length
(
$prompt
)
? substr
(
$prompt
,2
)
:
""
;
$last_read
=
$key
;
delete
$limits
{
'restart'
}
;
delete
$limits
{
'restart'
}
;
}
}
else
else
...
@@ -3473,6 +3617,11 @@ sub read_config_data
...
@@ -3473,6 +3617,11 @@ sub read_config_data
}
}
}
}
}
}
elsif
(
/
\s
*
###(.*)$/) # log line
{
# add log line for previously read key
$log
{
$last_read
}
.
=
"
$1
\n
"
;
}
elsif
(!
/^
\s
*
$/
&&
!
/^
\#
/
)
elsif
(!
/^
\s
*
$/
&&
!
/^
\#
/
)
{
{
die
"Wrong config row:
$_
\n
"
;
die
"Wrong config row:
$_
\n
"
;
...
@@ -3494,6 +3643,18 @@ sub save_config_data
...
@@ -3494,6 +3643,18 @@ sub save_config_data
print CONFIG_FILE
"
$key
=
$limit
\t
#
$prompt
\n
"
;
print CONFIG_FILE
"
$key
=
$limit
\t
#
$prompt
\n
"
;
$limits
{
$key
}=
$limit
;
$limits
{
$key
}=
$limit
;
$limit_changed
=
1
;
$limit_changed
=
1
;
# now write log lines (immediatelly after limits)
my
$line
;
my
$last_line_was_empty
=
0
;
foreach
$line
(
split
/
\n
/,
$log
{
$key
})
{
print CONFIG_FILE
" ###
$line
\n
"
unless
(
(
$last_line_was_empty
eq 1
)
&&
(
$line
=
~ /^
\s
+
$/
)
)
;
$last_line_was_empty
=
(
$line
=
~ /^
\s
+
$/
)
?1:0
;
}
;
if
((
$opt_restart
&&
$limits
{
'operating_system'
}
=
~ /windows/i
)
||
if
((
$opt_restart
&&
$limits
{
'operating_system'
}
=
~ /windows/i
)
||
(
$limits
{
'operating_system'
}
=
~ /NT/
))
(
$limits
{
'operating_system'
}
=
~ /NT/
))
{
{
...
@@ -3504,6 +3665,12 @@ sub save_config_data
...
@@ -3504,6 +3665,12 @@ sub save_config_data
}
}
}
}
sub add_log
{
my
$key
=
shift
;
my
$line
=
shift
;
$log
{
$key
}
.
=
$line
.
"
\n
"
;
}
sub save_all_config_data
sub save_all_config_data
{
{
...
@@ -3523,6 +3690,16 @@ sub save_all_config_data
...
@@ -3523,6 +3690,16 @@ sub save_all_config_data
$tmp
=
"
$key
=
$limits
{
$key
}"
;
$tmp
=
"
$key
=
$limits
{
$key
}"
;
print CONFIG_FILE
$tmp
.
(
"
\t
"
x
(
int
((
32-min
(
length
(
$tmp
)
,32
)
+7
)
/8
)
+1
))
.
print CONFIG_FILE
$tmp
.
(
"
\t
"
x
(
int
((
32-min
(
length
(
$tmp
)
,32
)
+7
)
/8
)
+1
))
.
"#
$prompts
{
$key
}
\n
"
;
"#
$prompts
{
$key
}
\n
"
;
my
$line
;
my
$last_line_was_empty
=
0
;
foreach
$line
(
split
/
\n
/,
$log
{
$key
})
{
print CONFIG_FILE
" ###
$line
\n
"
unless
(
(
$last_line_was_empty
eq 1
)
&&
(
$line
=
~ /^
\s
+
$/
)
)
;
$last_line_was_empty
=
(
$line
=
~ /^
\s
+
$/
)
?1:0
;
}
;
}
}
close CONFIG_FILE
;
close CONFIG_FILE
;
}
}
...
@@ -3800,7 +3977,6 @@ sub new
...
@@ -3800,7 +3977,6 @@ sub new
bless
$self
;
bless
$self
;
}
}
sub query
sub query
{
{
my
(
$self
,
$i
)=
@_
;
my
(
$self
,
$i
)=
@_
;
...
...
sql-bench/server-cfg.sh
View file @
9657cddd
#!@PERL@
#!@PERL@
# -*- perl -*-
# Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
# Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
#
#
# This library is free software; you can redistribute it and/or
# This library is free software; you can redistribute it and/or
...
@@ -671,9 +672,9 @@ sub create
...
@@ -671,9 +672,9 @@ sub create
$field
=
~ s/int
\(\d
*
\)
/int/
;
$field
=
~ s/int
\(\d
*
\)
/int/
;
$field
=
~ s/float
\(\d
*
,
\d
*
\)
/float/
;
$field
=
~ s/float
\(\d
*
,
\d
*
\)
/float/
;
$field
=
~ s/ double/ float/
;
$field
=
~ s/ double/ float/
;
$field
=
~ s/ decimal/ float/i
;
#
$field =~ s/ decimal/ float/i;
$field
=
~ s/ big_decimal/ float/i
;
#
$field =~ s/ big_decimal/ float/i;
$field
=
~ s/
date
/ int/i
;
#
$field =~ s/ date/ int/i;
# Pg doesn't have blob, it has text instead
# Pg doesn't have blob, it has text instead
$field
=
~ s/ blob/ text/
;
$field
=
~ s/ blob/ text/
;
$query
.
=
$field
.
','
;
$query
.
=
$field
.
','
;
...
@@ -946,9 +947,9 @@ sub create
...
@@ -946,9 +947,9 @@ sub create
$field
=
~ s/ double/ float/i
;
$field
=
~ s/ double/ float/i
;
# Solid doesn't have blob, it has long varchar
# Solid doesn't have blob, it has long varchar
$field
=
~ s/ blob/ long varchar/
;
$field
=
~ s/ blob/ long varchar/
;
$field
=
~ s/ decimal/ float/i
;
#
$field =~ s/ decimal/ float/i;
$field
=
~ s/ big_decimal/ float/i
;
#
$field =~ s/ big_decimal/ float/i;
$field
=
~ s/
date
/ int/i
;
#
$field =~ s/ date/ int/i;
$query
.
=
$field
.
','
;
$query
.
=
$field
.
','
;
}
}
substr
(
$query
,-1
)=
")"
;
# Remove last ',';
substr
(
$query
,-1
)=
")"
;
# Remove last ',';
...
@@ -1194,9 +1195,9 @@ sub create
...
@@ -1194,9 +1195,9 @@ sub create
$field
=
~ s/ blob/ text/
;
$field
=
~ s/ blob/ text/
;
$field
=
~ s/ varchar
\(
(
\d
+
)
\)
/ char
(
$1
,3
)
/
;
$field
=
~ s/ varchar
\(
(
\d
+
)
\)
/ char
(
$1
,3
)
/
;
$field
=
~ s/ char
\(
(
\d
+
)
\)
/ char
(
$1
,3
)
/
;
$field
=
~ s/ char
\(
(
\d
+
)
\)
/ char
(
$1
,3
)
/
;
$field
=
~ s/ decimal/ float/i
;
#
$field =~ s/ decimal/ float/i;
$field
=
~ s/ big_decimal/ longfloat/i
;
#
$field =~ s/ big_decimal/ longfloat/i;
$field
=
~ s/
date
/ int/i
;
#
$field =~ s/ date/ int/i;
$field
=
~ s/ float
(
.
*
)
/ float/i
;
$field
=
~ s/ float
(
.
*
)
/ float/i
;
if
(
$field
=
~ / int
\(
(
\d
+
)
\)
/
)
{
if
(
$field
=
~ / int
\(
(
\d
+
)
\)
/
)
{
if
(
$1
>
4
)
{
if
(
$1
>
4
)
{
...
@@ -2896,8 +2897,8 @@ sub create
...
@@ -2896,8 +2897,8 @@ sub create
$query
=
"create table
$table_name
("
;
$query
=
"create table
$table_name
("
;
foreach
$field
(
@
$fields
)
foreach
$field
(
@
$fields
)
{
{
$field
=
~ s/ decimal/ double
(
10,2
)
/i
;
#
$field =~ s/ decimal/ double(10,2)/i;
$field
=
~ s/ big_decimal/ double
(
10,2
)
/i
;
#
$field =~ s/ big_decimal/ double(10,2)/i;
$field
=
~ s/ tinyint
\(
.
*
\)
/ smallint/i
;
$field
=
~ s/ tinyint
\(
.
*
\)
/ smallint/i
;
$field
=
~ s/ smallint
\(
.
*
\)
/ smallint/i
;
$field
=
~ s/ smallint
\(
.
*
\)
/ smallint/i
;
$field
=
~ s/ mediumint/ integer/i
;
$field
=
~ s/ mediumint/ integer/i
;
...
@@ -3092,7 +3093,7 @@ sub create
...
@@ -3092,7 +3093,7 @@ sub create
$query
=
"create table
$table_name
("
;
$query
=
"create table
$table_name
("
;
foreach
$field
(
@
$fields
)
foreach
$field
(
@
$fields
)
{
{
$field
=
~ s/ big_decimal/ decimal/i
;
#
$field =~ s/ big_decimal/ decimal/i;
$field
=
~ s/ double/ double precision/i
;
$field
=
~ s/ double/ double precision/i
;
$field
=
~ s/ tinyint/ smallint/i
;
$field
=
~ s/ tinyint/ smallint/i
;
$field
=
~ s/ mediumint/ integer/i
;
$field
=
~ s/ mediumint/ integer/i
;
...
...
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