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
81b59fb3
Commit
81b59fb3
authored
Mar 22, 2007
by
holyfoot/hf@hfmain.(none)
Browse files
Options
Browse Files
Download
Plain Diff
Merge mysql.com:/home/hf/work/mrg/mysql-5.0-opt
into mysql.com:/home/hf/work/mrg/mysql-5.1-opt
parents
0d556669
68f9ff12
Changes
11
Hide whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
171 additions
and
48 deletions
+171
-48
mysql-test/r/create.result
mysql-test/r/create.result
+15
-15
mysql-test/r/insert_select.result
mysql-test/r/insert_select.result
+29
-0
mysql-test/r/temp_table.result
mysql-test/r/temp_table.result
+21
-0
mysql-test/r/type_float.result
mysql-test/r/type_float.result
+7
-7
mysql-test/r/union.result
mysql-test/r/union.result
+2
-2
mysql-test/t/insert_select.test
mysql-test/t/insert_select.test
+26
-1
mysql-test/t/temp_table.test
mysql-test/t/temp_table.test
+15
-0
sql/field.h
sql/field.h
+1
-3
sql/item.cc
sql/item.cc
+11
-7
sql/item_sum.cc
sql/item_sum.cc
+3
-1
sql/sql_select.h
sql/sql_select.h
+41
-12
No files found.
mysql-test/r/create.result
View file @
81b59fb3
...
@@ -455,21 +455,21 @@ create table t2 select ifnull(a,a), ifnull(b,b), ifnull(c,c), ifnull(d,d), ifnul
...
@@ -455,21 +455,21 @@ create table t2 select ifnull(a,a), ifnull(b,b), ifnull(c,c), ifnull(d,d), ifnul
show create table t2;
show create table t2;
Table Create Table
Table Create Table
t2 CREATE TABLE `t2` (
t2 CREATE TABLE `t2` (
`ifnull(a,a)` tinyint(4)
DEFAULT
NULL,
`ifnull(a,a)` tinyint(4)
default
NULL,
`ifnull(b,b)` smallint(6)
DEFAULT
NULL,
`ifnull(b,b)` smallint(6)
default
NULL,
`ifnull(c,c)` mediumint(8)
DEFAULT
NULL,
`ifnull(c,c)` mediumint(8)
default
NULL,
`ifnull(d,d)` int(11)
DEFAULT
NULL,
`ifnull(d,d)` int(11)
default
NULL,
`ifnull(e,e)` bigint(20)
DEFAULT
NULL,
`ifnull(e,e)` bigint(20)
default
NULL,
`ifnull(f,f)` float(
24,2) DEFAULT
NULL,
`ifnull(f,f)` float(
3,2) default
NULL,
`ifnull(g,g)` double(
53,3) DEFAULT
NULL,
`ifnull(g,g)` double(
4,3) default
NULL,
`ifnull(h,h)` decimal(5,4)
DEFAULT
NULL,
`ifnull(h,h)` decimal(5,4)
default
NULL,
`ifnull(i,i)` year(4)
DEFAULT
NULL,
`ifnull(i,i)` year(4)
default
NULL,
`ifnull(j,j)` date
DEFAULT
NULL,
`ifnull(j,j)` date
default
NULL,
`ifnull(k,k)` timestamp NOT NULL
DEFAULT
'0000-00-00 00:00:00',
`ifnull(k,k)` timestamp NOT NULL
default
'0000-00-00 00:00:00',
`ifnull(l,l)` datetime
DEFAULT
NULL,
`ifnull(l,l)` datetime
default
NULL,
`ifnull(m,m)` varchar(1)
DEFAULT
NULL,
`ifnull(m,m)` varchar(1)
default
NULL,
`ifnull(n,n)` varchar(3)
DEFAULT
NULL,
`ifnull(n,n)` varchar(3)
default
NULL,
`ifnull(o,o)` varchar(10)
DEFAULT
NULL
`ifnull(o,o)` varchar(10)
default
NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
) ENGINE=MyISAM DEFAULT CHARSET=latin1
drop table t1,t2;
drop table t1,t2;
create table t1(str varchar(10) default 'def',strnull varchar(10),intg int default '10',rel double default '3.14');
create table t1(str varchar(10) default 'def',strnull varchar(10),intg int default '10',rel double default '3.14');
...
...
mysql-test/r/insert_select.result
View file @
81b59fb3
...
@@ -730,3 +730,32 @@ f1 f2
...
@@ -730,3 +730,32 @@ f1 f2
2 2
2 2
10 10
10 10
DROP TABLE t1, t2;
DROP TABLE t1, t2;
SET SQL_MODE='STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
CREATE TABLE t1 (c VARCHAR(30), INDEX ix_c (c(10)));
CREATE TABLE t2 (d VARCHAR(10));
INSERT INTO t1 (c) VALUES ('7_chars'), ('13_characters');
EXPLAIN
SELECT (SELECT SUM(LENGTH(c)) FROM t1 WHERE c='13_characters') FROM t1;
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY t1 ALL NULL NULL NULL NULL 2
2 SUBQUERY t1 ref ix_c ix_c 13 const 1 Using where
SELECT (SELECT SUM(LENGTH(c)) FROM t1 WHERE c='13_characters') FROM t1;
(SELECT SUM(LENGTH(c)) FROM t1 WHERE c='13_characters')
13
13
INSERT INTO t2 (d)
SELECT (SELECT SUM(LENGTH(c)) FROM t1 WHERE c='13_characters') FROM t1;
INSERT INTO t2 (d)
SELECT (SELECT SUM(LENGTH(c)) FROM t1 WHERE c='7_chars') FROM t1;
INSERT INTO t2 (d)
SELECT (SELECT SUM(LENGTH(c)) FROM t1 WHERE c IN (SELECT t1.c FROM t1))
FROM t1;
SELECT * FROM t2;
d
13
13
7
7
20
20
DROP TABLE t1,t2;
mysql-test/r/temp_table.result
View file @
81b59fb3
...
@@ -152,6 +152,27 @@ SELECT * FROM t1;
...
@@ -152,6 +152,27 @@ SELECT * FROM t1;
i
i
DROP TABLE t1;
DROP TABLE t1;
End of 4.1 tests.
End of 4.1 tests.
CREATE TABLE t1 ( c FLOAT( 20, 14 ) );
INSERT INTO t1 VALUES( 12139 );
CREATE TABLE t2 ( c FLOAT(30,18) );
INSERT INTO t2 VALUES( 123456 );
SELECT AVG( c ) FROM t1 UNION SELECT 1;
AVG( c )
12139
1
SELECT 1 UNION SELECT AVG( c ) FROM t1;
1
1
12139
SELECT 1 UNION SELECT * FROM t2 UNION SELECT 1;
1
1
123456
SELECT c/1 FROM t1 UNION SELECT 1;
c/1
12139
1
DROP TABLE t1, t2;
create temporary table t1 (a int);
create temporary table t1 (a int);
insert into t1 values (4711);
insert into t1 values (4711);
select * from t1;
select * from t1;
...
...
mysql-test/r/type_float.result
View file @
81b59fb3
...
@@ -91,10 +91,10 @@ col1 col2 col3 col4
...
@@ -91,10 +91,10 @@ col1 col2 col3 col4
show create table t2;
show create table t2;
Table Create Table
Table Create Table
t2 CREATE TABLE `t2` (
t2 CREATE TABLE `t2` (
`col1` double
DEFAULT
NULL,
`col1` double
default
NULL,
`col2` double(
53,5) DEFAULT
NULL,
`col2` double(
22,5) default
NULL,
`col3` double
DEFAULT
NULL,
`col3` double
default
NULL,
`col4` double
DEFAULT
NULL
`col4` double
default
NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
) ENGINE=MyISAM DEFAULT CHARSET=latin1
drop table t1,t2;
drop table t1,t2;
create table t1 (a float);
create table t1 (a float);
...
@@ -232,12 +232,12 @@ insert into t2 values ("1.23456780");
...
@@ -232,12 +232,12 @@ insert into t2 values ("1.23456780");
create table t3 select * from t2 union select * from t1;
create table t3 select * from t2 union select * from t1;
select * from t3;
select * from t3;
d
d
1.2345678
00
1.2345678
100000000
.000000000
100000000
show create table t3;
show create table t3;
Table Create Table
Table Create Table
t3 CREATE TABLE `t3` (
t3 CREATE TABLE `t3` (
`d` double
(22,9) DEFAULT
NULL
`d` double
default
NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
) ENGINE=MyISAM DEFAULT CHARSET=latin1
drop table t1, t2, t3;
drop table t1, t2, t3;
create table t1 select 105213674794682365.00 + 0.0 x;
create table t1 select 105213674794682365.00 + 0.0 x;
...
...
mysql-test/r/union.result
View file @
81b59fb3
...
@@ -554,7 +554,7 @@ aa
...
@@ -554,7 +554,7 @@ aa
show create table t1;
show create table t1;
Table Create Table
Table Create Table
t1 CREATE TABLE `t1` (
t1 CREATE TABLE `t1` (
`a` varbinary(2
0) NOT NULL DEFAULT
''
`a` varbinary(2
) NOT NULL default
''
) ENGINE=MyISAM DEFAULT CHARSET=latin1
) ENGINE=MyISAM DEFAULT CHARSET=latin1
drop table t1;
drop table t1;
create table t1 SELECT 12 as a UNION select 12.2 as a;
create table t1 SELECT 12 as a UNION select 12.2 as a;
...
@@ -655,7 +655,7 @@ f
...
@@ -655,7 +655,7 @@ f
show create table t1;
show create table t1;
Table Create Table
Table Create Table
t1 CREATE TABLE `t1` (
t1 CREATE TABLE `t1` (
`f` varbinary(
24) DEFAULT
NULL
`f` varbinary(
12) default
NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
) ENGINE=MyISAM DEFAULT CHARSET=latin1
drop table t1;
drop table t1;
create table t1 SELECT y from t2 UNION select da from t2;
create table t1 SELECT y from t2 UNION select da from t2;
...
...
mysql-test/t/insert_select.test
View file @
81b59fb3
...
@@ -293,4 +293,29 @@ INSERT INTO t2 (f1, f2)
...
@@ -293,4 +293,29 @@ INSERT INTO t2 (f1, f2)
SELECT
*
FROM
t2
;
SELECT
*
FROM
t2
;
DROP
TABLE
t1
,
t2
;
DROP
TABLE
t1
,
t2
;
#
# Bug #26207: inserts don't work with shortened index
#
SET
SQL_MODE
=
'STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'
;
CREATE
TABLE
t1
(
c
VARCHAR
(
30
),
INDEX
ix_c
(
c
(
10
)));
CREATE
TABLE
t2
(
d
VARCHAR
(
10
));
INSERT
INTO
t1
(
c
)
VALUES
(
'7_chars'
),
(
'13_characters'
);
EXPLAIN
SELECT
(
SELECT
SUM
(
LENGTH
(
c
))
FROM
t1
WHERE
c
=
'13_characters'
)
FROM
t1
;
SELECT
(
SELECT
SUM
(
LENGTH
(
c
))
FROM
t1
WHERE
c
=
'13_characters'
)
FROM
t1
;
INSERT
INTO
t2
(
d
)
SELECT
(
SELECT
SUM
(
LENGTH
(
c
))
FROM
t1
WHERE
c
=
'13_characters'
)
FROM
t1
;
INSERT
INTO
t2
(
d
)
SELECT
(
SELECT
SUM
(
LENGTH
(
c
))
FROM
t1
WHERE
c
=
'7_chars'
)
FROM
t1
;
INSERT
INTO
t2
(
d
)
SELECT
(
SELECT
SUM
(
LENGTH
(
c
))
FROM
t1
WHERE
c
IN
(
SELECT
t1
.
c
FROM
t1
))
FROM
t1
;
SELECT
*
FROM
t2
;
DROP
TABLE
t1
,
t2
;
mysql-test/t/temp_table.test
View file @
81b59fb3
...
@@ -164,6 +164,21 @@ DROP TABLE t1;
...
@@ -164,6 +164,21 @@ DROP TABLE t1;
--
echo
End
of
4.1
tests
.
--
echo
End
of
4.1
tests
.
#
# Bug #24791: Union with AVG-groups generates wrong results
#
CREATE
TABLE
t1
(
c
FLOAT
(
20
,
14
)
);
INSERT
INTO
t1
VALUES
(
12139
);
CREATE
TABLE
t2
(
c
FLOAT
(
30
,
18
)
);
INSERT
INTO
t2
VALUES
(
123456
);
SELECT
AVG
(
c
)
FROM
t1
UNION
SELECT
1
;
SELECT
1
UNION
SELECT
AVG
(
c
)
FROM
t1
;
SELECT
1
UNION
SELECT
*
FROM
t2
UNION
SELECT
1
;
SELECT
c
/
1
FROM
t1
UNION
SELECT
1
;
DROP
TABLE
t1
,
t2
;
#
#
# Test truncate with temporary tables
# Test truncate with temporary tables
...
...
sql/field.h
View file @
81b59fb3
...
@@ -504,6 +504,7 @@ public:
...
@@ -504,6 +504,7 @@ public:
{}
{}
int
store_decimal
(
const
my_decimal
*
);
int
store_decimal
(
const
my_decimal
*
);
my_decimal
*
val_decimal
(
my_decimal
*
);
my_decimal
*
val_decimal
(
my_decimal
*
);
uint32
max_display_length
()
{
return
field_length
;
}
};
};
...
@@ -532,7 +533,6 @@ public:
...
@@ -532,7 +533,6 @@ public:
void
overflow
(
bool
negative
);
void
overflow
(
bool
negative
);
bool
zero_pack
()
const
{
return
0
;
}
bool
zero_pack
()
const
{
return
0
;
}
void
sql_type
(
String
&
str
)
const
;
void
sql_type
(
String
&
str
)
const
;
uint32
max_display_length
()
{
return
field_length
;
}
};
};
...
@@ -783,7 +783,6 @@ public:
...
@@ -783,7 +783,6 @@ public:
void
sort_string
(
char
*
buff
,
uint
length
);
void
sort_string
(
char
*
buff
,
uint
length
);
uint32
pack_length
()
const
{
return
sizeof
(
float
);
}
uint32
pack_length
()
const
{
return
sizeof
(
float
);
}
void
sql_type
(
String
&
str
)
const
;
void
sql_type
(
String
&
str
)
const
;
uint32
max_display_length
()
{
return
24
;
}
};
};
...
@@ -825,7 +824,6 @@ public:
...
@@ -825,7 +824,6 @@ public:
void
sort_string
(
char
*
buff
,
uint
length
);
void
sort_string
(
char
*
buff
,
uint
length
);
uint32
pack_length
()
const
{
return
sizeof
(
double
);
}
uint32
pack_length
()
const
{
return
sizeof
(
double
);
}
void
sql_type
(
String
&
str
)
const
;
void
sql_type
(
String
&
str
)
const
;
uint32
max_display_length
()
{
return
53
;
}
uint
size_of
()
const
{
return
sizeof
(
*
this
);
}
uint
size_of
()
const
{
return
sizeof
(
*
this
);
}
};
};
...
...
sql/item.cc
View file @
81b59fb3
...
@@ -6437,8 +6437,6 @@ Item_type_holder::Item_type_holder(THD *thd, Item *item)
...
@@ -6437,8 +6437,6 @@ Item_type_holder::Item_type_holder(THD *thd, Item *item)
:
Item
(
thd
,
item
),
enum_set_typelib
(
0
),
fld_type
(
get_real_type
(
item
))
:
Item
(
thd
,
item
),
enum_set_typelib
(
0
),
fld_type
(
get_real_type
(
item
))
{
{
DBUG_ASSERT
(
item
->
fixed
);
DBUG_ASSERT
(
item
->
fixed
);
max_length
=
display_length
(
item
);
maybe_null
=
item
->
maybe_null
;
maybe_null
=
item
->
maybe_null
;
collation
.
set
(
item
->
collation
);
collation
.
set
(
item
->
collation
);
get_full_info
(
item
);
get_full_info
(
item
);
...
@@ -6610,11 +6608,17 @@ bool Item_type_holder::join_types(THD *thd, Item *item)
...
@@ -6610,11 +6608,17 @@ bool Item_type_holder::join_types(THD *thd, Item *item)
{
{
int
delta1
=
max_length_orig
-
decimals_orig
;
int
delta1
=
max_length_orig
-
decimals_orig
;
int
delta2
=
item
->
max_length
-
item
->
decimals
;
int
delta2
=
item
->
max_length
-
item
->
decimals
;
if
(
fld_type
==
MYSQL_TYPE_DECIMAL
)
max_length
=
max
(
delta1
,
delta2
)
+
decimals
;
max_length
=
max
(
delta1
,
delta2
)
+
decimals
;
if
(
fld_type
==
MYSQL_TYPE_FLOAT
&&
max_length
>
FLT_DIG
+
2
)
else
{
max_length
=
min
(
max
(
delta1
,
delta2
)
+
decimals
,
max_length
=
FLT_DIG
+
6
;
(
fld_type
==
MYSQL_TYPE_FLOAT
)
?
FLT_DIG
+
6
:
DBL_DIG
+
7
);
decimals
=
NOT_FIXED_DEC
;
}
if
(
fld_type
==
MYSQL_TYPE_DOUBLE
&&
max_length
>
DBL_DIG
+
2
)
{
max_length
=
DBL_DIG
+
7
;
decimals
=
NOT_FIXED_DEC
;
}
}
}
else
else
max_length
=
(
fld_type
==
MYSQL_TYPE_FLOAT
)
?
FLT_DIG
+
6
:
DBL_DIG
+
7
;
max_length
=
(
fld_type
==
MYSQL_TYPE_FLOAT
)
?
FLT_DIG
+
6
:
DBL_DIG
+
7
;
...
...
sql/item_sum.cc
View file @
81b59fb3
...
@@ -1130,8 +1130,10 @@ void Item_sum_avg::fix_length_and_dec()
...
@@ -1130,8 +1130,10 @@ void Item_sum_avg::fix_length_and_dec()
f_scale
=
args
[
0
]
->
decimals
;
f_scale
=
args
[
0
]
->
decimals
;
dec_bin_size
=
my_decimal_get_binary_size
(
f_precision
,
f_scale
);
dec_bin_size
=
my_decimal_get_binary_size
(
f_precision
,
f_scale
);
}
}
else
else
{
decimals
=
min
(
args
[
0
]
->
decimals
+
prec_increment
,
NOT_FIXED_DEC
);
decimals
=
min
(
args
[
0
]
->
decimals
+
prec_increment
,
NOT_FIXED_DEC
);
max_length
=
args
[
0
]
->
max_length
+
prec_increment
;
}
}
}
...
...
sql/sql_select.h
View file @
81b59fb3
...
@@ -527,15 +527,11 @@ extern "C" int refpos_order_cmp(void* arg, const void *a,const void *b);
...
@@ -527,15 +527,11 @@ extern "C" int refpos_order_cmp(void* arg, const void *a,const void *b);
class
store_key
:
public
Sql_alloc
class
store_key
:
public
Sql_alloc
{
{
protected:
Field
*
to_field
;
// Store data here
char
*
null_ptr
;
char
err
;
public:
public:
bool
null_key
;
/* TRUE <=> the value of the key has a null part */
bool
null_key
;
/* TRUE <=> the value of the key has a null part */
enum
store_key_result
{
STORE_KEY_OK
,
STORE_KEY_FATAL
,
STORE_KEY_CONV
};
enum
store_key_result
{
STORE_KEY_OK
,
STORE_KEY_FATAL
,
STORE_KEY_CONV
};
store_key
(
THD
*
thd
,
Field
*
field_arg
,
char
*
ptr
,
char
*
null
,
uint
length
)
store_key
(
THD
*
thd
,
Field
*
field_arg
,
char
*
ptr
,
char
*
null
,
uint
length
)
:
null_
ptr
(
null
),
err
(
0
),
null_key
(
0
)
:
null_
key
(
0
),
null_ptr
(
null
),
err
(
0
)
{
{
if
(
field_arg
->
type
()
==
MYSQL_TYPE_BLOB
)
if
(
field_arg
->
type
()
==
MYSQL_TYPE_BLOB
)
{
{
...
@@ -550,8 +546,35 @@ public:
...
@@ -550,8 +546,35 @@ public:
ptr
,
(
uchar
*
)
null
,
1
);
ptr
,
(
uchar
*
)
null
,
1
);
}
}
virtual
~
store_key
()
{}
/* Not actually needed */
virtual
~
store_key
()
{}
/* Not actually needed */
virtual
enum
store_key_result
copy
()
=
0
;
virtual
const
char
*
name
()
const
=
0
;
virtual
const
char
*
name
()
const
=
0
;
/**
@brief sets ignore truncation warnings mode and calls the real copy method
@details this function makes sure truncation warnings when preparing the
key buffers don't end up as errors (because of an enclosing INSERT/UPDATE).
*/
enum
store_key_result
copy
()
{
enum
store_key_result
result
;
enum_check_fields
saved_count_cuted_fields
=
to_field
->
table
->
in_use
->
count_cuted_fields
;
to_field
->
table
->
in_use
->
count_cuted_fields
=
CHECK_FIELD_IGNORE
;
result
=
copy_inner
();
to_field
->
table
->
in_use
->
count_cuted_fields
=
saved_count_cuted_fields
;
return
result
;
}
protected:
Field
*
to_field
;
// Store data here
char
*
null_ptr
;
char
err
;
virtual
enum
store_key_result
copy_inner
()
=
0
;
};
};
...
@@ -571,7 +594,10 @@ class store_key_field: public store_key
...
@@ -571,7 +594,10 @@ class store_key_field: public store_key
copy_field
.
set
(
to_field
,
from_field
,
0
);
copy_field
.
set
(
to_field
,
from_field
,
0
);
}
}
}
}
enum
store_key_result
copy
()
const
char
*
name
()
const
{
return
field_name
;
}
protected:
enum
store_key_result
copy_inner
()
{
{
TABLE
*
table
=
copy_field
.
to_field
->
table
;
TABLE
*
table
=
copy_field
.
to_field
->
table
;
my_bitmap_map
*
old_map
=
dbug_tmp_use_all_columns
(
table
,
my_bitmap_map
*
old_map
=
dbug_tmp_use_all_columns
(
table
,
...
@@ -581,7 +607,6 @@ class store_key_field: public store_key
...
@@ -581,7 +607,6 @@ class store_key_field: public store_key
null_key
=
to_field
->
is_null
();
null_key
=
to_field
->
is_null
();
return
err
!=
0
?
STORE_KEY_FATAL
:
STORE_KEY_OK
;
return
err
!=
0
?
STORE_KEY_FATAL
:
STORE_KEY_OK
;
}
}
const
char
*
name
()
const
{
return
field_name
;
}
};
};
...
@@ -596,7 +621,10 @@ public:
...
@@ -596,7 +621,10 @@ public:
null_ptr_arg
?
null_ptr_arg
:
item_arg
->
maybe_null
?
null_ptr_arg
?
null_ptr_arg
:
item_arg
->
maybe_null
?
&
err
:
NullS
,
length
),
item
(
item_arg
)
&
err
:
NullS
,
length
),
item
(
item_arg
)
{}
{}
enum
store_key_result
copy
()
const
char
*
name
()
const
{
return
"func"
;
}
protected:
enum
store_key_result
copy_inner
()
{
{
TABLE
*
table
=
to_field
->
table
;
TABLE
*
table
=
to_field
->
table
;
my_bitmap_map
*
old_map
=
dbug_tmp_use_all_columns
(
table
,
my_bitmap_map
*
old_map
=
dbug_tmp_use_all_columns
(
table
,
...
@@ -606,7 +634,6 @@ public:
...
@@ -606,7 +634,6 @@ public:
null_key
=
to_field
->
is_null
()
||
item
->
null_value
;
null_key
=
to_field
->
is_null
()
||
item
->
null_value
;
return
(
err
!=
0
||
res
>
2
?
STORE_KEY_FATAL
:
(
store_key_result
)
res
);
return
(
err
!=
0
||
res
>
2
?
STORE_KEY_FATAL
:
(
store_key_result
)
res
);
}
}
const
char
*
name
()
const
{
return
"func"
;
}
};
};
...
@@ -622,7 +649,10 @@ public:
...
@@ -622,7 +649,10 @@ public:
&
err
:
NullS
,
length
,
item_arg
),
inited
(
0
)
&
err
:
NullS
,
length
,
item_arg
),
inited
(
0
)
{
{
}
}
enum
store_key_result
copy
()
const
char
*
name
()
const
{
return
"const"
;
}
protected:
enum
store_key_result
copy_inner
()
{
{
int
res
;
int
res
;
if
(
!
inited
)
if
(
!
inited
)
...
@@ -637,7 +667,6 @@ public:
...
@@ -637,7 +667,6 @@ public:
null_key
=
to_field
->
is_null
()
||
item
->
null_value
;
null_key
=
to_field
->
is_null
()
||
item
->
null_value
;
return
(
err
>
2
?
STORE_KEY_FATAL
:
(
store_key_result
)
err
);
return
(
err
>
2
?
STORE_KEY_FATAL
:
(
store_key_result
)
err
);
}
}
const
char
*
name
()
const
{
return
"const"
;
}
};
};
bool
cp_buffer_from_ref
(
THD
*
thd
,
TABLE
*
table
,
TABLE_REF
*
ref
);
bool
cp_buffer_from_ref
(
THD
*
thd
,
TABLE
*
table
,
TABLE_REF
*
ref
);
...
...
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