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
0022bb67
Commit
0022bb67
authored
Mar 02, 2006
by
serg@serg.mylan
Browse files
Options
Browse Files
Download
Plain Diff
Merge bk-internal.mysql.com:/home/bk/mysql-5.1-new
into serg.mylan:/usr/home/serg/Abk/mysql-5.1
parents
c7513d18
3072df16
Changes
15
Hide whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
146 additions
and
22 deletions
+146
-22
mysql-test/r/bigint.result
mysql-test/r/bigint.result
+9
-0
mysql-test/r/ndb_partition_range.result
mysql-test/r/ndb_partition_range.result
+3
-3
mysql-test/r/partition_charset.result
mysql-test/r/partition_charset.result
+18
-0
mysql-test/r/xml.result
mysql-test/r/xml.result
+12
-0
mysql-test/t/bigint.test
mysql-test/t/bigint.test
+9
-0
mysql-test/t/ndb_partition_range.test
mysql-test/t/ndb_partition_range.test
+3
-3
mysql-test/t/partition_charset.test
mysql-test/t/partition_charset.test
+21
-0
mysql-test/t/xml.test
mysql-test/t/xml.test
+6
-0
sql/ha_ndbcluster.cc
sql/ha_ndbcluster.cc
+5
-2
sql/ha_ndbcluster_binlog.cc
sql/ha_ndbcluster_binlog.cc
+20
-10
sql/ha_ndbcluster_binlog.h
sql/ha_ndbcluster_binlog.h
+3
-1
sql/item.h
sql/item.h
+3
-2
sql/item_cmpfunc.cc
sql/item_cmpfunc.cc
+2
-1
sql/item_xmlfunc.cc
sql/item_xmlfunc.cc
+29
-0
sql/sql_partition.cc
sql/sql_partition.cc
+3
-0
No files found.
mysql-test/r/bigint.result
View file @
0022bb67
...
@@ -332,3 +332,12 @@ SELECT * FROM t1;
...
@@ -332,3 +332,12 @@ SELECT * FROM t1;
col1 col2 col3 col4 col5 col6 col7 col8 col9 col10 col11 col12 col13 col14 col15 col16 col17 col18 col19 col20 col21 col22 col23 col24 col25 col26 col27 col28 col29 col30 col31 col32 col33 col34 col35 col36 col37 col38 fix1 fix2 fix3 fix4 fix5 fix6 fix7 fix8 fix9 fix10 fix11 fix12 fix13 fix14 fix15 fix16 fix17 fix18 fix19 fix20 fix21 fix22 fix23 fix24 fix25 fix26 fix27 fix28 fix29 fix30
col1 col2 col3 col4 col5 col6 col7 col8 col9 col10 col11 col12 col13 col14 col15 col16 col17 col18 col19 col20 col21 col22 col23 col24 col25 col26 col27 col28 col29 col30 col31 col32 col33 col34 col35 col36 col37 col38 fix1 fix2 fix3 fix4 fix5 fix6 fix7 fix8 fix9 fix10 fix11 fix12 fix13 fix14 fix15 fix16 fix17 fix18 fix19 fix20 fix21 fix22 fix23 fix24 fix25 fix26 fix27 fix28 fix29 fix30
9 99 999 9999 99999 999999 9999999 99999999 999999999 9999999999 99999999999 999999999999 9999999999999 99999999999999 999999999999999 9999999999999999 99999999999999999 999999999999999999 9999999999999999999 99999999999999999999 999999999999999999999 9999999999999999999999 99999999999999999999999 999999999999999999999999 9999999999999999999999999 99999999999999999999999999 999999999999999999999999999 9999999999999999999999999999 99999999999999999999999999999 999999999999999999999999999999 9999999999999999999999999999999 99999999999999999999999999999999 999999999999999999999999999999999 9999999999999999999999999999999999 99999999999999999999999999999999999 999999999999999999999999999999999999 9999999999999999999999999999999999999 99999999999999999999999999999999999999 9999999999999999999999999999999999999.9 999999999999999999999999999999999999.99 99999999999999999999999999999999999.999 9999999999999999999999999999999999.9999 999999999999999999999999999999999.99999 99999999999999999999999999999999.999999 9999999999999999999999999999999.9999999 999999999999999999999999999999.99999999 99999999999999999999999999999.999999999 9999999999999999999999999999.9999999999 999999999999999999999999999.99999999999 99999999999999999999999999.999999999999 9999999999999999999999999.9999999999999 999999999999999999999999.99999999999999 99999999999999999999999.999999999999999 9999999999999999999999.9999999999999999 999999999999999999999.99999999999999999 99999999999999999999.999999999999999999 9999999999999999999.9999999999999999999 999999999999999999.99999999999999999999 99999999999999999.999999999999999999999 9999999999999999.9999999999999999999999 999999999999999.99999999999999999999999 99999999999999.999999999999999999999999 9999999999999.9999999999999999999999999 999999999999.99999999999999999999999999 99999999999.999999999999999999999999999 9999999999.9999999999999999999999999999 999999999.99999999999999999999999999999 99999999.999999999999999999999999999999
9 99 999 9999 99999 999999 9999999 99999999 999999999 9999999999 99999999999 999999999999 9999999999999 99999999999999 999999999999999 9999999999999999 99999999999999999 999999999999999999 9999999999999999999 99999999999999999999 999999999999999999999 9999999999999999999999 99999999999999999999999 999999999999999999999999 9999999999999999999999999 99999999999999999999999999 999999999999999999999999999 9999999999999999999999999999 99999999999999999999999999999 999999999999999999999999999999 9999999999999999999999999999999 99999999999999999999999999999999 999999999999999999999999999999999 9999999999999999999999999999999999 99999999999999999999999999999999999 999999999999999999999999999999999999 9999999999999999999999999999999999999 99999999999999999999999999999999999999 9999999999999999999999999999999999999.9 999999999999999999999999999999999999.99 99999999999999999999999999999999999.999 9999999999999999999999999999999999.9999 999999999999999999999999999999999.99999 99999999999999999999999999999999.999999 9999999999999999999999999999999.9999999 999999999999999999999999999999.99999999 99999999999999999999999999999.999999999 9999999999999999999999999999.9999999999 999999999999999999999999999.99999999999 99999999999999999999999999.999999999999 9999999999999999999999999.9999999999999 999999999999999999999999.99999999999999 99999999999999999999999.999999999999999 9999999999999999999999.9999999999999999 999999999999999999999.99999999999999999 99999999999999999999.999999999999999999 9999999999999999999.9999999999999999999 999999999999999999.99999999999999999999 99999999999999999.999999999999999999999 9999999999999999.9999999999999999999999 999999999999999.99999999999999999999999 99999999999999.999999999999999999999999 9999999999999.9999999999999999999999999 999999999999.99999999999999999999999999 99999999999.999999999999999999999999999 9999999999.9999999999999999999999999999 999999999.99999999999999999999999999999 99999999.999999999999999999999999999999
DROP TABLE t1;
DROP TABLE t1;
create table t1 (bigint_col bigint unsigned);
insert into t1 values (17666000000000000000);
select * from t1 where bigint_col=17666000000000000000;
bigint_col
17666000000000000000
select * from t1 where bigint_col='17666000000000000000';
bigint_col
17666000000000000000
drop table t1;
mysql-test/r/ndb_partition_range.result
View file @
0022bb67
...
@@ -246,17 +246,17 @@ PARTITION BY RANGE(f1)
...
@@ -246,17 +246,17 @@ PARTITION BY RANGE(f1)
PARTITION part2 VALUES LESS THAN (1000));
PARTITION part2 VALUES LESS THAN (1000));
INSERT INTO t1 VALUES(1, '---1---');
INSERT INTO t1 VALUES(1, '---1---');
INSERT INTO t1 VALUES(2, '---2---');
INSERT INTO t1 VALUES(2, '---2---');
select * from t1;
select * from t1
order by f1
;
f1 f2
f1 f2
1 ---1---
1 ---1---
2 ---2---
2 ---2---
UPDATE t1 SET f1 = f1 + 4 WHERE f1 = 2;
UPDATE t1 SET f1 = f1 + 4 WHERE f1 = 2;
select * from t1;
select * from t1
order by f1
;
f1 f2
f1 f2
1 ---1---
1 ---1---
6 ---2---
6 ---2---
UPDATE t1 SET f1 = f1 + 4 WHERE f1 = 1;
UPDATE t1 SET f1 = f1 + 4 WHERE f1 = 1;
select * from t1;
select * from t1
order by f1
;
f1 f2
f1 f2
5 ---1---
5 ---1---
6 ---2---
6 ---2---
...
...
mysql-test/r/partition_charset.result
0 → 100644
View file @
0022bb67
drop table if exists t1;
set names utf8;
create table t1 (s1 int)
partition by list (s1)
(partition c values in (1),
partition Ç values in (3));
insert into t1 values (1),(3);
select * from t1;
s1
1
3
flush tables;
set names latin1;
select * from t1;
s1
1
3
drop table t1;
mysql-test/r/xml.result
View file @
0022bb67
...
@@ -65,6 +65,9 @@ c1
...
@@ -65,6 +65,9 @@ c1
SELECT extractValue(@xml,'/a/child::*');
SELECT extractValue(@xml,'/a/child::*');
extractValue(@xml,'/a/child::*')
extractValue(@xml,'/a/child::*')
b1 b2
b1 b2
SELECT extractValue(@xml,'/a/self::*');
extractValue(@xml,'/a/self::*')
a1 a2
SELECT extractValue(@xml,'/a/descendant::*');
SELECT extractValue(@xml,'/a/descendant::*');
extractValue(@xml,'/a/descendant::*')
extractValue(@xml,'/a/descendant::*')
b1 c1 b2
b1 c1 b2
...
@@ -546,6 +549,15 @@ select extractvalue('<a>A</a>','/<a>');
...
@@ -546,6 +549,15 @@ select extractvalue('<a>A</a>','/<a>');
ERROR HY000: XPATH syntax error: '>'
ERROR HY000: XPATH syntax error: '>'
select extractvalue('<a><b>b</b><b!>b!</b!></a>','//b!');
select extractvalue('<a><b>b</b><b!>b!</b!></a>','//b!');
ERROR HY000: XPATH syntax error: '!'
ERROR HY000: XPATH syntax error: '!'
select extractvalue('<a>A<b>B<c>C</c></b></a>','/a/descendant::*');
extractvalue('<a>A<b>B<c>C</c></b></a>','/a/descendant::*')
B C
select extractvalue('<a>A<b>B<c>C</c></b></a>','/a/self::*');
extractvalue('<a>A<b>B<c>C</c></b></a>','/a/self::*')
A
select extractvalue('<a>A<b>B<c>C</c></b></a>','/a/descendant-or-self::*');
extractvalue('<a>A<b>B<c>C</c></b></a>','/a/descendant-or-self::*')
A B C
select extractvalue('<A_B>A</A_B>','/A_B');
select extractvalue('<A_B>A</A_B>','/A_B');
extractvalue('<A_B>A</A_B>','/A_B')
extractvalue('<A_B>A</A_B>','/A_B')
A
A
mysql-test/t/bigint.test
View file @
0022bb67
...
@@ -270,3 +270,12 @@ VALUES (9, 99, 999, 9999, 99999, 999999, 9999999, 99999999, 999999999,
...
@@ -270,3 +270,12 @@ VALUES (9, 99, 999, 9999, 99999, 999999, 9999999, 99999999, 999999999,
SELECT
*
FROM
t1
;
SELECT
*
FROM
t1
;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
#bug #9088 BIGINT WHERE CLAUSE
create
table
t1
(
bigint_col
bigint
unsigned
);
insert
into
t1
values
(
17666000000000000000
);
select
*
from
t1
where
bigint_col
=
17666000000000000000
;
select
*
from
t1
where
bigint_col
=
'17666000000000000000'
;
drop
table
t1
;
mysql-test/t/ndb_partition_range.test
View file @
0022bb67
...
@@ -252,9 +252,9 @@ PARTITION BY RANGE(f1)
...
@@ -252,9 +252,9 @@ PARTITION BY RANGE(f1)
PARTITION
part2
VALUES
LESS
THAN
(
1000
));
PARTITION
part2
VALUES
LESS
THAN
(
1000
));
INSERT
INTO
t1
VALUES
(
1
,
'---1---'
);
INSERT
INTO
t1
VALUES
(
1
,
'---1---'
);
INSERT
INTO
t1
VALUES
(
2
,
'---2---'
);
INSERT
INTO
t1
VALUES
(
2
,
'---2---'
);
select
*
from
t1
;
select
*
from
t1
order
by
f1
;
UPDATE
t1
SET
f1
=
f1
+
4
WHERE
f1
=
2
;
UPDATE
t1
SET
f1
=
f1
+
4
WHERE
f1
=
2
;
select
*
from
t1
;
select
*
from
t1
order
by
f1
;
UPDATE
t1
SET
f1
=
f1
+
4
WHERE
f1
=
1
;
UPDATE
t1
SET
f1
=
f1
+
4
WHERE
f1
=
1
;
select
*
from
t1
;
select
*
from
t1
order
by
f1
;
drop
table
t1
;
drop
table
t1
;
mysql-test/t/partition_charset.test
0 → 100644
View file @
0022bb67
#
# Test for character set related things in combination
# with the partition storage engine
#
--
source
include
/
have_partition
.
inc
--
disable_warnings
drop
table
if
exists
t1
;
--
enable_warnings
set
names
utf8
;
create
table
t1
(
s1
int
)
partition
by
list
(
s1
)
(
partition
c
values
in
(
1
),
partition
Ç
values
in
(
3
));
insert
into
t1
values
(
1
),(
3
);
select
*
from
t1
;
flush
tables
;
set
names
latin1
;
select
*
from
t1
;
drop
table
t1
;
mysql-test/t/xml.test
View file @
0022bb67
...
@@ -23,6 +23,7 @@ SELECT extractValue(@xml,'/*/*');
...
@@ -23,6 +23,7 @@ SELECT extractValue(@xml,'/*/*');
SELECT
extractValue
(
@
xml
,
'/*/*/*'
);
SELECT
extractValue
(
@
xml
,
'/*/*/*'
);
SELECT
extractValue
(
@
xml
,
'/a/child::*'
);
SELECT
extractValue
(
@
xml
,
'/a/child::*'
);
SELECT
extractValue
(
@
xml
,
'/a/self::*'
);
SELECT
extractValue
(
@
xml
,
'/a/descendant::*'
);
SELECT
extractValue
(
@
xml
,
'/a/descendant::*'
);
SELECT
extractValue
(
@
xml
,
'/a/descendant-or-self::*'
);
SELECT
extractValue
(
@
xml
,
'/a/descendant-or-self::*'
);
SELECT
extractValue
(
@
xml
,
'/a/attribute::*'
);
SELECT
extractValue
(
@
xml
,
'/a/attribute::*'
);
...
@@ -245,6 +246,11 @@ select extractvalue('<a>A</a>','/<a>');
...
@@ -245,6 +246,11 @@ select extractvalue('<a>A</a>','/<a>');
select
extractvalue
(
'<a><b>b</b><b!>b!</b!></a>'
,
'//b!'
);
select
extractvalue
(
'<a><b>b</b><b!>b!</b!></a>'
,
'//b!'
);
#
#
# Bug #16315 XML: extractvalue() handles self badly
#
select
extractvalue
(
'<a>A<b>B<c>C</c></b></a>'
,
'/a/descendant::*'
);
select
extractvalue
(
'<a>A<b>B<c>C</c></b></a>'
,
'/a/self::*'
);
select
extractvalue
(
'<a>A<b>B<c>C</c></b></a>'
,
'/a/descendant-or-self::*'
);
# Bug #16320 XML: extractvalue() won't accept names containing underscores
# Bug #16320 XML: extractvalue() won't accept names containing underscores
#
#
select
extractvalue
(
'<A_B>A</A_B>'
,
'/A_B'
);
select
extractvalue
(
'<A_B>A</A_B>'
,
'/A_B'
);
sql/ha_ndbcluster.cc
View file @
0022bb67
...
@@ -4728,13 +4728,14 @@ int ha_ndbcluster::final_drop_index(TABLE *table_arg)
...
@@ -4728,13 +4728,14 @@ int ha_ndbcluster::final_drop_index(TABLE *table_arg)
int
ha_ndbcluster
::
rename_table
(
const
char
*
from
,
const
char
*
to
)
int
ha_ndbcluster
::
rename_table
(
const
char
*
from
,
const
char
*
to
)
{
{
NDBDICT
*
dict
;
NDBDICT
*
dict
;
char
old_dbname
[
FN_HEADLEN
];
char
new_tabname
[
FN_HEADLEN
];
char
new_tabname
[
FN_HEADLEN
];
const
NDBTAB
*
orig_tab
;
const
NDBTAB
*
orig_tab
;
int
result
;
int
result
;
DBUG_ENTER
(
"ha_ndbcluster::rename_table"
);
DBUG_ENTER
(
"ha_ndbcluster::rename_table"
);
DBUG_PRINT
(
"info"
,
(
"Renaming %s to %s"
,
from
,
to
));
DBUG_PRINT
(
"info"
,
(
"Renaming %s to %s"
,
from
,
to
));
set_dbname
(
from
);
set_dbname
(
from
,
old_dbname
);
set_tabname
(
from
);
set_tabname
(
from
);
set_tabname
(
to
,
new_tabname
);
set_tabname
(
to
,
new_tabname
);
...
@@ -4742,6 +4743,7 @@ int ha_ndbcluster::rename_table(const char *from, const char *to)
...
@@ -4742,6 +4743,7 @@ int ha_ndbcluster::rename_table(const char *from, const char *to)
DBUG_RETURN
(
my_errno
=
HA_ERR_NO_CONNECTION
);
DBUG_RETURN
(
my_errno
=
HA_ERR_NO_CONNECTION
);
Ndb
*
ndb
=
get_ndb
();
Ndb
*
ndb
=
get_ndb
();
ndb
->
setDatabaseName
(
old_dbname
);
dict
=
ndb
->
getDictionary
();
dict
=
ndb
->
getDictionary
();
if
(
!
(
orig_tab
=
dict
->
getTable
(
m_tabname
)))
if
(
!
(
orig_tab
=
dict
->
getTable
(
m_tabname
)))
ERR_RETURN
(
dict
->
getNdbError
());
ERR_RETURN
(
dict
->
getNdbError
());
...
@@ -4833,7 +4835,8 @@ int ha_ndbcluster::rename_table(const char *from, const char *to)
...
@@ -4833,7 +4835,8 @@ int ha_ndbcluster::rename_table(const char *from, const char *to)
current_thd
->
query
,
current_thd
->
query_length
,
current_thd
->
query
,
current_thd
->
query_length
,
m_dbname
,
new_tabname
,
m_dbname
,
new_tabname
,
0
,
0
,
0
,
0
,
SOT_RENAME_TABLE
);
SOT_RENAME_TABLE
,
old_dbname
,
m_tabname
);
}
}
if
(
share
)
if
(
share
)
free_share
(
&
share
);
free_share
(
&
share
);
...
...
sql/ha_ndbcluster_binlog.cc
View file @
0022bb67
...
@@ -885,7 +885,8 @@ int ndbcluster_log_schema_op(THD *thd, NDB_SHARE *share,
...
@@ -885,7 +885,8 @@ int ndbcluster_log_schema_op(THD *thd, NDB_SHARE *share,
const
char
*
db
,
const
char
*
table_name
,
const
char
*
db
,
const
char
*
table_name
,
uint32
ndb_table_id
,
uint32
ndb_table_id
,
uint32
ndb_table_version
,
uint32
ndb_table_version
,
enum
SCHEMA_OP_TYPE
type
)
enum
SCHEMA_OP_TYPE
type
,
const
char
*
old_db
,
const
char
*
old_table_name
)
{
{
DBUG_ENTER
(
"ndbcluster_log_schema_op"
);
DBUG_ENTER
(
"ndbcluster_log_schema_op"
);
Thd_ndb
*
thd_ndb
=
get_thd_ndb
(
thd
);
Thd_ndb
*
thd_ndb
=
get_thd_ndb
(
thd
);
...
@@ -919,10 +920,19 @@ int ndbcluster_log_schema_op(THD *thd, NDB_SHARE *share,
...
@@ -919,10 +920,19 @@ int ndbcluster_log_schema_op(THD *thd, NDB_SHARE *share,
query
=
tmp_buf2
;
query
=
tmp_buf2
;
query_length
=
(
uint
)
(
strxmov
(
tmp_buf2
,
"drop table `"
,
query_length
=
(
uint
)
(
strxmov
(
tmp_buf2
,
"drop table `"
,
table_name
,
"`"
,
NullS
)
-
tmp_buf2
);
table_name
,
"`"
,
NullS
)
-
tmp_buf2
);
// fall through
if
(
!
share
)
case
SOT_CREATE_TABLE
:
get_a_share
=
1
;
// fall through
break
;
case
SOT_RENAME_TABLE
:
case
SOT_RENAME_TABLE
:
/* redo the rename table query as is may contain several tables */
query
=
tmp_buf2
;
query_length
=
(
uint
)
(
strxmov
(
tmp_buf2
,
"rename table `"
,
old_db
,
"."
,
old_table_name
,
"` to `"
,
db
,
"."
,
table_name
,
"`"
,
NullS
)
-
tmp_buf2
);
if
(
!
share
)
get_a_share
=
1
;
break
;
case
SOT_CREATE_TABLE
:
// fall through
// fall through
case
SOT_ALTER_TABLE
:
case
SOT_ALTER_TABLE
:
if
(
!
share
)
if
(
!
share
)
...
@@ -983,8 +993,8 @@ int ndbcluster_log_schema_op(THD *thd, NDB_SHARE *share,
...
@@ -983,8 +993,8 @@ int ndbcluster_log_schema_op(THD *thd, NDB_SHARE *share,
}
}
Ndb
*
ndb
=
thd_ndb
->
ndb
;
Ndb
*
ndb
=
thd_ndb
->
ndb
;
char
old
_db
[
FN_REFLEN
];
char
save
_db
[
FN_REFLEN
];
strcpy
(
old
_db
,
ndb
->
getDatabaseName
());
strcpy
(
save
_db
,
ndb
->
getDatabaseName
());
char
tmp_buf
[
SCHEMA_QUERY_SIZE
];
char
tmp_buf
[
SCHEMA_QUERY_SIZE
];
NDBDICT
*
dict
=
ndb
->
getDictionary
();
NDBDICT
*
dict
=
ndb
->
getDictionary
();
...
@@ -1091,7 +1101,7 @@ end:
...
@@ -1091,7 +1101,7 @@ end:
if
(
trans
)
if
(
trans
)
ndb
->
closeTransaction
(
trans
);
ndb
->
closeTransaction
(
trans
);
ndb
->
setDatabaseName
(
old
_db
);
ndb
->
setDatabaseName
(
save
_db
);
/*
/*
Wait for other mysqld's to acknowledge the table operation
Wait for other mysqld's to acknowledge the table operation
...
@@ -1169,8 +1179,8 @@ ndbcluster_update_slock(THD *thd,
...
@@ -1169,8 +1179,8 @@ ndbcluster_update_slock(THD *thd,
const
NdbError
*
ndb_error
=
0
;
const
NdbError
*
ndb_error
=
0
;
uint32
node_id
=
g_ndb_cluster_connection
->
node_id
();
uint32
node_id
=
g_ndb_cluster_connection
->
node_id
();
Ndb
*
ndb
=
check_ndb_in_thd
(
thd
);
Ndb
*
ndb
=
check_ndb_in_thd
(
thd
);
char
old_db
[
128
];
char
save_db
[
FN_HEADLEN
];
strcpy
(
old
_db
,
ndb
->
getDatabaseName
());
strcpy
(
save
_db
,
ndb
->
getDatabaseName
());
char
tmp_buf
[
SCHEMA_QUERY_SIZE
];
char
tmp_buf
[
SCHEMA_QUERY_SIZE
];
NDBDICT
*
dict
=
ndb
->
getDictionary
();
NDBDICT
*
dict
=
ndb
->
getDictionary
();
...
@@ -1292,7 +1302,7 @@ end:
...
@@ -1292,7 +1302,7 @@ end:
db
,
table_name
);
db
,
table_name
);
if
(
trans
)
if
(
trans
)
ndb
->
closeTransaction
(
trans
);
ndb
->
closeTransaction
(
trans
);
ndb
->
setDatabaseName
(
old
_db
);
ndb
->
setDatabaseName
(
save
_db
);
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
}
...
...
sql/ha_ndbcluster_binlog.h
View file @
0022bb67
...
@@ -95,7 +95,9 @@ int ndbcluster_log_schema_op(THD *thd, NDB_SHARE *share,
...
@@ -95,7 +95,9 @@ int ndbcluster_log_schema_op(THD *thd, NDB_SHARE *share,
const
char
*
db
,
const
char
*
table_name
,
const
char
*
db
,
const
char
*
table_name
,
uint32
ndb_table_id
,
uint32
ndb_table_id
,
uint32
ndb_table_version
,
uint32
ndb_table_version
,
enum
SCHEMA_OP_TYPE
type
);
enum
SCHEMA_OP_TYPE
type
,
const
char
*
old_db
=
0
,
const
char
*
old_table_name
=
0
);
int
ndbcluster_handle_drop_table
(
Ndb
*
ndb
,
const
char
*
event_name
,
int
ndbcluster_handle_drop_table
(
Ndb
*
ndb
,
const
char
*
event_name
,
NDB_SHARE
*
share
);
NDB_SHARE
*
share
);
void
ndb_rep_event_name
(
String
*
event_name
,
void
ndb_rep_event_name
(
String
*
event_name
,
...
...
sql/item.h
View file @
0022bb67
...
@@ -1931,9 +1931,10 @@ class Item_int_with_ref :public Item_int
...
@@ -1931,9 +1931,10 @@ class Item_int_with_ref :public Item_int
{
{
Item
*
ref
;
Item
*
ref
;
public:
public:
Item_int_with_ref
(
longlong
i
,
Item
*
ref_arg
)
:
Item_int
(
i
),
ref
(
ref_arg
)
Item_int_with_ref
(
longlong
i
,
Item
*
ref_arg
,
my_bool
unsigned_arg
)
:
Item_int
(
i
),
ref
(
ref_arg
)
{
{
unsigned_flag
=
ref_arg
->
unsigned_fla
g
;
unsigned_flag
=
unsigned_ar
g
;
}
}
int
save_in_field
(
Field
*
field
,
bool
no_conversions
)
int
save_in_field
(
Field
*
field
,
bool
no_conversions
)
{
{
...
...
sql/item_cmpfunc.cc
View file @
0022bb67
...
@@ -216,7 +216,8 @@ static bool convert_constant_item(THD *thd, Field *field, Item **item)
...
@@ -216,7 +216,8 @@ static bool convert_constant_item(THD *thd, Field *field, Item **item)
field
->
table
->
in_use
->
variables
.
sql_mode
|=
MODE_INVALID_DATES
;
field
->
table
->
in_use
->
variables
.
sql_mode
|=
MODE_INVALID_DATES
;
if
(
!
(
*
item
)
->
save_in_field
(
field
,
1
)
&&
!
((
*
item
)
->
null_value
))
if
(
!
(
*
item
)
->
save_in_field
(
field
,
1
)
&&
!
((
*
item
)
->
null_value
))
{
{
Item
*
tmp
=
new
Item_int_with_ref
(
field
->
val_int
(),
*
item
);
Item
*
tmp
=
new
Item_int_with_ref
(
field
->
val_int
(),
*
item
,
test
(
field
->
flags
&
UNSIGNED_FLAG
));
field
->
table
->
in_use
->
variables
.
sql_mode
=
orig_sql_mode
;
field
->
table
->
in_use
->
variables
.
sql_mode
=
orig_sql_mode
;
if
(
tmp
)
if
(
tmp
)
thd
->
change_item_tree
(
item
,
tmp
);
thd
->
change_item_tree
(
item
,
tmp
);
...
...
sql/item_xmlfunc.cc
View file @
0022bb67
...
@@ -252,6 +252,18 @@ public:
...
@@ -252,6 +252,18 @@ public:
};
};
/* Returns self */
class
Item_nodeset_func_selfbyname
:
public
Item_nodeset_func_axisbyname
{
public:
Item_nodeset_func_selfbyname
(
Item
*
a
,
const
char
*
n_arg
,
uint
l_arg
,
String
*
pxml
)
:
Item_nodeset_func_axisbyname
(
a
,
n_arg
,
l_arg
,
pxml
)
{}
const
char
*
func_name
()
const
{
return
"xpath_selfbyname"
;
}
String
*
val_nodeset
(
String
*
nodeset
);
};
/* Returns children */
/* Returns children */
class
Item_nodeset_func_childbyname
:
public
Item_nodeset_func_axisbyname
class
Item_nodeset_func_childbyname
:
public
Item_nodeset_func_axisbyname
{
{
...
@@ -572,6 +584,20 @@ String * Item_nodeset_func_union::val_nodeset(String *nodeset)
...
@@ -572,6 +584,20 @@ String * Item_nodeset_func_union::val_nodeset(String *nodeset)
}
}
String
*
Item_nodeset_func_selfbyname
::
val_nodeset
(
String
*
nodeset
)
{
prepare
(
nodeset
);
for
(
MY_XPATH_FLT
*
flt
=
fltbeg
;
flt
<
fltend
;
flt
++
)
{
uint
pos
=
0
;
MY_XML_NODE
*
self
=
&
nodebeg
[
flt
->
num
];
if
(
validname
(
self
))
((
XPathFilter
*
)
nodeset
)
->
append_element
(
flt
->
num
,
pos
++
);
}
return
nodeset
;
}
String
*
Item_nodeset_func_childbyname
::
val_nodeset
(
String
*
nodeset
)
String
*
Item_nodeset_func_childbyname
::
val_nodeset
(
String
*
nodeset
)
{
{
prepare
(
nodeset
);
prepare
(
nodeset
);
...
@@ -945,6 +971,9 @@ static Item* nametestfunc(MY_XPATH *xpath,
...
@@ -945,6 +971,9 @@ static Item* nametestfunc(MY_XPATH *xpath,
case
MY_XPATH_AXIS_ATTRIBUTE
:
case
MY_XPATH_AXIS_ATTRIBUTE
:
res
=
new
Item_nodeset_func_attributebyname
(
arg
,
beg
,
len
,
xpath
->
pxml
);
res
=
new
Item_nodeset_func_attributebyname
(
arg
,
beg
,
len
,
xpath
->
pxml
);
break
;
break
;
case
MY_XPATH_AXIS_SELF
:
res
=
new
Item_nodeset_func_selfbyname
(
arg
,
beg
,
len
,
xpath
->
pxml
);
break
;
default:
default:
res
=
new
Item_nodeset_func_childbyname
(
arg
,
beg
,
len
,
xpath
->
pxml
);
res
=
new
Item_nodeset_func_childbyname
(
arg
,
beg
,
len
,
xpath
->
pxml
);
}
}
...
...
sql/sql_partition.cc
View file @
0022bb67
...
@@ -3630,11 +3630,13 @@ bool mysql_unpack_partition(THD *thd, const uchar *part_buf,
...
@@ -3630,11 +3630,13 @@ bool mysql_unpack_partition(THD *thd, const uchar *part_buf,
Item
*
thd_free_list
=
thd
->
free_list
;
Item
*
thd_free_list
=
thd
->
free_list
;
bool
result
=
TRUE
;
bool
result
=
TRUE
;
partition_info
*
part_info
;
partition_info
*
part_info
;
CHARSET_INFO
*
old_character_set_client
=
thd
->
variables
.
character_set_client
;
LEX
*
old_lex
=
thd
->
lex
;
LEX
*
old_lex
=
thd
->
lex
;
LEX
lex
;
LEX
lex
;
DBUG_ENTER
(
"mysql_unpack_partition"
);
DBUG_ENTER
(
"mysql_unpack_partition"
);
thd
->
lex
=
&
lex
;
thd
->
lex
=
&
lex
;
thd
->
variables
.
character_set_client
=
system_charset_info
;
lex_start
(
thd
,
part_buf
,
part_info_len
);
lex_start
(
thd
,
part_buf
,
part_info_len
);
/*
/*
We need to use the current SELECT_LEX since I need to keep the
We need to use the current SELECT_LEX since I need to keep the
...
@@ -3760,6 +3762,7 @@ bool mysql_unpack_partition(THD *thd, const uchar *part_buf,
...
@@ -3760,6 +3762,7 @@ bool mysql_unpack_partition(THD *thd, const uchar *part_buf,
end:
end:
thd
->
free_list
=
thd_free_list
;
thd
->
free_list
=
thd_free_list
;
thd
->
lex
=
old_lex
;
thd
->
lex
=
old_lex
;
thd
->
variables
.
character_set_client
=
old_character_set_client
;
DBUG_RETURN
(
result
);
DBUG_RETURN
(
result
);
}
}
...
...
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