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
2d88514d
Commit
2d88514d
authored
Dec 09, 2008
by
Georgi Kodinov
Browse files
Options
Browse Files
Download
Plain Diff
merged 37936 to 5.1-bugteam
parents
9ce98dd1
71296ae2
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
106 additions
and
27 deletions
+106
-27
mysql-test/r/select.result
mysql-test/r/select.result
+26
-0
mysql-test/t/select.test
mysql-test/t/select.test
+33
-0
sql/item_cmpfunc.cc
sql/item_cmpfunc.cc
+6
-12
sql/opt_range.cc
sql/opt_range.cc
+11
-15
sql/table.h
sql/table.h
+30
-0
No files found.
mysql-test/r/select.result
View file @
2d88514d
...
@@ -4358,3 +4358,29 @@ a
...
@@ -4358,3 +4358,29 @@ a
4
4
5
5
DROP TABLE t1;
DROP TABLE t1;
CREATE TABLE A (date_key date);
CREATE TABLE C (
pk int,
int_nokey int,
int_key int,
date_key date NOT NULL,
date_nokey date,
varchar_key varchar(1)
);
INSERT INTO C VALUES
(1,1,1,'0000-00-00',NULL,NULL),
(1,1,1,'0000-00-00',NULL,NULL);
SELECT 1 FROM C WHERE pk > ANY (SELECT 1 FROM C);
1
SELECT COUNT(DISTINCT 1) FROM C
WHERE date_key = (SELECT 1 FROM A WHERE C.date_key IS NULL) GROUP BY pk;
COUNT(DISTINCT 1)
SELECT date_nokey FROM C
WHERE int_key IN (SELECT 1 FROM A)
HAVING date_nokey = '10:41:7'
ORDER BY date_key;
date_nokey
Warnings:
Warning 1292 Incorrect date value: '10:41:7' for column 'date_nokey' at row 1
DROP TABLE A,C;
End of 5.1 tests
mysql-test/t/select.test
View file @
2d88514d
...
@@ -3701,3 +3701,36 @@ SELECT a FROM t1 ORDER BY a LIMIT 2;
...
@@ -3701,3 +3701,36 @@ SELECT a FROM t1 ORDER BY a LIMIT 2;
SELECT
a
FROM
t1
ORDER
BY
a
LIMIT
2
,
4294967296
;
SELECT
a
FROM
t1
ORDER
BY
a
LIMIT
2
,
4294967296
;
SELECT
a
FROM
t1
ORDER
BY
a
LIMIT
2
,
4294967297
;
SELECT
a
FROM
t1
ORDER
BY
a
LIMIT
2
,
4294967297
;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
#
# Bug #37936: ASSERT_COLUMN_MARKED_FOR_WRITE in Field_datetime::store ,
# Field_varstring::store
#
CREATE
TABLE
A
(
date_key
date
);
CREATE
TABLE
C
(
pk
int
,
int_nokey
int
,
int_key
int
,
date_key
date
NOT
NULL
,
date_nokey
date
,
varchar_key
varchar
(
1
)
);
INSERT
INTO
C
VALUES
(
1
,
1
,
1
,
'0000-00-00'
,
NULL
,
NULL
),
(
1
,
1
,
1
,
'0000-00-00'
,
NULL
,
NULL
);
SELECT
1
FROM
C
WHERE
pk
>
ANY
(
SELECT
1
FROM
C
);
SELECT
COUNT
(
DISTINCT
1
)
FROM
C
WHERE
date_key
=
(
SELECT
1
FROM
A
WHERE
C
.
date_key
IS
NULL
)
GROUP
BY
pk
;
SELECT
date_nokey
FROM
C
WHERE
int_key
IN
(
SELECT
1
FROM
A
)
HAVING
date_nokey
=
'10:41:7'
ORDER
BY
date_key
;
DROP
TABLE
A
,
C
;
--
echo
End
of
5.1
tests
sql/item_cmpfunc.cc
View file @
2d88514d
...
@@ -394,19 +394,16 @@ static bool convert_constant_item(THD *thd, Item_field *field_item,
...
@@ -394,19 +394,16 @@ static bool convert_constant_item(THD *thd, Item_field *field_item,
TABLE
*
table
=
field
->
table
;
TABLE
*
table
=
field
->
table
;
ulong
orig_sql_mode
=
thd
->
variables
.
sql_mode
;
ulong
orig_sql_mode
=
thd
->
variables
.
sql_mode
;
enum_check_fields
orig_count_cuted_fields
=
thd
->
count_cuted_fields
;
enum_check_fields
orig_count_cuted_fields
=
thd
->
count_cuted_fields
;
my_bitmap_map
*
old_write_map
;
my_bitmap_map
*
old_maps
[
2
];
my_bitmap_map
*
old_read_map
;
ulonglong
orig_field_val
;
/* original field value if valid */
ulonglong
orig_field_val
;
/* original field value if valid */
LINT_INIT
(
old_
write_map
);
LINT_INIT
(
old_
maps
[
0
]
);
LINT_INIT
(
old_
read_map
);
LINT_INIT
(
old_
maps
[
1
]
);
LINT_INIT
(
orig_field_val
);
LINT_INIT
(
orig_field_val
);
if
(
table
)
if
(
table
)
{
dbug_tmp_use_all_columns
(
table
,
old_maps
,
old_write_map
=
dbug_tmp_use_all_columns
(
table
,
table
->
write_set
);
table
->
read_set
,
table
->
write_set
);
old_read_map
=
dbug_tmp_use_all_columns
(
table
,
table
->
read_set
);
}
/* For comparison purposes allow invalid dates like 2000-01-32 */
/* For comparison purposes allow invalid dates like 2000-01-32 */
thd
->
variables
.
sql_mode
=
(
orig_sql_mode
&
~
MODE_NO_ZERO_DATE
)
|
thd
->
variables
.
sql_mode
=
(
orig_sql_mode
&
~
MODE_NO_ZERO_DATE
)
|
MODE_INVALID_DATES
;
MODE_INVALID_DATES
;
...
@@ -441,10 +438,7 @@ static bool convert_constant_item(THD *thd, Item_field *field_item,
...
@@ -441,10 +438,7 @@ static bool convert_constant_item(THD *thd, Item_field *field_item,
thd
->
variables
.
sql_mode
=
orig_sql_mode
;
thd
->
variables
.
sql_mode
=
orig_sql_mode
;
thd
->
count_cuted_fields
=
orig_count_cuted_fields
;
thd
->
count_cuted_fields
=
orig_count_cuted_fields
;
if
(
table
)
if
(
table
)
{
dbug_tmp_restore_column_maps
(
table
->
read_set
,
table
->
write_set
,
old_maps
);
dbug_tmp_restore_column_map
(
table
->
write_set
,
old_write_map
);
dbug_tmp_restore_column_map
(
table
->
read_set
,
old_read_map
);
}
}
}
return
result
;
return
result
;
}
}
...
...
sql/opt_range.cc
View file @
2d88514d
...
@@ -2668,7 +2668,7 @@ bool prune_partitions(THD *thd, TABLE *table, Item *pprune_cond)
...
@@ -2668,7 +2668,7 @@ bool prune_partitions(THD *thd, TABLE *table, Item *pprune_cond)
PART_PRUNE_PARAM
prune_param
;
PART_PRUNE_PARAM
prune_param
;
MEM_ROOT
alloc
;
MEM_ROOT
alloc
;
RANGE_OPT_PARAM
*
range_par
=
&
prune_param
.
range_param
;
RANGE_OPT_PARAM
*
range_par
=
&
prune_param
.
range_param
;
my_bitmap_map
*
old_
read_set
,
*
old_write_set
;
my_bitmap_map
*
old_
sets
[
2
]
;
prune_param
.
part_info
=
part_info
;
prune_param
.
part_info
=
part_info
;
init_sql_alloc
(
&
alloc
,
thd
->
variables
.
range_alloc_block_size
,
0
);
init_sql_alloc
(
&
alloc
,
thd
->
variables
.
range_alloc_block_size
,
0
);
...
@@ -2682,8 +2682,8 @@ bool prune_partitions(THD *thd, TABLE *table, Item *pprune_cond)
...
@@ -2682,8 +2682,8 @@ bool prune_partitions(THD *thd, TABLE *table, Item *pprune_cond)
DBUG_RETURN
(
FALSE
);
DBUG_RETURN
(
FALSE
);
}
}
old_write_set
=
dbug_tmp_use_all_columns
(
table
,
table
->
write_set
);
dbug_tmp_use_all_columns
(
table
,
old_sets
,
old_read_set
=
dbug_tmp_use_all_columns
(
table
,
table
->
read
_set
);
table
->
read_set
,
table
->
write
_set
);
range_par
->
thd
=
thd
;
range_par
->
thd
=
thd
;
range_par
->
table
=
table
;
range_par
->
table
=
table
;
/* range_par->cond doesn't need initialization */
/* range_par->cond doesn't need initialization */
...
@@ -2773,8 +2773,7 @@ all_used:
...
@@ -2773,8 +2773,7 @@ all_used:
retval
=
FALSE
;
// some partitions are used
retval
=
FALSE
;
// some partitions are used
mark_all_partitions_as_used
(
prune_param
.
part_info
);
mark_all_partitions_as_used
(
prune_param
.
part_info
);
end:
end:
dbug_tmp_restore_column_map
(
table
->
write_set
,
old_write_set
);
dbug_tmp_restore_column_maps
(
table
->
read_set
,
table
->
write_set
,
old_sets
);
dbug_tmp_restore_column_map
(
table
->
read_set
,
old_read_set
);
thd
->
no_errors
=
0
;
thd
->
no_errors
=
0
;
thd
->
mem_root
=
range_par
->
old_root
;
thd
->
mem_root
=
range_par
->
old_root
;
free_root
(
&
alloc
,
MYF
(
0
));
// Return memory & allocator
free_root
(
&
alloc
,
MYF
(
0
));
// Return memory & allocator
...
@@ -11145,9 +11144,9 @@ print_key(KEY_PART *key_part, const uchar *key, uint used_length)
...
@@ -11145,9 +11144,9 @@ print_key(KEY_PART *key_part, const uchar *key, uint used_length)
String
tmp
(
buff
,
sizeof
(
buff
),
&
my_charset_bin
);
String
tmp
(
buff
,
sizeof
(
buff
),
&
my_charset_bin
);
uint
store_length
;
uint
store_length
;
TABLE
*
table
=
key_part
->
field
->
table
;
TABLE
*
table
=
key_part
->
field
->
table
;
my_bitmap_map
*
old_
write_set
,
*
old_read_set
;
my_bitmap_map
*
old_
sets
[
2
]
;
old_write_set
=
dbug_tmp_use_all_columns
(
table
,
table
->
write_set
);
old_read_set
=
dbug_tmp_use_all_columns
(
table
,
table
->
read
_set
);
dbug_tmp_use_all_columns
(
table
,
old_sets
,
table
->
read_set
,
table
->
write
_set
);
for
(;
key
<
key_end
;
key
+=
store_length
,
key_part
++
)
for
(;
key
<
key_end
;
key
+=
store_length
,
key_part
++
)
{
{
...
@@ -11173,8 +11172,7 @@ print_key(KEY_PART *key_part, const uchar *key, uint used_length)
...
@@ -11173,8 +11172,7 @@ print_key(KEY_PART *key_part, const uchar *key, uint used_length)
if
(
key
+
store_length
<
key_end
)
if
(
key
+
store_length
<
key_end
)
fputc
(
'/'
,
DBUG_FILE
);
fputc
(
'/'
,
DBUG_FILE
);
}
}
dbug_tmp_restore_column_map
(
table
->
write_set
,
old_write_set
);
dbug_tmp_restore_column_maps
(
table
->
read_set
,
table
->
write_set
,
old_sets
);
dbug_tmp_restore_column_map
(
table
->
read_set
,
old_read_set
);
}
}
...
@@ -11182,18 +11180,16 @@ static void print_quick(QUICK_SELECT_I *quick, const key_map *needed_reg)
...
@@ -11182,18 +11180,16 @@ static void print_quick(QUICK_SELECT_I *quick, const key_map *needed_reg)
{
{
char
buf
[
MAX_KEY
/
8
+
1
];
char
buf
[
MAX_KEY
/
8
+
1
];
TABLE
*
table
;
TABLE
*
table
;
my_bitmap_map
*
old_
read_map
,
*
old_write_map
;
my_bitmap_map
*
old_
sets
[
2
]
;
DBUG_ENTER
(
"print_quick"
);
DBUG_ENTER
(
"print_quick"
);
if
(
!
quick
)
if
(
!
quick
)
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
DBUG_LOCK_FILE
;
DBUG_LOCK_FILE
;
table
=
quick
->
head
;
table
=
quick
->
head
;
old_read_map
=
dbug_tmp_use_all_columns
(
table
,
table
->
read_set
);
dbug_tmp_use_all_columns
(
table
,
old_sets
,
table
->
read_set
,
table
->
write_set
);
old_write_map
=
dbug_tmp_use_all_columns
(
table
,
table
->
write_set
);
quick
->
dbug_dump
(
0
,
TRUE
);
quick
->
dbug_dump
(
0
,
TRUE
);
dbug_tmp_restore_column_map
(
table
->
read_set
,
old_read_map
);
dbug_tmp_restore_column_maps
(
table
->
read_set
,
table
->
write_set
,
old_sets
);
dbug_tmp_restore_column_map
(
table
->
write_set
,
old_write_map
);
fprintf
(
DBUG_FILE
,
"other_keys: 0x%s:
\n
"
,
needed_reg
->
print
(
buf
));
fprintf
(
DBUG_FILE
,
"other_keys: 0x%s:
\n
"
,
needed_reg
->
print
(
buf
));
...
...
sql/table.h
View file @
2d88514d
...
@@ -1691,5 +1691,35 @@ static inline void dbug_tmp_restore_column_map(MY_BITMAP *bitmap,
...
@@ -1691,5 +1691,35 @@ static inline void dbug_tmp_restore_column_map(MY_BITMAP *bitmap,
#endif
#endif
}
}
/*
Variant of the above : handle both read and write sets.
Provide for the possiblity of the read set being the same as the write set
*/
static
inline
void
dbug_tmp_use_all_columns
(
TABLE
*
table
,
my_bitmap_map
**
save
,
MY_BITMAP
*
read_set
,
MY_BITMAP
*
write_set
)
{
#ifndef DBUG_OFF
save
[
0
]
=
read_set
->
bitmap
;
save
[
1
]
=
write_set
->
bitmap
;
(
void
)
tmp_use_all_columns
(
table
,
read_set
);
(
void
)
tmp_use_all_columns
(
table
,
write_set
);
#endif
}
static
inline
void
dbug_tmp_restore_column_maps
(
MY_BITMAP
*
read_set
,
MY_BITMAP
*
write_set
,
my_bitmap_map
**
old
)
{
#ifndef DBUG_OFF
tmp_restore_column_map
(
read_set
,
old
[
0
]);
tmp_restore_column_map
(
write_set
,
old
[
1
]);
#endif
}
size_t
max_row_length
(
TABLE
*
table
,
const
uchar
*
data
);
size_t
max_row_length
(
TABLE
*
table
,
const
uchar
*
data
);
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