mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 18:38:00 +03:00 
			
		
		
		
	Problem:
  item->name was NULL for Item_user_var_as_out_param
  which made strcmp(something, item->name) crash in the LOAD XML code.
  
  Fix:
  - item_func.h: Adding set_name() in constuctor for Item_user_var_as_out_param
  - sql_load.cc: Changing the condition in write_execute_load_query_log_event() which
  distiguished between Item_user_var_as_out_param and Item_field
  from
    if (item->name == NULL)
  to
    if (item->type() == Item::FIELD_ITEM)
  - loadxml.result, loadxml.test: adding tests
		
	
		
			
				
	
	
		
			96 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| drop table if exists t1, t2;
 | |
| create table t1 (a int, b varchar(64));
 | |
| -- Load a static XML file
 | |
| load xml infile '../../std_data/loadxml.dat' into table t1
 | |
| rows identified by '<row>';
 | |
| select * from t1 order by a;
 | |
| a	b
 | |
| 1	b1
 | |
| 2	b2
 | |
| 3	b3
 | |
| 11	b11
 | |
| 111	b111
 | |
| 112	b112 & < > " ' &unknown; -- check entities
 | |
| 212	b212
 | |
| 213	b213
 | |
| 214	b214
 | |
| 215	b215
 | |
| 216	&bb b;
 | |
| delete from t1;
 | |
| -- Load a static XML file with 'IGNORE num ROWS'
 | |
| load xml infile '../../std_data/loadxml.dat' into table t1
 | |
| rows identified by '<row>' ignore 4 rows;
 | |
| select * from t1 order by a;
 | |
| a	b
 | |
| 111	b111
 | |
| 112	b112 & < > " ' &unknown; -- check entities
 | |
| 212	b212
 | |
| 213	b213
 | |
| 214	b214
 | |
| 215	b215
 | |
| 216	&bb b;
 | |
| -- Check 'mysqldump --xml' + 'LOAD XML' round trip
 | |
| delete from t1;
 | |
| load xml infile 'MYSQLTEST_VARDIR/tmp/loadxml-dump.xml' into table t1 rows identified by '<row>';;
 | |
| select * from t1 order by a;
 | |
| a	b
 | |
| 111	b111
 | |
| 112	b112 & < > " ' &unknown; -- check entities
 | |
| 212	b212
 | |
| 213	b213
 | |
| 214	b214
 | |
| 215	b215
 | |
| 216	&bb b;
 | |
| --Check that default row tag is '<row>
 | |
| delete from t1;
 | |
| load xml infile 'MYSQLTEST_VARDIR/tmp/loadxml-dump.xml' into table t1;;
 | |
| select * from t1 order by a;
 | |
| a	b
 | |
| 111	b111
 | |
| 112	b112 & < > " ' &unknown; -- check entities
 | |
| 212	b212
 | |
| 213	b213
 | |
| 214	b214
 | |
| 215	b215
 | |
| 216	&bb b;
 | |
| -- Check that 'xml' is not a keyword
 | |
| select 1 as xml;
 | |
| xml
 | |
| 1
 | |
| create table t2(fl text);
 | |
| LOAD XML LOCAL INFILE "MYSQLTEST_VARDIR/tmp/loadxml-dump.xml"  INTO TABLE t2 ROWS IDENTIFIED BY '<person>';;
 | |
| drop table t1;
 | |
| drop table t2;
 | |
| create table t1 (
 | |
| id int(11) not null,
 | |
| text text,
 | |
| primary key (id)
 | |
| ) engine=MyISAM default charset=latin1;
 | |
| load xml infile '../../std_data/loadxml2.dat' into table t1;
 | |
| select * from t1;
 | |
| id	text
 | |
| 1	line1
 | |
| line2
 | |
| line3
 | |
| drop table t1;
 | |
| #
 | |
| # Bug#51571 load xml infile causes server crash
 | |
| #
 | |
| CREATE TABLE t1 (a text, b text);
 | |
| LOAD XML INFILE '../../std_data/loadxml.dat' INTO TABLE t1
 | |
| ROWS IDENTIFIED BY '<row>' (a,@b) SET b=concat('!',@b);
 | |
| SELECT * FROM t1 ORDER BY a;
 | |
| a	b
 | |
| 1	!b1
 | |
| 11	!b11
 | |
| 111	!b111
 | |
| 112	!b112 & < > " ' &unknown; -- check entities
 | |
| 2	!b2
 | |
| 212	!b212
 | |
| 213	!b213
 | |
| 214	!b214
 | |
| 215	!b215
 | |
| 216	!&bb b;
 | |
| 3	!b3
 | |
| DROP TABLE t1;
 |