Browse Source
Backporting bugs fixes fixed by MDEV-31340 from 11.5
Backporting bugs fixes fixed by MDEV-31340 from 11.5
The patch for MDEV-31340 fixed the following bugs: MDEV-33084 LASTVAL(t1) and LASTVAL(T1) do not work well with lower-case-table-names=0 MDEV-33085 Tables T1 and t1 do not work well with ENGINE=CSV and lower-case-table-names=0 MDEV-33086 SHOW OPEN TABLES IN DB1 -- is case insensitive with lower-case-table-names=0 MDEV-33088 Cannot create triggers in the database `MYSQL` MDEV-33103 LOCK TABLE t1 AS t2 -- alias is not case sensitive with lower-case-table-names=0 MDEV-33108 TABLE_STATISTICS and INDEX_STATISTICS are case insensitive with lower-case-table-names=0 MDEV-33109 DROP DATABASE MYSQL -- does not drop SP with lower-case-table-names=0 MDEV-33110 HANDLER commands are case insensitive with lower-case-table-names=0 MDEV-33119 User is case insensitive in INFORMATION_SCHEMA.VIEWS MDEV-33120 System log table names are case insensitive with lower-cast-table-names=0 Backporting the fixes from 11.5 to 10.5pull/3270/head
23 changed files with 561 additions and 90 deletions
-
142mysql-test/main/lowercase_table5.result
-
138mysql-test/main/lowercase_table5.test
-
31mysql-test/main/view_grant.result
-
27mysql-test/main/view_grant.test
-
15mysql-test/suite/csv/lowercase_table0.result
-
16mysql-test/suite/csv/lowercase_table0.test
-
85sql/lex_ident.h
-
18sql/sql_acl.cc
-
52sql/sql_base.cc
-
3sql/sql_base.h
-
5sql/sql_class.cc
-
1sql/sql_class.h
-
6sql/sql_connect.cc
-
3sql/sql_db.cc
-
7sql/sql_handler.cc
-
15sql/sql_parse.cc
-
12sql/sql_show.cc
-
5sql/sql_string.h
-
2sql/sql_trigger.cc
-
35sql/table.cc
-
17sql/table.h
-
13sql/temporary_tables.cc
-
3storage/csv/ha_tina.cc
@ -0,0 +1,15 @@ |
|||
# |
|||
# MDEV-33085 Tables T1 and t1 do not work well with ENGINE=CSV and lower-case-table-names=0 |
|||
# |
|||
CREATE OR REPLACE TABLE t1 (a INT NOT NULL) ENGINE=CSV; |
|||
CREATE OR REPLACE TABLE T1 (a INT NOT NULL) ENGINE=CSV; |
|||
INSERT INTO t1 VALUES (10); |
|||
INSERT INTO T1 VALUES (20); |
|||
SELECT * FROM t1; |
|||
a |
|||
10 |
|||
SELECT * FROM T1; |
|||
a |
|||
20 |
|||
DROP TABLE t1; |
|||
DROP TABLE T1; |
|||
@ -0,0 +1,16 @@ |
|||
--source include/have_csv.inc |
|||
--source include/have_lowercase0.inc |
|||
--source include/have_case_sensitive_file_system.inc |
|||
|
|||
--echo # |
|||
--echo # MDEV-33085 Tables T1 and t1 do not work well with ENGINE=CSV and lower-case-table-names=0 |
|||
--echo # |
|||
|
|||
CREATE OR REPLACE TABLE t1 (a INT NOT NULL) ENGINE=CSV; |
|||
CREATE OR REPLACE TABLE T1 (a INT NOT NULL) ENGINE=CSV; |
|||
INSERT INTO t1 VALUES (10); |
|||
INSERT INTO T1 VALUES (20); |
|||
SELECT * FROM t1; |
|||
SELECT * FROM T1; |
|||
DROP TABLE t1; |
|||
DROP TABLE T1; |
|||
@ -0,0 +1,85 @@ |
|||
#ifndef LEX_IDENT_INCLUDED |
|||
#define LEX_IDENT_INCLUDED |
|||
/* |
|||
Copyright (c) 2023, MariaDB |
|||
|
|||
This program is free software; you can redistribute it and/or |
|||
modify it under the terms of the GNU General Public License |
|||
as published by the Free Software Foundation; version 2 of |
|||
the License. |
|||
|
|||
This program is distributed in the hope that it will be useful, |
|||
but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
GNU General Public License for more details. |
|||
|
|||
You should have received a copy of the GNU General Public License |
|||
along with this program; if not, write to the Free Software |
|||
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1335 USA |
|||
*/ |
|||
|
|||
|
|||
extern MYSQL_PLUGIN_IMPORT CHARSET_INFO *table_alias_charset; |
|||
|
|||
|
|||
/* |
|||
Identifiers for the database objects stored on disk, |
|||
e.g. databases, tables, triggers. |
|||
*/ |
|||
class Lex_ident_fs: public LEX_CSTRING |
|||
{ |
|||
public: |
|||
static CHARSET_INFO *charset_info() |
|||
{ |
|||
return table_alias_charset; |
|||
} |
|||
public: |
|||
Lex_ident_fs() |
|||
:LEX_CSTRING({0,0}) |
|||
{ } |
|||
Lex_ident_fs(const char *str, size_t length) |
|||
:LEX_CSTRING({str, length}) |
|||
{ } |
|||
explicit Lex_ident_fs(const LEX_CSTRING &str) |
|||
:LEX_CSTRING(str) |
|||
{ } |
|||
#if MYSQL_VERSION_ID<=110501 |
|||
private: |
|||
static bool is_valid_ident(const LEX_CSTRING &str) |
|||
{ |
|||
// NULL identifier, or 0-terminated identifier |
|||
return (str.str == NULL && str.length == 0) || str.str[str.length] == 0; |
|||
} |
|||
public: |
|||
bool streq(const LEX_CSTRING &rhs) const |
|||
{ |
|||
DBUG_ASSERT(is_valid_ident(*this)); |
|||
DBUG_ASSERT(is_valid_ident(rhs)); |
|||
return length == rhs.length && |
|||
my_strcasecmp(charset_info(), str, rhs.str) == 0; |
|||
} |
|||
#else |
|||
/* |
|||
Starting from 11.5.1 streq() is inherited from the base. |
|||
The above implementations of streq() and is_valid_ident() should be removed. |
|||
*/ |
|||
#error Remove streq() above. |
|||
#endif |
|||
}; |
|||
|
|||
|
|||
class Lex_ident_db: public Lex_ident_fs |
|||
{ |
|||
public: |
|||
using Lex_ident_fs::Lex_ident_fs; |
|||
}; |
|||
|
|||
|
|||
class Lex_ident_table: public Lex_ident_fs |
|||
{ |
|||
public: |
|||
using Lex_ident_fs::Lex_ident_fs; |
|||
}; |
|||
|
|||
|
|||
#endif // LEX_IDENT_INCLUDED |
|||
Write
Preview
Loading…
Cancel
Save
Reference in new issue