mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-26 01:18:31 +02:00 
			
		
		
		
	 7ae12371dd
			
		
	
	
	7ae12371dd
	
	
	
		
			
			create_table_info_t::create_foreign_keys(): Make the create_name buffer long enough for both the database and table name. It is still not long enough to hold partition or subpartition names. Because we do never supported FOREIGN KEY constraints on partitions, we can simply skip the call to innobase_convert_name() on CREATE TABLE.
		
			
				
	
	
		
			66 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| source include/have_innodb.inc;
 | |
| source include/have_partition.inc;
 | |
| # The absolute path names in the embedded server hit the limit earlier.
 | |
| source include/not_embedded.inc;
 | |
| set names utf8;
 | |
| 
 | |
| create database mysqltest1;
 | |
| select database_name, table_name, length(table_name) from mysql.innodb_table_stats where database_name = 'mysqltest1';
 | |
| CREATE TABLE mysqltest1.test_jfg_table_name_with_64_chars_123456789012345678901234567890 (
 | |
|   id int(10) unsigned NOT NULL,
 | |
|   id2 int(10) unsigned NOT NULL,
 | |
|   PRIMARY KEY ( id, id2 )
 | |
| ) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=DYNAMIC
 | |
| PARTITION BY RANGE ( id )
 | |
|   SUBPARTITION BY HASH ( id2 )
 | |
|   SUBPARTITIONS 2 (
 | |
|   PARTITION test_jfg_partition_name_with_60_chars_1234567890123456789012 VALUES LESS THAN (1000) ENGINE = InnoDB,
 | |
|   PARTITION pmax VALUES LESS THAN MAXVALUE ENGINE = InnoDB);
 | |
| 
 | |
| select database_name, table_name, length(table_name) from mysql.innodb_table_stats where database_name = 'mysqltest1';
 | |
| 
 | |
| --error ER_PATH_LENGTH
 | |
| CREATE TABLE mysqltest1.éééééééééééééééééééééééééééééééééééééééééééééééééééééééééééééééé (
 | |
|   id int(10) unsigned NOT NULL,
 | |
|   id2 int(10) unsigned NOT NULL,
 | |
|   PRIMARY KEY ( id, id2 )
 | |
| ) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=DYNAMIC
 | |
| PARTITION BY RANGE ( id )
 | |
|   SUBPARTITION BY HASH ( id2 )
 | |
|   SUBPARTITIONS 2 (
 | |
|   PARTITION çççççççççççççççççççççççççççççççççççççççççççççççççççççççççççç VALUES LESS THAN (1000) ENGINE = InnoDB,
 | |
|   PARTITION pmax VALUES LESS THAN MAXVALUE ENGINE = InnoDB);
 | |
| 
 | |
| SET @file_per_table=@@GLOBAL.innodb_file_per_table;
 | |
| SET GLOBAL innodb_file_per_table=0;
 | |
| 
 | |
| CREATE TABLE mysqltest1.t1 (a INT) ENGINE=INNODB
 | |
| PARTITION BY RANGE (a) SUBPARTITION BY HASH(a)
 | |
| (PARTITION `$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$`
 | |
|  VALUES LESS THAN (10)
 | |
|  (SUBPARTITION
 | |
|   `--------------------------abcdef0123456789abcdef0123456789abcdef`,
 | |
|   SUBPARTITION
 | |
|   `0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef`)
 | |
| );
 | |
| 
 | |
| SET GLOBAL innodb_file_per_table=@file_per_table;
 | |
| 
 | |
| SHOW CREATE TABLE mysqltest1.t1;
 | |
| INSERT INTO mysqltest1.t1 VALUES(1);
 | |
| 
 | |
| --error ER_WRONG_TABLE_NAME
 | |
| DROP TABLE mysqltest1.`#mysql50#t1#P#@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024@0024#SP#0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef`;
 | |
| 
 | |
| --error ER_FEATURE_NOT_SUPPORTED_WITH_PARTITIONING
 | |
| ALTER TABLE mysqltest1.t1 ADD FOREIGN KEY (a) REFERENCES
 | |
| mysqltest1.test_jfg_table_name_with_64_chars_123456789012345678901234567890;
 | |
| --error ER_FEATURE_NOT_SUPPORTED_WITH_PARTITIONING
 | |
| ALTER TABLE
 | |
| mysqltest1.test_jfg_table_name_with_64_chars_123456789012345678901234567890
 | |
| ADD FOREIGN KEY (a) REFERENCES mysqltest1.t1;
 | |
| 
 | |
| SELECT NAME FROM INFORMATION_SCHEMA.INNODB_SYS_TABLES
 | |
| WHERE NAME LIKE 'mysqltest1%';
 | |
| 
 | |
| drop database mysqltest1;
 |