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
8bef3771
Commit
8bef3771
authored
Dec 11, 2001
by
monty@hundin.mysql.fi
Browse files
Options
Browse Files
Download
Plain Diff
Merge work:/home/bk/mysql-4.0 into hundin.mysql.fi:/my/bk/mysql-4.0
parents
2bb6ecf1
9ca9fc22
Changes
14
Hide whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
499 additions
and
329 deletions
+499
-329
Docs/manual.texi
Docs/manual.texi
+12
-9
client/mysqltest.c
client/mysqltest.c
+10
-6
innobase/os/os0file.c
innobase/os/os0file.c
+15
-18
myisam/mi_check.c
myisam/mi_check.c
+30
-18
myisam/mi_dynrec.c
myisam/mi_dynrec.c
+8
-4
myisam/myisamdef.h
myisam/myisamdef.h
+1
-1
mysql-test/mysql-test-run.sh
mysql-test/mysql-test-run.sh
+299
-243
mysql-test/r/query_cache.result
mysql-test/r/query_cache.result
+0
-6
mysql-test/t/group_by.test
mysql-test/t/group_by.test
+24
-1
mysql-test/t/query_cache.test
mysql-test/t/query_cache.test
+5
-2
sql/sql_cache.cc
sql/sql_cache.cc
+3
-1
sql/sql_select.cc
sql/sql_select.cc
+11
-8
sql/sql_yacc.yy
sql/sql_yacc.yy
+9
-12
tests/myisam-big-rows.tst
tests/myisam-big-rows.tst
+72
-0
No files found.
Docs/manual.texi
View file @
8bef3771
...
@@ -13637,7 +13637,6 @@ connection between a MySQL server and a MySQL client.
...
@@ -13637,7 +13637,6 @@ connection between a MySQL server and a MySQL client.
If you are using MySQL 4.0, you can also use internal openssl support.
If you are using MySQL 4.0, you can also use internal openssl support.
@xref{Secure connections}.
@xref{Secure connections}.
To make a MySQL system secure, you should strongly consider the
To make a MySQL system secure, you should strongly consider the
following suggestions:
following suggestions:
...
@@ -13653,8 +13652,7 @@ this:
...
@@ -13653,8 +13652,7 @@ this:
@example
@example
shell> mysql -u root mysql
shell> mysql -u root mysql
mysql> UPDATE user SET Password=PASSWORD('new_password')
mysql> UPDATE user SET Password=PASSWORD('new_password') WHERE user='root';
WHERE user='root';
mysql> FLUSH PRIVILEGES;
mysql> FLUSH PRIVILEGES;
@end example
@end example
...
@@ -15396,17 +15394,17 @@ password using the @code{PASSWORD()} function):
...
@@ -15396,17 +15394,17 @@ password using the @code{PASSWORD()} function):
@example
@example
shell> mysql -u root mysql
shell> mysql -u root mysql
mysql> UPDATE user SET Password=PASSWORD('new_password')
mysql> SET PASSWORD FOR root@@localhost=PASSWORD('new_password');
WHERE user='root';
mysql> FLUSH PRIVILEGES;
@end example
@end example
You can, in MySQL Version 3.22 and above, use the @code{SET PASSWORD}
If you know what you are doing, you can also directly manipulate the
statement
:
privilege tables
:
@example
@example
shell> mysql -u root mysql
shell> mysql -u root mysql
mysql> SET PASSWORD FOR root=PASSWORD('new_password');
mysql> UPDATE user SET Password=PASSWORD('new_password')
WHERE user='root';
mysql> FLUSH PRIVILEGES;
@end example
@end example
Another way to set the password is by using the @code{mysqladmin} command:
Another way to set the password is by using the @code{mysqladmin} command:
...
@@ -46287,6 +46285,9 @@ Our TODO section contains what we plan to have in 4.0. @xref{TODO MySQL 4.0}.
...
@@ -46287,6 +46285,9 @@ Our TODO section contains what we plan to have in 4.0. @xref{TODO MySQL 4.0}.
@itemize @bullet
@itemize @bullet
@item
@item
Changed @code{SELECT ... IN SHARE MODE} to
@code{SELECT .. LOCK IN SHARE MODE} (as in MySQL 3.23).
@item
A new query cache to cache results from identical @code{SELECT} queries.
A new query cache to cache results from identical @code{SELECT} queries.
@item
@item
Fixed core dump bug on 64 bit machines when it got a wrong communication
Fixed core dump bug on 64 bit machines when it got a wrong communication
...
@@ -46540,6 +46541,8 @@ not yet 100% confident in this code.
...
@@ -46540,6 +46541,8 @@ not yet 100% confident in this code.
@appendixsubsec Changes in release 3.23.47
@appendixsubsec Changes in release 3.23.47
@itemize @bullet
@itemize @bullet
@item
@item
Fixed that @code{GROUP BY expr DESC} works.
@item
Fixed bug when using @code{t1 LEFT JOIN t2 ON t2.key=constant}.
Fixed bug when using @code{t1 LEFT JOIN t2 ON t2.key=constant}.
@item
@item
@code{mysqlconfig} now also work with binary (relocated) distributions.
@code{mysqlconfig} now also work with binary (relocated) distributions.
client/mysqltest.c
View file @
8bef3771
...
@@ -75,17 +75,21 @@
...
@@ -75,17 +75,21 @@
#define MAX_EXPECTED_ERRORS 10
#define MAX_EXPECTED_ERRORS 10
#define QUERY_SEND 1
#define QUERY_SEND 1
#define QUERY_REAP 2
#define QUERY_REAP 2
#define CON_RETRY_SLEEP 1
/* how long to sleep before trying to connect again*/
#define MAX_CON_TRIES 2
/* sometimes in a test the client starts before
* the server - to solve the problem, we try again
* after some sleep if connection fails the first
* time */
#ifndef MYSQL_MANAGER_PORT
#ifndef MYSQL_MANAGER_PORT
#define MYSQL_MANAGER_PORT 23546
#define MYSQL_MANAGER_PORT 23546
#endif
#endif
/*
Sometimes in a test the client starts before
the server - to solve the problem, we try again
after some sleep if connection fails the first
time
*/
#define CON_RETRY_SLEEP 2
#define MAX_CON_TRIES 5
enum
{
OPT_MANAGER_USER
=
256
,
OPT_MANAGER_HOST
,
OPT_MANAGER_PASSWD
,
enum
{
OPT_MANAGER_USER
=
256
,
OPT_MANAGER_HOST
,
OPT_MANAGER_PASSWD
,
OPT_MANAGER_PORT
,
OPT_MANAGER_WAIT_TIMEOUT
};
OPT_MANAGER_PORT
,
OPT_MANAGER_WAIT_TIMEOUT
};
static
int
record
=
0
,
verbose
=
0
,
silent
=
0
,
opt_sleep
=
0
;
static
int
record
=
0
,
verbose
=
0
,
silent
=
0
,
opt_sleep
=
0
;
static
char
*
db
=
0
,
*
pass
=
0
;
static
char
*
db
=
0
,
*
pass
=
0
;
...
...
innobase/os/os0file.c
View file @
8bef3771
...
@@ -457,14 +457,13 @@ os_file_get_size(
...
@@ -457,14 +457,13 @@ os_file_get_size(
offs
=
lseek
(
file
,
0
,
SEEK_END
);
offs
=
lseek
(
file
,
0
,
SEEK_END
);
if
(
sizeof
(
off_t
)
>
4
)
{
#if SIZEOF_OFF_T > 4
*
size
=
(
ulint
)(
offs
&
0xFFFFFFFF
);
*
size
=
(
ulint
)(
offs
&
0xFFFFFFFF
);
*
size_high
=
(
ulint
)(
offs
>>
32
);
*
size_high
=
(
ulint
)(
offs
>>
32
);
}
else
{
#else
*
size
=
(
ulint
)
offs
;
*
size
=
(
ulint
)
offs
;
*
size_high
=
0
;
*
size_high
=
0
;
}
#endif
return
(
TRUE
);
return
(
TRUE
);
#endif
#endif
}
}
...
@@ -614,18 +613,16 @@ os_file_pread(
...
@@ -614,18 +613,16 @@ os_file_pread(
/* If off_t is > 4 bytes in size, then we assume we can pass a
/* If off_t is > 4 bytes in size, then we assume we can pass a
64-bit address */
64-bit address */
if
(
sizeof
(
off_t
)
>
4
)
{
#if SIZEOF_OFF_T > 4
offs
=
(
off_t
)
offset
+
(((
off_t
)
offset_high
)
<<
32
);
offs
=
(
off_t
)
offset
+
(((
off_t
)
offset_high
)
<<
32
);
#else
}
else
{
offs
=
(
off_t
)
offset
;
offs
=
(
off_t
)
offset
;
if
(
offset_high
>
0
)
{
if
(
offset_high
>
0
)
{
fprintf
(
stderr
,
fprintf
(
stderr
,
"InnoDB: Error: file read at offset > 4 GB
\n
"
);
"InnoDB: Error: file read at offset > 4 GB
\n
"
);
}
}
}
#endif
os_n_file_reads
++
;
os_n_file_reads
++
;
#ifdef HAVE_PREAD
#ifdef HAVE_PREAD
...
...
myisam/mi_check.c
View file @
8bef3771
...
@@ -1288,8 +1288,6 @@ int mi_repair(MI_CHECK *param, register MI_INFO *info,
...
@@ -1288,8 +1288,6 @@ int mi_repair(MI_CHECK *param, register MI_INFO *info,
my_close
(
info
->
dfile
,
MYF
(
0
));
my_close
(
info
->
dfile
,
MYF
(
0
));
info
->
dfile
=
new_file
;
info
->
dfile
=
new_file
;
info
->
state
->
data_file_length
=
sort_info
->
filepos
;
info
->
state
->
data_file_length
=
sort_info
->
filepos
;
/* Only whole records */
share
->
state
.
split
=
info
->
state
->
records
+
info
->
state
->
del
;
share
->
state
.
version
=
(
ulong
)
time
((
time_t
*
)
0
);
/* Force reopen */
share
->
state
.
version
=
(
ulong
)
time
((
time_t
*
)
0
);
/* Force reopen */
}
}
else
else
...
@@ -1962,7 +1960,6 @@ int mi_repair_by_sort(MI_CHECK *param, register MI_INFO *info,
...
@@ -1962,7 +1960,6 @@ int mi_repair_by_sort(MI_CHECK *param, register MI_INFO *info,
share
->
state
.
state
.
data_file_length
=
info
->
state
->
data_file_length
share
->
state
.
state
.
data_file_length
=
info
->
state
->
data_file_length
=
sort_info
->
filepos
;
=
sort_info
->
filepos
;
/* Only whole records */
/* Only whole records */
share
->
state
.
split
=
info
->
state
->
records
+
info
->
state
->
del
;
share
->
state
.
version
=
(
ulong
)
time
((
time_t
*
)
0
);
share
->
state
.
version
=
(
ulong
)
time
((
time_t
*
)
0
);
my_close
(
info
->
dfile
,
MYF
(
0
));
my_close
(
info
->
dfile
,
MYF
(
0
));
info
->
dfile
=
new_file
;
info
->
dfile
=
new_file
;
...
@@ -2183,9 +2180,11 @@ static int sort_get_next_record(SORT_INFO *sort_info)
...
@@ -2183,9 +2180,11 @@ static int sort_get_next_record(SORT_INFO *sort_info)
}
}
sort_info
->
start_recpos
=
sort_info
->
pos
;
sort_info
->
start_recpos
=
sort_info
->
pos
;
if
(
!
sort_info
->
fix_datafile
)
if
(
!
sort_info
->
fix_datafile
)
{
sort_info
->
filepos
=
sort_info
->
pos
;
sort_info
->
filepos
=
sort_info
->
pos
;
share
->
state
.
split
++
;
}
sort_info
->
max_pos
=
(
sort_info
->
pos
+=
share
->
base
.
pack_reclength
);
sort_info
->
max_pos
=
(
sort_info
->
pos
+=
share
->
base
.
pack_reclength
);
share
->
state
.
split
++
;
if
(
*
sort_info
->
record
)
if
(
*
sort_info
->
record
)
{
{
if
(
param
->
calc_checksum
)
if
(
param
->
calc_checksum
)
...
@@ -2356,7 +2355,8 @@ static int sort_get_next_record(SORT_INFO *sort_info)
...
@@ -2356,7 +2355,8 @@ static int sort_get_next_record(SORT_INFO *sort_info)
continue
;
continue
;
}
}
share
->
state
.
split
++
;
if
(
!
sort_info
->
fix_datafile
&&
(
b_type
&
BLOCK_DELETED
))
share
->
state
.
split
++
;
if
(
!
found_record
++
)
if
(
!
found_record
++
)
{
{
sort_info
->
find_length
=
left_length
=
block_info
.
rec_len
;
sort_info
->
find_length
=
left_length
=
block_info
.
rec_len
;
...
@@ -2494,10 +2494,12 @@ static int sort_get_next_record(SORT_INFO *sort_info)
...
@@ -2494,10 +2494,12 @@ static int sort_get_next_record(SORT_INFO *sort_info)
}
}
info
->
checksum
=
mi_checksum
(
info
,
sort_info
->
record
);
info
->
checksum
=
mi_checksum
(
info
,
sort_info
->
record
);
if
(
!
sort_info
->
fix_datafile
)
if
(
!
sort_info
->
fix_datafile
)
{
sort_info
->
filepos
=
sort_info
->
pos
;
sort_info
->
filepos
=
sort_info
->
pos
;
share
->
state
.
split
++
;
}
sort_info
->
max_pos
=
(
sort_info
->
pos
=
block_info
.
filepos
+
sort_info
->
max_pos
=
(
sort_info
->
pos
=
block_info
.
filepos
+
block_info
.
rec_len
);
block_info
.
rec_len
);
share
->
state
.
split
++
;
info
->
packed_length
=
block_info
.
rec_len
;
info
->
packed_length
=
block_info
.
rec_len
;
if
(
param
->
calc_checksum
)
if
(
param
->
calc_checksum
)
param
->
glob_crc
+=
info
->
checksum
;
param
->
glob_crc
+=
info
->
checksum
;
...
@@ -2535,6 +2537,7 @@ int sort_write_record(SORT_INFO *sort_info)
...
@@ -2535,6 +2537,7 @@ int sort_write_record(SORT_INFO *sort_info)
DBUG_RETURN
(
1
);
DBUG_RETURN
(
1
);
}
}
sort_info
->
filepos
+=
share
->
base
.
pack_reclength
;
sort_info
->
filepos
+=
share
->
base
.
pack_reclength
;
info
->
s
->
state
.
split
++
;
/* sort_info->param->glob_crc+=mi_static_checksum(info, sort_info->record); */
/* sort_info->param->glob_crc+=mi_static_checksum(info, sort_info->record); */
break
;
break
;
case
DYNAMIC_RECORD
:
case
DYNAMIC_RECORD
:
...
@@ -2559,20 +2562,28 @@ int sort_write_record(SORT_INFO *sort_info)
...
@@ -2559,20 +2562,28 @@ int sort_write_record(SORT_INFO *sort_info)
}
}
info
->
checksum
=
mi_checksum
(
info
,
sort_info
->
record
);
info
->
checksum
=
mi_checksum
(
info
,
sort_info
->
record
);
reclength
=
_mi_rec_pack
(
info
,
from
,
sort_info
->
record
);
reclength
=
_mi_rec_pack
(
info
,
from
,
sort_info
->
record
);
/* sort_info->param->glob_crc+=info->checksum; */
block_length
=
reclength
+
3
+
test
(
reclength
>=
(
65520
-
3
));
if
(
block_length
<
share
->
base
.
min_block_length
)
block_length
=
share
->
base
.
min_block_length
;
flag
=
0
;
flag
=
0
;
info
->
update
|=
HA_STATE_WRITE_AT_END
;
/* sort_info->param->glob_crc+=info->checksum; */
block_length
=
MY_ALIGN
(
block_length
,
MI_DYN_ALIGN_SIZE
);
if
(
_mi_write_part_record
(
info
,
0L
,
block_length
,
HA_OFFSET_ERROR
,
do
&
from
,
&
reclength
,
&
flag
))
{
{
mi_check_print_error
(
param
,
"%d when writing to datafile"
,
my_errno
);
block_length
=
reclength
+
3
+
test
(
reclength
>=
(
65520
-
3
));
DBUG_RETURN
(
1
);
if
(
block_length
<
share
->
base
.
min_block_length
)
}
block_length
=
share
->
base
.
min_block_length
;
sort_info
->
filepos
+=
block_length
;
info
->
update
|=
HA_STATE_WRITE_AT_END
;
block_length
=
MY_ALIGN
(
block_length
,
MI_DYN_ALIGN_SIZE
);
if
(
block_length
>
MI_MAX_BLOCK_LENGTH
)
block_length
=
MI_MAX_BLOCK_LENGTH
;
if
(
_mi_write_part_record
(
info
,
0L
,
block_length
,
sort_info
->
filepos
+
block_length
,
&
from
,
&
reclength
,
&
flag
))
{
mi_check_print_error
(
param
,
"%d when writing to datafile"
,
my_errno
);
DBUG_RETURN
(
1
);
}
sort_info
->
filepos
+=
block_length
;
info
->
s
->
state
.
split
++
;
}
while
(
reclength
);
/* sort_info->param->glob_crc+=info->checksum; */
/* sort_info->param->glob_crc+=info->checksum; */
break
;
break
;
case
COMPRESSED_RECORD
:
case
COMPRESSED_RECORD
:
...
@@ -2588,6 +2599,7 @@ int sort_write_record(SORT_INFO *sort_info)
...
@@ -2588,6 +2599,7 @@ int sort_write_record(SORT_INFO *sort_info)
}
}
/* sort_info->param->glob_crc+=info->checksum; */
/* sort_info->param->glob_crc+=info->checksum; */
sort_info
->
filepos
+=
reclength
+
length
;
sort_info
->
filepos
+=
reclength
+
length
;
info
->
s
->
state
.
split
++
;
break
;
break
;
}
}
}
}
...
...
myisam/mi_dynrec.c
View file @
8bef3771
...
@@ -64,11 +64,13 @@ int _mi_write_blob_record(MI_INFO *info, const byte *record)
...
@@ -64,11 +64,13 @@ int _mi_write_blob_record(MI_INFO *info, const byte *record)
MI_DYN_DELETE_BLOCK_HEADER
+
1
;
MI_DYN_DELETE_BLOCK_HEADER
+
1
;
reclength
=
info
->
s
->
base
.
pack_reclength
+
reclength
=
info
->
s
->
base
.
pack_reclength
+
_my_calc_total_blob_length
(
info
,
record
)
+
extra
;
_my_calc_total_blob_length
(
info
,
record
)
+
extra
;
#ifdef NOT_USED
/* We now support big rows */
if
(
reclength
>
MI_DYN_MAX_ROW_LENGTH
)
if
(
reclength
>
MI_DYN_MAX_ROW_LENGTH
)
{
{
my_errno
=
HA_ERR_TO_BIG_ROW
;
my_errno
=
HA_ERR_TO_BIG_ROW
;
return
-
1
;
return
-
1
;
}
}
#endif
if
(
!
(
rec_buff
=
(
byte
*
)
my_alloca
(
reclength
)))
if
(
!
(
rec_buff
=
(
byte
*
)
my_alloca
(
reclength
)))
{
{
my_errno
=
ENOMEM
;
my_errno
=
ENOMEM
;
...
@@ -93,11 +95,13 @@ int _mi_update_blob_record(MI_INFO *info, my_off_t pos, const byte *record)
...
@@ -93,11 +95,13 @@ int _mi_update_blob_record(MI_INFO *info, my_off_t pos, const byte *record)
MI_DYN_DELETE_BLOCK_HEADER
;
MI_DYN_DELETE_BLOCK_HEADER
;
reclength
=
info
->
s
->
base
.
pack_reclength
+
reclength
=
info
->
s
->
base
.
pack_reclength
+
_my_calc_total_blob_length
(
info
,
record
)
+
extra
;
_my_calc_total_blob_length
(
info
,
record
)
+
extra
;
#ifdef NOT_USED
/* We now support big rows */
if
(
reclength
>
MI_DYN_MAX_ROW_LENGTH
)
if
(
reclength
>
MI_DYN_MAX_ROW_LENGTH
)
{
{
my_errno
=
HA_ERR_TO_BIG_ROW
;
my_errno
=
HA_ERR_TO_BIG_ROW
;
return
-
1
;
return
-
1
;
}
}
#endif
if
(
!
(
rec_buff
=
(
byte
*
)
my_alloca
(
reclength
)))
if
(
!
(
rec_buff
=
(
byte
*
)
my_alloca
(
reclength
)))
{
{
my_errno
=
ENOMEM
;
my_errno
=
ENOMEM
;
...
@@ -130,14 +134,14 @@ static int write_dynamic_record(MI_INFO *info, const byte *record,
...
@@ -130,14 +134,14 @@ static int write_dynamic_record(MI_INFO *info, const byte *record,
DBUG_ENTER
(
"write_dynamic_record"
);
DBUG_ENTER
(
"write_dynamic_record"
);
flag
=
0
;
flag
=
0
;
while
(
reclength
)
do
{
{
if
(
_mi_find_writepos
(
info
,
reclength
,
&
filepos
,
&
length
))
if
(
_mi_find_writepos
(
info
,
reclength
,
&
filepos
,
&
length
))
goto
err
;
goto
err
;
if
(
_mi_write_part_record
(
info
,
filepos
,
length
,
info
->
s
->
state
.
dellink
,
if
(
_mi_write_part_record
(
info
,
filepos
,
length
,
info
->
s
->
state
.
dellink
,
(
byte
**
)
&
record
,
&
reclength
,
&
flag
))
(
byte
**
)
&
record
,
&
reclength
,
&
flag
))
goto
err
;
goto
err
;
}
}
while
(
reclength
);
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
err:
err:
...
@@ -377,7 +381,7 @@ int _mi_write_part_record(MI_INFO *info,
...
@@ -377,7 +381,7 @@ int _mi_write_part_record(MI_INFO *info,
head_length
=
16
;
head_length
=
16
;
temp
[
0
]
=
13
;
temp
[
0
]
=
13
;
mi_int4store
(
temp
+
1
,
*
reclength
);
mi_int4store
(
temp
+
1
,
*
reclength
);
mi_int3store
(
temp
+
4
,
length
-
head_length
);
mi_int3store
(
temp
+
5
,
length
-
head_length
);
mi_sizestore
((
byte
*
)
temp
+
8
,
next_filepos
);
mi_sizestore
((
byte
*
)
temp
+
8
,
next_filepos
);
}
}
else
else
...
@@ -1441,7 +1445,7 @@ uint _mi_get_block_info(MI_BLOCK_INFO *info, File file, my_off_t filepos)
...
@@ -1441,7 +1445,7 @@ uint _mi_get_block_info(MI_BLOCK_INFO *info, File file, my_off_t filepos)
DBUG_DUMP
(
"header"
,(
byte
*
)
header
,
MI_BLOCK_INFO_HEADER_LENGTH
);
DBUG_DUMP
(
"header"
,(
byte
*
)
header
,
MI_BLOCK_INFO_HEADER_LENGTH
);
if
(
info
->
second_read
)
if
(
info
->
second_read
)
{
{
if
(
info
->
header
[
0
]
<=
6
)
if
(
info
->
header
[
0
]
<=
6
||
info
->
header
[
0
]
==
13
)
return_val
=
BLOCK_SYNC_ERROR
;
return_val
=
BLOCK_SYNC_ERROR
;
}
}
else
else
...
...
myisam/myisamdef.h
View file @
8bef3771
...
@@ -359,7 +359,7 @@ struct st_myisam_info {
...
@@ -359,7 +359,7 @@ struct st_myisam_info {
#define MI_DYN_MAX_ROW_LENGTH (MI_DYN_MAX_BLOCK_LENGTH - MI_SPLIT_LENGTH)
#define MI_DYN_MAX_ROW_LENGTH (MI_DYN_MAX_BLOCK_LENGTH - MI_SPLIT_LENGTH)
#define MI_DYN_ALIGN_SIZE 4
/* Align blocks on this */
#define MI_DYN_ALIGN_SIZE 4
/* Align blocks on this */
#define MI_MAX_DYN_HEADER_BYTE 13
/* max header byte for dynamic rows */
#define MI_MAX_DYN_HEADER_BYTE 13
/* max header byte for dynamic rows */
#define MI_MAX_BLOCK_LENGTH (((
ulong) 1 << 24)-1
)
#define MI_MAX_BLOCK_LENGTH (((
(ulong) 1 << 24)-1) & (~ (ulong) (MI_DYN_ALIGN_SIZE-1))
)
#define MEMMAP_EXTRA_MARGIN 7
/* Write this as a suffix for file */
#define MEMMAP_EXTRA_MARGIN 7
/* Write this as a suffix for file */
...
...
mysql-test/mysql-test-run.sh
View file @
8bef3771
...
@@ -43,6 +43,39 @@ which ()
...
@@ -43,6 +43,39 @@ which ()
}
}
sleep_until_file_deleted
()
{
file
=
$1
loop
=
$SLEEP_TIME
while
(
test
$loop
-gt
0
)
do
sleep
1
if
[
!
-f
$file
]
then
return
fi
loop
=
`
expr
$loop
- 1
`
done
}
sleep_until_file_exists
()
{
file
=
$1
loop
=
60
# Should be long enough enough for all cases
while
(
test
$loop
-gt
0
)
do
sleep
1
if
[
-f
$file
]
then
return
fi
loop
=
`
expr
$loop
- 1
`
done
echo
"ERROR:
$file
was not created in 60 seconds; Aborting"
exit
1
;
}
# No paths below as we can't be sure where the program is!
# No paths below as we can't be sure where the program is!
BASENAME
=
`
which
basename
|
head
-1
`
BASENAME
=
`
which
basename
|
head
-1
`
...
@@ -91,7 +124,7 @@ else
...
@@ -91,7 +124,7 @@ else
BINARY_DIST
=
1
BINARY_DIST
=
1
fi
fi
#BASEDIR is always one above mysql-test directory
#BASEDIR is always one above mysql-test directory
CWD
=
`
pwd
`
CWD
=
`
pwd
`
cd
..
cd
..
BASEDIR
=
`
pwd
`
BASEDIR
=
`
pwd
`
...
@@ -101,7 +134,7 @@ export MYSQL_TEST_DIR
...
@@ -101,7 +134,7 @@ export MYSQL_TEST_DIR
STD_DATA
=
$MYSQL_TEST_DIR
/std_data
STD_DATA
=
$MYSQL_TEST_DIR
/std_data
hostname
=
`
hostname
`
# Installed in the mysql privilege table
hostname
=
`
hostname
`
# Installed in the mysql privilege table
MANAGER_QUIET_OPT
=
"-q"
MANAGER_QUIET_OPT
=
"-q"
TESTDIR
=
"
$MYSQL_TEST_DIR
/t"
TESTDIR
=
"
$MYSQL_TEST_DIR
/t"
TESTSUFFIX
=
test
TESTSUFFIX
=
test
TOT_SKIP
=
0
TOT_SKIP
=
0
...
@@ -139,7 +172,7 @@ DO_GCOV=""
...
@@ -139,7 +172,7 @@ DO_GCOV=""
DO_GDB
=
""
DO_GDB
=
""
DO_DDD
=
""
DO_DDD
=
""
DO_CLIENT_GDB
=
""
DO_CLIENT_GDB
=
""
SLEEP_TIME
=
2
SLEEP_TIME
=
10
CHARACTER_SET
=
latin1
CHARACTER_SET
=
latin1
DBUSER
=
""
DBUSER
=
""
START_WAIT_TIMEOUT
=
3
START_WAIT_TIMEOUT
=
3
...
@@ -176,7 +209,7 @@ while test $# -gt 0; do
...
@@ -176,7 +209,7 @@ while test $# -gt 0; do
;;
;;
--start-and-exit
)
--start-and-exit
)
START_AND_EXIT
=
1
START_AND_EXIT
=
1
;;
;;
--skip-innobase
)
--skip-innobase
)
EXTRA_MASTER_MYSQLD_OPT
=
"
$EXTRA_MASTER_MYSQLD_OPT
--skip-innobase"
EXTRA_MASTER_MYSQLD_OPT
=
"
$EXTRA_MASTER_MYSQLD_OPT
--skip-innobase"
EXTRA_SLAVE_MYSQLD_OPT
=
"
$EXTRA_SLAVE_MYSQLD_OPT
--skip-innobase"
;;
EXTRA_SLAVE_MYSQLD_OPT
=
"
$EXTRA_SLAVE_MYSQLD_OPT
--skip-innobase"
;;
...
@@ -195,7 +228,7 @@ while test $# -gt 0; do
...
@@ -195,7 +228,7 @@ while test $# -gt 0; do
--bench
)
--bench
)
DO_BENCH
=
1
DO_BENCH
=
1
NO_SLAVE
=
1
NO_SLAVE
=
1
;;
;;
--big
*
)
# Actually --big-test
--big
*
)
# Actually --big-test
EXTRA_MYSQL_TEST_OPT
=
"
$EXTRA_MYSQL_TEST_OPT
$1
"
;;
EXTRA_MYSQL_TEST_OPT
=
"
$EXTRA_MYSQL_TEST_OPT
$1
"
;;
--compress
)
--compress
)
...
@@ -218,7 +251,7 @@ while test $# -gt 0; do
...
@@ -218,7 +251,7 @@ while test $# -gt 0; do
;;
;;
--gprof
)
--gprof
)
DO_GPROF
=
1
DO_GPROF
=
1
;;
;;
--gdb
)
--gdb
)
START_WAIT_TIMEOUT
=
300
START_WAIT_TIMEOUT
=
300
STOP_WAIT_TIMEOUT
=
300
STOP_WAIT_TIMEOUT
=
300
...
@@ -249,7 +282,7 @@ while test $# -gt 0; do
...
@@ -249,7 +282,7 @@ while test $# -gt 0; do
;;
;;
--strace-client
)
--strace-client
)
STRACE_CLIENT
=
1
STRACE_CLIENT
=
1
;;
;;
--debug
)
--debug
)
EXTRA_MASTER_MYSQLD_OPT
=
"
$EXTRA_MASTER_MYSQLD_OPT
\
EXTRA_MASTER_MYSQLD_OPT
=
"
$EXTRA_MASTER_MYSQLD_OPT
\
--debug=d:t:i:O,
$MYSQL_TEST_DIR
/var/log/master.trace"
--debug=d:t:i:O,
$MYSQL_TEST_DIR
/var/log/master.trace"
...
@@ -292,7 +325,7 @@ if [ x$SOURCE_DIST = x1 ] ; then
...
@@ -292,7 +325,7 @@ if [ x$SOURCE_DIST = x1 ] ; then
MY_BASEDIR
=
$MYSQL_TEST_DIR
MY_BASEDIR
=
$MYSQL_TEST_DIR
else
else
MY_BASEDIR
=
$BASEDIR
MY_BASEDIR
=
$BASEDIR
fi
fi
# Create the directories
# Create the directories
...
@@ -321,7 +354,7 @@ if [ x$SOURCE_DIST = x1 ] ; then
...
@@ -321,7 +354,7 @@ if [ x$SOURCE_DIST = x1 ] ; then
if
[
-n
"
$STRACE_CLIENT
"
]
;
then
if
[
-n
"
$STRACE_CLIENT
"
]
;
then
MYSQL_TEST
=
"strace -o
$MYSQL_TEST_DIR
/var/log/mysqltest.strace
$MYSQL_TEST
"
MYSQL_TEST
=
"strace -o
$MYSQL_TEST_DIR
/var/log/mysqltest.strace
$MYSQL_TEST
"
fi
fi
MYSQLADMIN
=
"
$BASEDIR
/client/mysqladmin"
MYSQLADMIN
=
"
$BASEDIR
/client/mysqladmin"
MYSQL_MANAGER_CLIENT
=
"
$BASEDIR
/client/mysqlmanagerc"
MYSQL_MANAGER_CLIENT
=
"
$BASEDIR
/client/mysqlmanagerc"
MYSQL_MANAGER
=
"
$BASEDIR
/tools/mysqlmanager"
MYSQL_MANAGER
=
"
$BASEDIR
/tools/mysqlmanager"
...
@@ -339,7 +372,7 @@ else
...
@@ -339,7 +372,7 @@ else
MYSQL_MANAGER_PWGEN
=
"
$BASEDIR
/bin/mysqlmanager-pwgen"
MYSQL_MANAGER_PWGEN
=
"
$BASEDIR
/bin/mysqlmanager-pwgen"
MYSQL
=
"
$BASEDIR
/bin/mysql"
MYSQL
=
"
$BASEDIR
/bin/mysql"
INSTALL_DB
=
"./install_test_db -bin"
INSTALL_DB
=
"./install_test_db -bin"
if
test
-d
"
$BASEDIR
/share/mysql/english"
if
test
-d
"
$BASEDIR
/share/mysql/english"
then
then
LANGUAGE
=
"
$BASEDIR
/share/mysql/english/"
LANGUAGE
=
"
$BASEDIR
/share/mysql/english/"
CHARSETSDIR
=
"
$BASEDIR
/share/mysql/charsets"
CHARSETSDIR
=
"
$BASEDIR
/share/mysql/charsets"
...
@@ -409,12 +442,12 @@ show_failed_diff ()
...
@@ -409,12 +442,12 @@ show_failed_diff ()
reject_file
=
r/
$1
.reject
reject_file
=
r/
$1
.reject
result_file
=
r/
$1
.result
result_file
=
r/
$1
.result
eval_file
=
r/
$1
.eval
eval_file
=
r/
$1
.eval
if
[
-f
$eval_file
]
if
[
-f
$eval_file
]
then
then
result_file
=
$eval_file
result_file
=
$eval_file
fi
fi
if
[
-x
"
$DIFF
"
]
&&
[
-f
$reject_file
]
if
[
-x
"
$DIFF
"
]
&&
[
-f
$reject_file
]
then
then
echo
"Below are the diffs between actual and expected results:"
echo
"Below are the diffs between actual and expected results:"
...
@@ -424,7 +457,7 @@ show_failed_diff ()
...
@@ -424,7 +457,7 @@ show_failed_diff ()
echo
"Please follow the instructions outlined at"
echo
"Please follow the instructions outlined at"
echo
"http://www.mysql.com/doc/R/e/Reporting_mysqltest_bugs.html"
echo
"http://www.mysql.com/doc/R/e/Reporting_mysqltest_bugs.html"
echo
"to find the reason to this problem and how to report this."
echo
"to find the reason to this problem and how to report this."
fi
fi
}
}
do_gdb_test
()
do_gdb_test
()
...
@@ -469,12 +502,12 @@ report_stats () {
...
@@ -469,12 +502,12 @@ report_stats () {
if
[
$TOT_FAIL
=
0
]
;
then
if
[
$TOT_FAIL
=
0
]
;
then
$ECHO
"All
$TOT_TEST
tests were successful."
$ECHO
"All
$TOT_TEST
tests were successful."
else
else
xten
=
`
$EXPR
$TOT_PASS
\*
10000
`
xten
=
`
$EXPR
$TOT_PASS
\*
10000
`
raw
=
`
$EXPR
$xten
/
$TOT_TEST
`
raw
=
`
$EXPR
$xten
/
$TOT_TEST
`
raw
=
`
$PRINTF
%.4d
$raw
`
raw
=
`
$PRINTF
%.4d
$raw
`
whole
=
`
$PRINTF
%.2s
$raw
`
whole
=
`
$PRINTF
%.2s
$raw
`
xwhole
=
`
$EXPR
$whole
\*
100
`
xwhole
=
`
$EXPR
$whole
\*
100
`
deci
=
`
$EXPR
$raw
-
$xwhole
`
deci
=
`
$EXPR
$raw
-
$xwhole
`
$ECHO
"Failed
${
TOT_FAIL
}
/
${
TOT_TEST
}
tests,
${
whole
}
.
${
deci
}
% successful."
$ECHO
"Failed
${
TOT_FAIL
}
/
${
TOT_TEST
}
tests,
${
whole
}
.
${
deci
}
% successful."
$ECHO
""
$ECHO
""
$ECHO
"The log files in
$MYSQL_TEST_DIR
/var/log may give you some hint"
$ECHO
"The log files in
$MYSQL_TEST_DIR
/var/log may give you some hint"
...
@@ -500,23 +533,21 @@ mysql_install_db () {
...
@@ -500,23 +533,21 @@ mysql_install_db () {
error
"Could not install slave test DBs"
error
"Could not install slave test DBs"
exit
1
exit
1
fi
fi
for
slave_num
in
1 2
;
for
slave_num
in
1 2
;
do
do
rm
-rf
var/slave
$slave_num
-data
/
$RM
-rf
var/slave
$slave_num
-data
/
mkdir
-p
var/slave
$slave_num
-data
/mysql
mkdir
-p
var/slave
$slave_num
-data
/mysql
mkdir
-p
var/slave
$slave_num
-data
/test
mkdir
-p
var/slave
$slave_num
-data
/test
cp
var/slave-data/mysql/
*
var/slave
$slave_num
-data
/mysql
cp
var/slave-data/mysql/
*
var/slave
$slave_num
-data
/mysql
done
done
# Give mysqld some time to die.
sleep
$SLEEP_TIME
return
0
return
0
}
}
gprof_prepare
()
gprof_prepare
()
{
{
rm
-rf
$GPROF_DIR
$RM
-rf
$GPROF_DIR
mkdir
-p
$GPROF_DIR
mkdir
-p
$GPROF_DIR
}
}
gprof_collect
()
gprof_collect
()
...
@@ -556,7 +587,7 @@ abort_if_failed()
...
@@ -556,7 +587,7 @@ abort_if_failed()
if
[
!
$?
=
0
]
;
then
if
[
!
$?
=
0
]
;
then
echo
$1
echo
$1
exit
1
exit
1
fi
fi
}
}
start_manager
()
start_manager
()
...
@@ -575,7 +606,7 @@ start_manager()
...
@@ -575,7 +606,7 @@ start_manager()
fi
fi
fi
fi
rm
-f
$MANAGER_PID_FILE
$RM
-f
$MANAGER_PID_FILE
MYSQL_MANAGER_PW
=
`
$MYSQL_MANAGER_PWGEN
-u
$MYSQL_MANAGER_USER
\
MYSQL_MANAGER_PW
=
`
$MYSQL_MANAGER_PWGEN
-u
$MYSQL_MANAGER_USER
\
-o
$MYSQL_MANAGER_PW_FILE
`
-o
$MYSQL_MANAGER_PW_FILE
`
$MYSQL_MANAGER
--log
=
$MYSQL_MANAGER_LOG
--port
=
$MYSQL_MANAGER_PORT
\
$MYSQL_MANAGER
--log
=
$MYSQL_MANAGER_LOG
--port
=
$MYSQL_MANAGER_PORT
\
...
@@ -613,7 +644,7 @@ manager_launch()
...
@@ -613,7 +644,7 @@ manager_launch()
shift
shift
if
[
$USE_MANAGER
=
0
]
;
then
if
[
$USE_MANAGER
=
0
]
;
then
$@
>
$CUR_MYERR
2>&1 &
$@
>
$CUR_MYERR
2>&1 &
sleep
2
#hack
sleep
2
#hack
return
return
fi
fi
$MYSQL_MANAGER_CLIENT
$MANAGER_QUIET_OPT
--user
=
$MYSQL_MANAGER_USER
\
$MYSQL_MANAGER_CLIENT
$MANAGER_QUIET_OPT
--user
=
$MYSQL_MANAGER_USER
\
...
@@ -646,181 +677,186 @@ EOF
...
@@ -646,181 +677,186 @@ EOF
start_master
()
start_master
()
{
{
if
[
x
$MASTER_RUNNING
=
x1
]
||
[
x
$LOCAL_MASTER
=
x1
]
;
then
if
[
x
$MASTER_RUNNING
=
x1
]
||
[
x
$LOCAL_MASTER
=
x1
]
;
then
return
return
fi
fi
# Remove old berkeley db log files that can confuse the server
# Remove old berkeley db log files that can confuse the server
$RM
-f
$MASTER_MYDDIR
/log.
*
$RM
-f
$MASTER_MYDDIR
/log.
*
# Remove stale binary logs
# Remove stale binary logs
$RM
-f
$MYSQL_TEST_DIR
/var/log/master-bin.
*
$RM
-f
$MYSQL_TEST_DIR
/var/log/master-bin.
*
#run master initialization shell script if one exists
if
[
-f
"
$master_init_script
"
]
;
#run master initialization shell script if one exists
then
/bin/sh
$master_init_script
if
[
-f
"
$master_init_script
"
]
;
fi
then
cd
$BASEDIR
# for gcov
/bin/sh
$master_init_script
#start master
fi
if
[
-z
"
$DO_BENCH
"
]
cd
$BASEDIR
# for gcov
then
#start master
master_args
=
"--no-defaults --log-bin=
$MYSQL_TEST_DIR
/var/log/master-bin
\
if
[
-z
"
$DO_BENCH
"
]
--server-id=1 --rpl-recovery-rank=1
\
then
--basedir=
$MY_BASEDIR
--init-rpl-role=master
\
master_args
=
"--no-defaults --log-bin=
$MYSQL_TEST_DIR
/var/log/master-bin
\
--port=
$MASTER_MYPORT
\
--server-id=1 --rpl-recovery-rank=1
\
--exit-info=256
\
--basedir=
$MY_BASEDIR
--init-rpl-role=master
\
--core
\
--port=
$MASTER_MYPORT
\
--datadir=
$MASTER_MYDDIR
\
--exit-info=256
\
--pid-file=
$MASTER_MYPID
\
--core
\
--socket=
$MASTER_MYSOCK
\
--datadir=
$MASTER_MYDDIR
\
--log=
$MASTER_MYLOG
\
--pid-file=
$MASTER_MYPID
\
--character-sets-dir=
$CHARSETSDIR
\
--socket=
$MASTER_MYSOCK
\
--default-character-set=
$CHARACTER_SET
\
--log=
$MASTER_MYLOG
\
--tmpdir=
$MYSQL_TMP_DIR
\
--character-sets-dir=
$CHARSETSDIR
\
--language=
$LANGUAGE
\
--default-character-set=
$CHARACTER_SET
\
--innodb_data_file_path=ibdata1:50M
\
--tmpdir=
$MYSQL_TMP_DIR
\
$SMALL_SERVER
\
--language=
$LANGUAGE
\
$EXTRA_MASTER_OPT
$EXTRA_MASTER_MYSQLD_OPT
"
--innodb_data_file_path=ibdata1:50M
\
else
$SMALL_SERVER
\
master_args
=
"--no-defaults --log-bin=
$MYSQL_TEST_DIR
/var/log/master-bin
\
$EXTRA_MASTER_OPT
$EXTRA_MASTER_MYSQLD_OPT
"
--server-id=1 --rpl-recovery-rank=1
\
else
--basedir=
$MY_BASEDIR
--init-rpl-role=master
\
master_args
=
"--no-defaults --log-bin=
$MYSQL_TEST_DIR
/var/log/master-bin
\
--port=
$MASTER_MYPORT
\
--server-id=1 --rpl-recovery-rank=1
\
--datadir=
$MASTER_MYDDIR
\
--basedir=
$MY_BASEDIR
--init-rpl-role=master
\
--pid-file=
$MASTER_MYPID
\
--port=
$MASTER_MYPORT
\
--socket=
$MASTER_MYSOCK
\
--datadir=
$MASTER_MYDDIR
\
--character-sets-dir=
$CHARSETSDIR
\
--pid-file=
$MASTER_MYPID
\
--default-character-set=
$CHARACTER_SET
\
--socket=
$MASTER_MYSOCK
\
--core
\
--character-sets-dir=
$CHARSETSDIR
\
--tmpdir=
$MYSQL_TMP_DIR
\
--default-character-set=
$CHARACTER_SET
\
--language=
$LANGUAGE
\
--core
\
--innodb_data_file_path=ibdata1:50M
\
--tmpdir=
$MYSQL_TMP_DIR
\
$SMALL_SERVER
\
--language=
$LANGUAGE
\
$EXTRA_MASTER_OPT
$EXTRA_MASTER_MYSQLD_OPT
"
--innodb_data_file_path=ibdata1:50M
\
fi
$SMALL_SERVER
\
$EXTRA_MASTER_OPT
$EXTRA_MASTER_MYSQLD_OPT
"
CUR_MYERR
=
$MASTER_MYERR
fi
CUR_MYSOCK
=
$MASTER_MYSOCK
CUR_MYERR
=
$MASTER_MYERR
if
[
x
$DO_DDD
=
x1
]
CUR_MYSOCK
=
$MASTER_MYSOCK
then
$ECHO
"set args
$master_args
"
>
$GDB_MASTER_INIT
if
[
x
$DO_DDD
=
x1
]
manager_launch master ddd
-display
$DISPLAY
--debugger
\
then
"gdb -x
$GDB_MASTER_INIT
"
$MYSQLD
$ECHO
"set args
$master_args
"
>
$GDB_MASTER_INIT
elif
[
x
$DO_GDB
=
x1
]
manager_launch master ddd
-display
$DISPLAY
--debugger
\
then
"gdb -x
$GDB_MASTER_INIT
"
$MYSQLD
(
echo set
args
$master_args
;
elif
[
x
$DO_GDB
=
x1
]
if
[
$USE_MANAGER
=
0
]
;
then
then
cat
<<
EOF
(
echo set
args
$master_args
;
if
[
$USE_MANAGER
=
0
]
;
then
cat
<<
EOF
b mysql_parse
b mysql_parse
commands 1
commands 1
disa 1
disa 1
end
end
r
r
EOF
EOF
fi
)
>
$GDB_MASTER_INIT
fi
)
>
$GDB_MASTER_INIT
manager_launch master
$XTERM
-display
$DISPLAY
\
manager_launch master
$XTERM
-display
$DISPLAY
\
-title
"Master"
-e
gdb
-x
$GDB_MASTER_INIT
$MYSQLD
-title
"Master"
-e
gdb
-x
$GDB_MASTER_INIT
$MYSQLD
else
else
manager_launch master
$MYSQLD
$master_args
manager_launch master
$MYSQLD
$master_args
fi
fi
sleep_until_file_exists
$MASTER_MYPID
MASTER_RUNNING
=
1
MASTER_RUNNING
=
1
}
}
start_slave
()
start_slave
()
{
{
[
x
$SKIP_SLAVE
=
x1
]
&&
return
[
x
$SKIP_SLAVE
=
x1
]
&&
return
eval
"this_slave_running=
\$
SLAVE
$1_RUNNING
"
eval
"this_slave_running=
\$
SLAVE
$1_RUNNING
"
[
x
$this_slave_running
=
1
]
&&
return
[
x
$this_slave_running
=
1
]
&&
return
#when testing fail-safe replication, we will have more than one slave
#when testing fail-safe replication, we will have more than one slave
#in this case, we start secondary slaves with an argument
#in this case, we start secondary slaves with an argument
slave_ident
=
"slave
$1
"
slave_ident
=
"slave
$1
"
if
[
-n
"
$1
"
]
;
if
[
-n
"
$1
"
]
;
then
then
slave_server_id
=
`
$EXPR
2 +
$1
`
slave_server_id
=
`
$EXPR
2 +
$1
`
slave_rpl_rank
=
$slave_server_id
slave_rpl_rank
=
$slave_server_id
slave_port
=
`
expr
$SLAVE_MYPORT
+
$1
`
slave_port
=
`
expr
$SLAVE_MYPORT
+
$1
`
slave_log
=
"
$SLAVE_MYLOG
.
$1
"
slave_log
=
"
$SLAVE_MYLOG
.
$1
"
slave_err
=
"
$SLAVE_MYERR
.
$1
"
slave_err
=
"
$SLAVE_MYERR
.
$1
"
slave_datadir
=
"var/
$slave_ident
-data/"
slave_datadir
=
"var/
$slave_ident
-data/"
slave_pid
=
"
$MYRUN_DIR
/mysqld-
$slave_ident
.pid"
slave_pid
=
"
$MYRUN_DIR
/mysqld-
$slave_ident
.pid"
slave_sock
=
"
$SLAVE_MYSOCK
-
$1
"
slave_sock
=
"
$SLAVE_MYSOCK
-
$1
"
else
else
slave_server_id
=
2
slave_server_id
=
2
slave_rpl_rank
=
2
slave_rpl_rank
=
2
slave_port
=
$SLAVE_MYPORT
slave_port
=
$SLAVE_MYPORT
slave_log
=
$SLAVE_MYLOG
slave_log
=
$SLAVE_MYLOG
slave_err
=
$SLAVE_MYERR
slave_err
=
$SLAVE_MYERR
slave_datadir
=
$SLAVE_MYDDIR
slave_datadir
=
$SLAVE_MYDDIR
slave_pid
=
$SLAVE_MYPID
slave_pid
=
$SLAVE_MYPID
slave_sock
=
"
$SLAVE_MYSOCK
"
slave_sock
=
"
$SLAVE_MYSOCK
"
fi
fi
# Remove stale binary logs
# Remove stale binary logs
$RM
-f
$MYSQL_TEST_DIR
/var/log/
$slave_ident
-bin
.
*
$RM
-f
$MYSQL_TEST_DIR
/var/log/
$slave_ident
-bin
.
*
#run slave initialization shell script if one exists
#run slave initialization shell script if one exists
if
[
-f
"
$slave_init_script
"
]
;
if
[
-f
"
$slave_init_script
"
]
;
then
then
/bin/sh
$slave_init_script
/bin/sh
$slave_init_script
fi
fi
if
[
-z
"
$SLAVE_MASTER_INFO
"
]
;
then
if
[
-z
"
$SLAVE_MASTER_INFO
"
]
;
then
master_info
=
"--master-user=root
\
master_info
=
"--master-user=root
\
--master-connect-retry=1
\
--master-connect-retry=1
\
--master-host=127.0.0.1
\
--master-host=127.0.0.1
\
--master-password=
\
--master-password=
\
--master-port=
$MASTER_MYPORT
\
--master-port=
$MASTER_MYPORT
\
--server-id=
$slave_server_id
--rpl-recovery-rank=
$slave_rpl_rank
"
--server-id=
$slave_server_id
--rpl-recovery-rank=
$slave_rpl_rank
"
else
else
master_info
=
$SLAVE_MASTER_INFO
master_info
=
$SLAVE_MASTER_INFO
fi
fi
$RM
-f
$slave_datadir
/log.
*
$RM
-f
$slave_datadir
/log.
*
slave_args
=
"--no-defaults
$master_info
\
slave_args
=
"--no-defaults
$master_info
\
--exit-info=256
\
--exit-info=256
\
--log-bin=
$MYSQL_TEST_DIR
/var/log/
$slave_ident
-bin
\
--log-bin=
$MYSQL_TEST_DIR
/var/log/
$slave_ident
-bin
\
--log-slave-updates
\
--log-slave-updates
\
--log=
$slave_log
\
--log=
$slave_log
\
--basedir=
$MY_BASEDIR
\
--basedir=
$MY_BASEDIR
\
--datadir=
$slave_datadir
\
--datadir=
$slave_datadir
\
--pid-file=
$slave_pid
\
--pid-file=
$slave_pid
\
--port=
$slave_port
\
--port=
$slave_port
\
--socket=
$slave_sock
\
--socket=
$slave_sock
\
--character-sets-dir=
$CHARSETSDIR
\
--character-sets-dir=
$CHARSETSDIR
\
--default-character-set=
$CHARACTER_SET
\
--default-character-set=
$CHARACTER_SET
\
--core --init-rpl-role=slave
\
--core --init-rpl-role=slave
\
--tmpdir=
$MYSQL_TMP_DIR
\
--tmpdir=
$MYSQL_TMP_DIR
\
--language=
$LANGUAGE
\
--language=
$LANGUAGE
\
--skip-innodb --skip-slave-start
\
--skip-innodb --skip-slave-start
\
--slave-load-tmpdir=
$SLAVE_LOAD_TMPDIR
\
--slave-load-tmpdir=
$SLAVE_LOAD_TMPDIR
\
--report-host=127.0.0.1 --report-user=root
\
--report-host=127.0.0.1 --report-user=root
\
--report-port=
$slave_port
\
--report-port=
$slave_port
\
--master-retry-count=5
\
--master-retry-count=5
\
$SMALL_SERVER
\
$SMALL_SERVER
\
$EXTRA_SLAVE_OPT
$EXTRA_SLAVE_MYSQLD_OPT
"
$EXTRA_SLAVE_OPT
$EXTRA_SLAVE_MYSQLD_OPT
"
CUR_MYERR
=
$slave_err
CUR_MYERR
=
$slave_err
CUR_MYSOCK
=
$slave_sock
CUR_MYSOCK
=
$slave_sock
if
[
x
$DO_DDD
=
x1
]
if
[
x
$DO_DDD
=
x1
]
then
then
$ECHO
"set args
$master_args
"
>
$GDB_SLAVE_INIT
$ECHO
"set args
$master_args
"
>
$GDB_SLAVE_INIT
manager_launch
$slave_ident
ddd
-display
$DISPLAY
--debugger
\
manager_launch
$slave_ident
ddd
-display
$DISPLAY
--debugger
\
"gdb -x
$GDB_SLAVE_INIT
"
$SLAVE_MYSQLD
"gdb -x
$GDB_SLAVE_INIT
"
$SLAVE_MYSQLD
elif
[
x
$DO_GDB
=
x1
]
elif
[
x
$DO_GDB
=
x1
]
then
then
$ECHO
"set args
$slave_args
"
>
$GDB_SLAVE_INIT
$ECHO
"set args
$slave_args
"
>
$GDB_SLAVE_INIT
manager_launch
$slave_ident
$XTERM
-display
$DISPLAY
-title
"Slave"
-e
\
manager_launch
$slave_ident
$XTERM
-display
$DISPLAY
-title
"Slave"
-e
\
gdb
-x
$GDB_SLAVE_INIT
$SLAVE_MYSQLD
gdb
-x
$GDB_SLAVE_INIT
$SLAVE_MYSQLD
else
else
manager_launch
$slave_ident
$SLAVE_MYSQLD
$slave_args
manager_launch
$slave_ident
$SLAVE_MYSQLD
$slave_args
fi
fi
eval
"SLAVE
$1_RUNNING
=1"
eval
"SLAVE
$1_RUNNING
=1"
sleep_until_file_exists
$slave_pid
}
}
mysql_start
()
{
mysql_start
()
$ECHO
"Starting MySQL daemon"
{
start_master
$ECHO
"Starting MySQL daemon"
start_slave
start_master
cd
$MYSQL_TEST_DIR
start_slave
return
1
cd
$MYSQL_TEST_DIR
return
1
}
}
stop_slave
()
stop_slave
()
...
@@ -832,7 +868,7 @@ stop_slave ()
...
@@ -832,7 +868,7 @@ stop_slave ()
slave_pid
=
"
$MYRUN_DIR
/mysqld-
$slave_ident
.pid"
slave_pid
=
"
$MYRUN_DIR
/mysqld-
$slave_ident
.pid"
else
else
slave_pid
=
$SLAVE_MYPID
slave_pid
=
$SLAVE_MYPID
fi
fi
if
[
x
$this_slave_running
=
x1
]
if
[
x
$this_slave_running
=
x1
]
then
then
manager_term
$slave_ident
manager_term
$slave_ident
...
@@ -840,17 +876,17 @@ stop_slave ()
...
@@ -840,17 +876,17 @@ stop_slave ()
then
# try harder!
then
# try harder!
$ECHO
"slave not cooperating with mysqladmin, will try manual kill"
$ECHO
"slave not cooperating with mysqladmin, will try manual kill"
kill
`
$CAT
$slave_pid
`
kill
`
$CAT
$slave_pid
`
sleep
$SLEEP_TIME
sleep
_until_file_deleted
$slave_pid
if
[
-f
$
SLAVE_MYPID
]
;
then
if
[
-f
$
slave_pid
]
;
then
$ECHO
"slave refused to die. Sending SIGKILL"
$ECHO
"slave refused to die. Sending SIGKILL"
kill
-9
`
$CAT
$slave_pid
`
kill
-9
`
$CAT
$slave_pid
`
$RM
-f
$slave_pid
$RM
-f
$slave_pid
else
else
$ECHO
"slave responded to SIGTERM "
$ECHO
"slave responded to SIGTERM "
fi
fi
fi
fi
eval
"SLAVE
$1_RUNNING
=0"
eval
"SLAVE
$1_RUNNING
=0"
fi
fi
}
}
stop_master
()
stop_master
()
...
@@ -862,13 +898,13 @@ stop_master ()
...
@@ -862,13 +898,13 @@ stop_master ()
then
# try harder!
then
# try harder!
$ECHO
"master not cooperating with mysqladmin, will try manual kill"
$ECHO
"master not cooperating with mysqladmin, will try manual kill"
kill
`
$CAT
$MASTER_MYPID
`
kill
`
$CAT
$MASTER_MYPID
`
sleep
$SLEEP_TIME
sleep
_until_file_deleted
$MASTER_MYPID
if
[
-f
$MASTER_MYPID
]
;
then
if
[
-f
$MASTER_MYPID
]
;
then
$ECHO
"master refused to die. Sending SIGKILL"
$ECHO
"master refused to die. Sending SIGKILL"
kill
-9
`
$CAT
$MASTER_MYPID
`
kill
-9
`
$CAT
$MASTER_MYPID
`
$RM
-f
$MASTER_MYPID
$RM
-f
$MASTER_MYPID
else
else
$ECHO
"master responded to SIGTERM "
$ECHO
"master responded to SIGTERM "
fi
fi
fi
fi
MASTER_RUNNING
=
0
MASTER_RUNNING
=
0
...
@@ -886,21 +922,20 @@ mysql_stop ()
...
@@ -886,21 +922,20 @@ mysql_stop ()
stop_slave 1
stop_slave 1
stop_slave 2
stop_slave 2
$ECHO
"Slave shutdown finished"
$ECHO
"Slave shutdown finished"
return
1
return
1
}
}
mysql_restart
()
{
mysql_restart
()
{
mysql_stop
mysql_stop
mysql_start
mysql_start
return
1
return
1
}
}
mysql_loadstd
()
{
mysql_loadstd
()
{
# cp $STD_DATA/*.frm $STD_DATA/*.MRG $MASTER_MYDDIR/test
# cp $STD_DATA/*.frm $STD_DATA/*.MRG $MASTER_MYDDIR/test
return
1
return
1
}
}
...
@@ -916,9 +951,9 @@ run_testcase ()
...
@@ -916,9 +951,9 @@ run_testcase ()
SKIP_SLAVE
=
`
$EXPR
\(
$tname
: rpl
\)
=
0
`
SKIP_SLAVE
=
`
$EXPR
\(
$tname
: rpl
\)
=
0
`
if
[
$USE_MANAGER
=
1
]
;
then
if
[
$USE_MANAGER
=
1
]
;
then
many_slaves
=
`
$EXPR
\(
$tname
: rpl_failsafe
\)
!=
0
`
many_slaves
=
`
$EXPR
\(
$tname
: rpl_failsafe
\)
!=
0
`
fi
fi
if
[
-n
"
$SKIP_TEST
"
]
;
then
if
[
-n
"
$SKIP_TEST
"
]
;
then
SKIP_THIS_TEST
=
`
$EXPR
\(
$tname
:
"
$SKIP_TEST
"
\)
!=
0
`
SKIP_THIS_TEST
=
`
$EXPR
\(
$tname
:
"
$SKIP_TEST
"
\)
!=
0
`
if
[
x
$SKIP_THIS_TEST
=
x1
]
;
if
[
x
$SKIP_THIS_TEST
=
x1
]
;
then
then
...
@@ -926,7 +961,7 @@ run_testcase ()
...
@@ -926,7 +961,7 @@ run_testcase ()
fi
fi
fi
fi
if
[
-n
"
$DO_TEST
"
]
;
then
if
[
-n
"
$DO_TEST
"
]
;
then
DO_THIS_TEST
=
`
$EXPR
\(
$tname
:
"
$DO_TEST
"
\)
!=
0
`
DO_THIS_TEST
=
`
$EXPR
\(
$tname
:
"
$DO_TEST
"
\)
!=
0
`
if
[
x
$DO_THIS_TEST
=
x0
]
;
if
[
x
$DO_THIS_TEST
=
x0
]
;
then
then
...
@@ -961,10 +996,10 @@ run_testcase ()
...
@@ -961,10 +996,10 @@ run_testcase ()
EXTRA_MASTER_OPT
=
""
EXTRA_MASTER_OPT
=
""
stop_master
stop_master
start_master
start_master
fi
fi
fi
fi
do_slave_restart
=
0
do_slave_restart
=
0
if
[
-f
$slave_opt_file
]
;
if
[
-f
$slave_opt_file
]
;
then
then
EXTRA_SLAVE_OPT
=
`
$CAT
$slave_opt_file
`
EXTRA_SLAVE_OPT
=
`
$CAT
$slave_opt_file
`
...
@@ -973,8 +1008,8 @@ run_testcase ()
...
@@ -973,8 +1008,8 @@ run_testcase ()
if
[
!
-z
"
$EXTRA_SLAVE_OPT
"
]
||
[
x
$SLAVE_RUNNING
!=
x1
]
;
if
[
!
-z
"
$EXTRA_SLAVE_OPT
"
]
||
[
x
$SLAVE_RUNNING
!=
x1
]
;
then
then
EXTRA_SLAVE_OPT
=
""
EXTRA_SLAVE_OPT
=
""
do_slave_restart
=
1
do_slave_restart
=
1
fi
fi
fi
fi
if
[
-f
$slave_master_info_file
]
;
then
if
[
-f
$slave_master_info_file
]
;
then
...
@@ -984,8 +1019,8 @@ run_testcase ()
...
@@ -984,8 +1019,8 @@ run_testcase ()
if
[
!
-z
"
$SLAVE_MASTER_INFO
"
]
||
[
x
$SLAVE_RUNNING
!=
x1
]
;
if
[
!
-z
"
$SLAVE_MASTER_INFO
"
]
||
[
x
$SLAVE_RUNNING
!=
x1
]
;
then
then
SLAVE_MASTER_INFO
=
""
SLAVE_MASTER_INFO
=
""
do_slave_restart
=
1
do_slave_restart
=
1
fi
fi
fi
fi
if
[
x
$do_slave_restart
=
x1
]
;
then
if
[
x
$do_slave_restart
=
x1
]
;
then
...
@@ -998,7 +1033,7 @@ run_testcase ()
...
@@ -998,7 +1033,7 @@ run_testcase ()
fi
fi
fi
fi
cd
$MYSQL_TEST_DIR
cd
$MYSQL_TEST_DIR
if
[
-f
$tf
]
;
then
if
[
-f
$tf
]
;
then
$RM
-f
r/
$tname
.
*
reject
$RM
-f
r/
$tname
.
*
reject
mysql_test_args
=
"-R r/
$tname
.result
$EXTRA_MYSQL_TEST_OPT
"
mysql_test_args
=
"-R r/
$tname
.result
$EXTRA_MYSQL_TEST_OPT
"
...
@@ -1007,7 +1042,7 @@ run_testcase ()
...
@@ -1007,7 +1042,7 @@ run_testcase ()
else
else
do_gdb_test
"
$mysql_test_args
"
"
$tf
"
do_gdb_test
"
$mysql_test_args
"
"
$tf
"
fi
fi
res
=
$?
res
=
$?
if
[
$res
=
0
]
;
then
if
[
$res
=
0
]
;
then
...
@@ -1028,12 +1063,12 @@ run_testcase ()
...
@@ -1028,12 +1063,12 @@ run_testcase ()
timestr
=
"
$USERT
$SYST
$REALT
"
timestr
=
"
$USERT
$SYST
$REALT
"
pname
=
`
$ECHO
"
$tname
"
|
$CUT
-c
1-24
`
pname
=
`
$ECHO
"
$tname
"
|
$CUT
-c
1-24
`
RES
=
"
$pname
$timestr
"
RES
=
"
$pname
$timestr
"
if
[
x
$many_slaves
=
x1
]
;
then
if
[
x
$many_slaves
=
x1
]
;
then
stop_slave 1
stop_slave 1
stop_slave 2
stop_slave 2
fi
fi
if
[
$res
=
0
]
;
then
if
[
$res
=
0
]
;
then
total_inc
total_inc
pass_inc
pass_inc
...
@@ -1061,7 +1096,7 @@ run_testcase ()
...
@@ -1061,7 +1096,7 @@ run_testcase ()
fi
fi
exit
1
exit
1
fi
fi
if
[
-z
"
$DO_GDB
"
]
&&
[
-z
"
$USE_RUNNING_SERVER
"
]
&&
[
-z
"
$DO_DDD
"
]
if
[
-z
"
$DO_GDB
"
]
&&
[
-z
"
$USE_RUNNING_SERVER
"
]
&&
[
-z
"
$DO_DDD
"
]
then
then
mysql_restart
mysql_restart
...
@@ -1073,26 +1108,47 @@ run_testcase ()
...
@@ -1073,26 +1108,47 @@ run_testcase ()
fi
fi
}
}
######################################################################
######################################################################
# Main script starts here
# Main script starts here
######################################################################
######################################################################
[
"
$DO_GCOV
"
-a
!
-x
"
$GCOV
"
]
&&
error
"No gcov found"
[
"
$DO_GCOV
"
-a
!
-x
"
$GCOV
"
]
&&
error
"No gcov found"
[
"
$DO_GCOV
"
]
&&
gcov_prepare
[
"
$DO_GCOV
"
]
&&
gcov_prepare
[
"
$DO_GPROF
"
]
&&
gprof_prepare
[
"
$DO_GPROF
"
]
&&
gprof_prepare
# Ensure that no old mysqld test servers are running
if
[
-z
"
$USE_RUNNING_SERVER
"
]
if
[
-z
"
$USE_RUNNING_SERVER
"
]
then
then
# Ensure that no old mysqld test servers are running
$MYSQLADMIN
--no-defaults
--socket
=
$MASTER_MYSOCK
-u
root
-O
connect_timeout
=
5
-O
shutdown_timeout
=
20 shutdown
>
/dev/null 2>&1
$MYSQLADMIN
--no-defaults
--socket
=
$MASTER_MYSOCK
-u
root
-O
connect_timeout
=
5
-O
shutdown_timeout
=
20 shutdown
>
/dev/null 2>&1
$MYSQLADMIN
--no-defaults
--socket
=
$SLAVE_MYSOCK
-u
root
-O
connect_timeout
=
5
-O
shutdown_timeout
=
20 shutdown
>
/dev/null 2>&1
$MYSQLADMIN
--no-defaults
--socket
=
$SLAVE_MYSOCK
-u
root
-O
connect_timeout
=
5
-O
shutdown_timeout
=
20 shutdown
>
/dev/null 2>&1
$MYSQLADMIN
--no-defaults
--host
=
$hostname
--port
=
$MASTER_MYPORT
-u
root
-O
connect_timeout
=
5
-O
shutdown_timeout
=
20 shutdown
>
/dev/null 2>&1
$MYSQLADMIN
--no-defaults
--host
=
$hostname
--port
=
$SLAVE_MYPORT
-u
root
-O
connect_timeout
=
5
-O
shutdown_timeout
=
20 shutdown
>
/dev/null 2>&1
$MYSQLADMIN
--no-defaults
--host
=
$hostname
--port
=
`
expr
$SLAVE_MYPORT
+ 1
`
-u
root
-O
connect_timeout
=
5
-O
shutdown_timeout
=
20 shutdown
>
/dev/null 2>&1
sleep_until_file_deleted
$MASTER_MYPID
sleep_until_file_deleted
$SLAVE_MYPID
# Kill any running managers
if
[
-f
"
$MANAGER_PID_FILE
"
]
then
kill
`
cat
$MANAGER_PID_FILE
`
sleep
1
if
[
-f
"
$MANAGER_PID_FILE
"
]
then
kill
-9
`
cat
$MANAGER_PID_FILE
`
sleep
1
fi
fi
# Remove files that can cause problems
$RM
-f
$MYSQL_TEST_DIR
/var/run/
*
$MYSQL_TEST_DIR
/var/tmp/
*
$ECHO
"Installing Test Databases"
$ECHO
"Installing Test Databases"
mysql_install_db
mysql_install_db
start_manager
start_manager
#do not automagically start deamons if we are in gdb or running only one test
#case
# Do not automagically start deamons if we are in gdb or running only one test
# case
if
[
-z
"
$DO_GDB
"
]
&&
[
-z
"
$DO_DDD
"
]
if
[
-z
"
$DO_GDB
"
]
&&
[
-z
"
$DO_DDD
"
]
then
then
mysql_start
mysql_start
...
@@ -1110,24 +1166,24 @@ $ECHO "Starting Tests"
...
@@ -1110,24 +1166,24 @@ $ECHO "Starting Tests"
if
[
"
$DO_BENCH
"
=
1
]
if
[
"
$DO_BENCH
"
=
1
]
then
then
BENCHDIR
=
$BASEDIR
/sql-bench/
BENCHDIR
=
$BASEDIR
/sql-bench/
savedir
=
`
pwd
`
savedir
=
`
pwd
`
cd
$BENCHDIR
cd
$BENCHDIR
if
[
-z
"
$1
"
]
if
[
-z
"
$1
"
]
then
./run-all-tests
--socket
=
$MASTER_MYSOCK
--user
=
root
else
if
[
-x
"./
$1
"
]
then
then
./
$1
--socket
=
$MASTER_MYSOCK
--user
=
root
./run-all-tests
--socket
=
$MASTER_MYSOCK
--user
=
root
else
else
echo
"benchmark
$1
not found"
if
[
-x
"./
$1
"
]
then
./
$1
--socket
=
$MASTER_MYSOCK
--user
=
root
else
echo
"benchmark
$1
not found"
fi
fi
fi
fi
cd
$savedir
cd
$savedir
mysql_stop
mysql_stop
stop_manager
stop_manager
exit
exit
fi
fi
$ECHO
$ECHO
...
@@ -1145,7 +1201,7 @@ then
...
@@ -1145,7 +1201,7 @@ then
done
done
$RM
-f
$TIMEFILE
# Remove for full test
$RM
-f
$TIMEFILE
# Remove for full test
fi
fi
else
else
while
[
!
-z
"
$1
"
]
;
do
while
[
!
-z
"
$1
"
]
;
do
tname
=
`
$BASENAME
$1
.test
`
tname
=
`
$BASENAME
$1
.test
`
tf
=
$TESTDIR
/
$tname
.
$TESTSUFFIX
tf
=
$TESTDIR
/
$tname
.
$TESTSUFFIX
...
...
mysql-test/r/query_cache.result
View file @
8bef3771
...
@@ -291,10 +291,4 @@ show status like "Qcache_queries_in_cache";
...
@@ -291,10 +291,4 @@ show status like "Qcache_queries_in_cache";
Variable_name Value
Variable_name Value
Qcache_queries_in_cache 2
Qcache_queries_in_cache 2
reset query cache;
reset query cache;
show variables like "query_cache_size";
Variable_name Value
query_cache_size 1039700
show status like "Qcache_free_memory";
Variable_name Value
Qcache_free_memory 1039700
drop table t1;
drop table t1;
mysql-test/t/group_by.test
View file @
8bef3771
...
@@ -38,7 +38,6 @@ INSERT INTO t2 VALUES (3,'name','pass','mail','Y','v','n','adr','1','1','1');
...
@@ -38,7 +38,6 @@ INSERT INTO t2 VALUES (3,'name','pass','mail','Y','v','n','adr','1','1','1');
SELECT
t2
.
userid
,
MIN
(
t1
.
score
)
FROM
t1
,
t2
WHERE
t1
.
userID
=
t2
.
userID
GROUP
BY
t2
.
userid
;
SELECT
t2
.
userid
,
MIN
(
t1
.
score
)
FROM
t1
,
t2
WHERE
t1
.
userID
=
t2
.
userID
GROUP
BY
t2
.
userid
;
SELECT
t2
.
userid
,
MIN
(
t1
.
score
)
FROM
t1
,
t2
WHERE
t1
.
userID
=
t2
.
userID
AND
t1
.
spID
=
2
GROUP
BY
t2
.
userid
;
SELECT
t2
.
userid
,
MIN
(
t1
.
score
)
FROM
t1
,
t2
WHERE
t1
.
userID
=
t2
.
userID
AND
t1
.
spID
=
2
GROUP
BY
t2
.
userid
;
SELECT
t2
.
userid
,
MIN
(
t1
.
score
+
0.0
)
FROM
t1
,
t2
WHERE
t1
.
userID
=
t2
.
userID
AND
t1
.
spID
=
2
GROUP
BY
t2
.
userid
;
SELECT
t2
.
userid
,
MIN
(
t1
.
score
+
0.0
)
FROM
t1
,
t2
WHERE
t1
.
userID
=
t2
.
userID
AND
t1
.
spID
=
2
GROUP
BY
t2
.
userid
;
drop
table
test
.
t1
,
test
.
t2
;
drop
table
test
.
t1
,
test
.
t2
;
#
#
...
@@ -220,3 +219,27 @@ select 1+1, "a",count(*) from t1 where foo in (2);
...
@@ -220,3 +219,27 @@ select 1+1, "a",count(*) from t1 where foo in (2);
insert
into
t1
values
(
1
);
insert
into
t1
values
(
1
);
select
1
+
1
,
"a"
,
count
(
*
)
from
t1
where
foo
in
(
2
);
select
1
+
1
,
"a"
,
count
(
*
)
from
t1
where
foo
in
(
2
);
drop
table
t1
;
drop
table
t1
;
#
# Test GROUP BY DESC
CREATE
TABLE
t1
(
spID
int
(
10
)
unsigned
,
userID
int
(
10
)
unsigned
,
score
smallint
(
5
)
unsigned
,
key
(
spid
),
key
(
score
)
);
INSERT
INTO
t1
VALUES
(
1
,
1
,
1
),(
2
,
2
,
2
),(
2
,
1
,
1
),(
3
,
3
,
3
),(
4
,
3
,
3
),(
5
,
3
,
3
);
explain
select
userid
,
count
(
*
)
from
t1
group
by
userid
desc
;
select
userid
,
count
(
*
)
from
t1
group
by
userid
desc
;
explain
select
spid
,
count
(
*
)
from
t1
where
spid
between
1
and
2
group
by
spid
desc
;
explain
select
spid
,
count
(
*
)
from
t1
where
spid
between
1
and
2
group
by
spid
;
select
spid
,
count
(
*
)
from
t1
where
spid
between
1
and
2
group
by
spid
;
select
spid
,
count
(
*
)
from
t1
where
spid
between
1
and
2
group
by
spid
desc
;
explain
select
sql_big_result
spid
,
sum
(
userid
)
from
t1
group
by
spid
desc
;
select
sql_big_result
spid
,
sum
(
userid
)
from
t1
group
by
spid
desc
;
explain
select
sql_big_result
score
,
count
(
*
)
from
t1
group
by
score
desc
;
select
sql_big_result
score
,
count
(
*
)
from
t1
group
by
score
desc
;
drop
table
t1
;
mysql-test/t/query_cache.test
View file @
8bef3771
...
@@ -178,6 +178,9 @@ enable_result_log;
...
@@ -178,6 +178,9 @@ enable_result_log;
show
status
like
"Qcache_hits"
;
show
status
like
"Qcache_hits"
;
show
status
like
"Qcache_queries_in_cache"
;
show
status
like
"Qcache_queries_in_cache"
;
reset
query
cache
;
reset
query
cache
;
show
variables
like
"query_cache_size"
;
show
status
like
"Qcache_free_memory"
;
drop
table
t1
;
drop
table
t1
;
# The following tests can't be done as the values differen on 32 and 64 bit
# machines :(
#show variables like "query_cache_size";
#show status like "Qcache_free_memory";
sql/sql_cache.cc
View file @
8bef3771
...
@@ -2672,6 +2672,7 @@ uint Query_cache::filename_2_table_key (char *key, const char *path)
...
@@ -2672,6 +2672,7 @@ uint Query_cache::filename_2_table_key (char *key, const char *path)
void
Query_cache
::
wreck
(
uint
line
,
const
char
*
message
)
void
Query_cache
::
wreck
(
uint
line
,
const
char
*
message
)
{
{
THD
*
thd
=
current_thd
;
DBUG_ENTER
(
"Query_cache::wreck"
);
DBUG_ENTER
(
"Query_cache::wreck"
);
query_cache_size
=
0
;
query_cache_size
=
0
;
if
(
*
message
)
if
(
*
message
)
...
@@ -2679,7 +2680,8 @@ void Query_cache::wreck(uint line, const char *message)
...
@@ -2679,7 +2680,8 @@ void Query_cache::wreck(uint line, const char *message)
DBUG_PRINT
(
"warning"
,
(
"=================================="
));
DBUG_PRINT
(
"warning"
,
(
"=================================="
));
DBUG_PRINT
(
"warning"
,
(
"%5d QUERY CACHE WRECK => DISABLED"
,
line
));
DBUG_PRINT
(
"warning"
,
(
"%5d QUERY CACHE WRECK => DISABLED"
,
line
));
DBUG_PRINT
(
"warning"
,
(
"=================================="
));
DBUG_PRINT
(
"warning"
,
(
"=================================="
));
current_thd
->
killed
=
1
;
if
(
thd
)
thd
->
killed
=
1
;
bins_dump
();
bins_dump
();
cache_dump
();
cache_dump
();
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
...
...
sql/sql_select.cc
View file @
8bef3771
...
@@ -480,7 +480,9 @@ mysql_select(THD *thd,TABLE_LIST *tables,List<Item> &fields,COND *conds,
...
@@ -480,7 +480,9 @@ mysql_select(THD *thd,TABLE_LIST *tables,List<Item> &fields,COND *conds,
(
thd
->
select_limit
==
HA_POS_ERROR
||
(
thd
->
select_limit
==
HA_POS_ERROR
||
(
join
.
select_options
&
OPTION_FOUND_ROWS
)
||
(
join
.
select_options
&
OPTION_FOUND_ROWS
)
||
order
&&
order
&&
!
(
skip_sort_order
=
test_if_skip_sort_order
(
&
join
.
join_tab
[
join
.
const_tables
],
order
,
thd
->
select_limit
,
1
))))
!
(
skip_sort_order
=
test_if_skip_sort_order
(
&
join
.
join_tab
[
join
.
const_tables
],
order
,
thd
->
select_limit
,
1
))))
{
{
if
((
group
=
create_distinct_group
(
order
,
fields
)))
if
((
group
=
create_distinct_group
(
order
,
fields
)))
{
{
...
@@ -5272,13 +5274,6 @@ static uint find_shortest_key(TABLE *table, key_map usable_keys)
...
@@ -5272,13 +5274,6 @@ static uint find_shortest_key(TABLE *table, key_map usable_keys)
}
}
/*****************************************************************************
** If not selecting by given key, create an index how records should be read
** return: 0 ok
** -1 some fatal error
** 1 no records
*****************************************************************************/
/* Return 1 if we don't have to do file sorting */
/* Return 1 if we don't have to do file sorting */
static
bool
static
bool
...
@@ -5391,6 +5386,14 @@ test_if_skip_sort_order(JOIN_TAB *tab,ORDER *order,ha_rows select_limit,
...
@@ -5391,6 +5386,14 @@ test_if_skip_sort_order(JOIN_TAB *tab,ORDER *order,ha_rows select_limit,
DBUG_RETURN
(
0
);
// Can't use index.
DBUG_RETURN
(
0
);
// Can't use index.
}
}
/*****************************************************************************
If not selecting by given key, create an index how records should be read
return: 0 ok
-1 some fatal error
1 no records
*****************************************************************************/
static
int
static
int
create_sort_index
(
JOIN_TAB
*
tab
,
ORDER
*
order
,
ha_rows
select_limit
)
create_sort_index
(
JOIN_TAB
*
tab
,
ORDER
*
order
,
ha_rows
select_limit
)
{
{
...
...
sql/sql_yacc.yy
View file @
8bef3771
...
@@ -509,7 +509,7 @@ bool my_yyoverflow(short **a, YYSTYPE **b,int *yystacksize);
...
@@ -509,7 +509,7 @@ bool my_yyoverflow(short **a, YYSTYPE **b,int *yystacksize);
ulonglong_num
ulonglong_num
%type <item>
%type <item>
literal text_literal insert_ident
group_ident
order_ident
literal text_literal insert_ident order_ident
simple_ident select_item2 expr opt_expr opt_else sum_expr in_sum_expr
simple_ident select_item2 expr opt_expr opt_else sum_expr in_sum_expr
table_wild opt_pad no_in_expr expr_expr simple_expr no_and_expr
table_wild opt_pad no_in_expr expr_expr simple_expr no_and_expr
using_list
using_list
...
@@ -1394,7 +1394,7 @@ select_lock_type:
...
@@ -1394,7 +1394,7 @@ select_lock_type:
/* empty */
/* empty */
| FOR_SYM UPDATE_SYM
| FOR_SYM UPDATE_SYM
{ Lex->lock_option= TL_WRITE; current_thd->safe_to_cache_query=0; }
{ Lex->lock_option= TL_WRITE; current_thd->safe_to_cache_query=0; }
| IN_SYM SHARE_SYM MODE_SYM
|
LOCK_SYM
IN_SYM SHARE_SYM MODE_SYM
{ Lex->lock_option= TL_READ_WITH_SHARED_LOCKS; current_thd->safe_to_cache_query=0; }
{ Lex->lock_option= TL_READ_WITH_SHARED_LOCKS; current_thd->safe_to_cache_query=0; }
select_item_list:
select_item_list:
...
@@ -2069,10 +2069,10 @@ group_clause:
...
@@ -2069,10 +2069,10 @@ group_clause:
| GROUP BY group_list
| GROUP BY group_list
group_list:
group_list:
group_list ','
group_ident
group_list ','
order_ident order_dir
{ if (add_group_to_list($3,(bool)
1
)) YYABORT; }
{ if (add_group_to_list($3,(bool)
$4
)) YYABORT; }
|
group_ident
|
order_ident order_dir
{ if (add_group_to_list($1,(bool)
1
)) YYABORT; }
{ if (add_group_to_list($1,(bool)
$2
)) YYABORT; }
/*
/*
** Order by statement in select
** Order by statement in select
...
@@ -2083,7 +2083,7 @@ opt_order_clause:
...
@@ -2083,7 +2083,7 @@ opt_order_clause:
| order_clause
| order_clause
order_clause:
order_clause:
ORDER_SYM BY
{ Select->sort_default=1; }
order_list
ORDER_SYM BY order_list
order_list:
order_list:
order_list ',' order_ident order_dir
order_list ',' order_ident order_dir
...
@@ -2093,8 +2093,8 @@ order_list:
...
@@ -2093,8 +2093,8 @@ order_list:
order_dir:
order_dir:
/* empty */ { $$ = 1; }
/* empty */ { $$ = 1; }
| ASC { $$ =
Select->sort_default=
1; }
| ASC { $$ =1; }
| DESC { $$ =
Select->sort_default=
0; }
| DESC { $$ =0; }
limit_clause:
limit_clause:
...
@@ -2813,9 +2813,6 @@ table_wild:
...
@@ -2813,9 +2813,6 @@ table_wild:
| ident '.' ident '.' '*'
| ident '.' ident '.' '*'
{ $$ = new Item_field((current_thd->client_capabilities & CLIENT_NO_SCHEMA ? NullS : $1.str),$3.str,"*"); }
{ $$ = new Item_field((current_thd->client_capabilities & CLIENT_NO_SCHEMA ? NullS : $1.str),$3.str,"*"); }
group_ident:
order_ident order_dir
order_ident:
order_ident:
expr { $$=$1; }
expr { $$=$1; }
...
...
tests/myisam-big-rows.tst
0 → 100644
View file @
8bef3771
#
# Test rows with length above > 16M
# Note that for this to work, you should start mysqld with
# -O max_allowed_packet=32M
#
drop table if exists t1;
create table t1 (a tinyint not null auto_increment, b longblob not null, primary key (a)) checksum=1;
insert into t1 (b) values(repeat(char(65),10));
insert into t1 (b) values(repeat(char(66),10));
insert into t1 (b) values(repeat(char(67),10));
update t1 set b=repeat(char(68),16777216) where a=1;
check table t1;
update t1 set b=repeat(char(69),16777000) where a=2;
update t1 set b=repeat(char(70),167) where a=3;
update t1 set b=repeat(char(71),16778000) where a=1;
update t1 set b=repeat(char(72),16778000) where a=3;
select a,length(b) from t1;
set @a=1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
update t1 set b=('A') where a=5;
delete from t1 where a=7;
set @a=@a+1;
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
update t1 set b=repeat(char(73+@a+1),17000000+@a) where a=last_insert_id();
select a,mid(b,1,5),length(b) from t1;
check table t1;
repair table t1;
check table t1;
select a from table where b<>repeat(mid(b,1,1),length(b));
delete from t1 where (a & 1);
select a from table where b<>repeat(mid(b,1,1),length(b));
check table t1;
repair table t1;
check table t1;
drop table t1;
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