mirror of
https://github.com/MariaDB/server.git
synced 2025-07-07 06:01:31 +03:00
In my merge of the MySQL fix for Oracle Bug#23333990 / WL#9513 I overlooked some subsequent revisions to the test, and I also failed to notice that the test is actually always failing. Oracle introduced the parameter innodb_stats_include_delete_marked but failed to consistently take it into account in FOREIGN KEY constraints that involve CASCADE or SET NULL. When innodb_stats_include_delete_marked=ON, obviously the purge of delete-marked records should update the statistics as well. One more omission was that statistics were never updated on ROLLBACK. We are fixing that as well, properly taking into account the parameter innodb_stats_include_delete_marked. dict_stats_analyze_index_level(): Simplify an expression. (Using the ternary operator with a constant operand is unnecessary obfuscation.) page_scan_method_t: Revert the change done by Oracle. Instead, examine srv_stats_include_delete_marked directly where it is needed. dict_stats_update_if_needed(): Renamed from row_update_statistics_if_needed(). row_update_for_mysql_using_upd_graph(): Assert that the table statistics are initialized, as guaranteed by ha_innobase::open(). Update the statistics in a consistent way, both for FOREIGN KEY triggers and for the main table. If FOREIGN KEY constraints exist, do not dereference a freed pointer, but cache the proper value of node->is_delete so that it matches prebuilt->table. row_purge_record_func(): Update statistics if innodb_stats_include_delete_marked=ON. row_undo_ins(): Update statistics (on ROLLBACK of a fresh INSERT). This is independent of the parameter; the record is not delete-marked. row_undo_mod(): Update statistics on the ROLLBACK of updating key columns, or (if innodb_stats_include_delete_marked=OFF) updating delete-marks. innodb.innodb_stats_persistent: Renamed and extended from innodb.innodb_stats_del_mark. Reduced the unnecessarily large dataset from 262,144 to 32 rows. Test both values of the configuration parameter innodb_stats_include_delete_marked. Test that purge is updating the statistics. innodb_fts.innodb_fts_multiple_index: Adjust the result. The test is performing a ROLLBACK of an INSERT, which now affects the statistics. include/wait_all_purged.inc: Moved from innodb.innodb_truncate_debug to its own file.
214 lines
9.2 KiB
Plaintext
214 lines
9.2 KiB
Plaintext
drop table if exists t1;
|
|
CREATE TABLE t1 (
|
|
id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
|
|
a VARCHAR(200),
|
|
b TEXT
|
|
) ENGINE = InnoDB STATS_PERSISTENT=0;
|
|
INSERT INTO t1 (a,b) VALUES
|
|
('MySQL Tutorial','DBMS stands for DataBase ...') ,
|
|
('How To Use MySQL Well','After you went through a ...'),
|
|
('Optimizing MySQL','In this tutorial we will show ...');
|
|
ALTER TABLE t1 ADD FULLTEXT INDEX idx_1 (a);
|
|
Warnings:
|
|
Warning 124 InnoDB rebuilding table to add column FTS_DOC_ID
|
|
ALTER TABLE t1 ADD FULLTEXT INDEX idx_2 (b);
|
|
SHOW CREATE TABLE t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
|
|
`a` varchar(200) DEFAULT NULL,
|
|
`b` text DEFAULT NULL,
|
|
PRIMARY KEY (`id`),
|
|
FULLTEXT KEY `idx_1` (`a`),
|
|
FULLTEXT KEY `idx_2` (`b`)
|
|
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=latin1 STATS_PERSISTENT=0
|
|
START TRANSACTION;
|
|
INSERT INTO t1 (a,b) VALUES
|
|
('1001 MySQL Tricks','1. Never run mysqld as root. 2. ...'),
|
|
('MySQL vs. YourSQL','In the following database comparison ...'),
|
|
('MySQL Security','When configured properly, MySQL ...');
|
|
ROLLBACK;
|
|
SELECT * FROM t1 WHERE MATCH (a)
|
|
AGAINST ('Tutorial' IN NATURAL LANGUAGE MODE);
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
select * from t1 where MATCH(a) AGAINST("+mysql +Tutorial" IN BOOLEAN MODE);
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
select * from t1 where MATCH(b) AGAINST("+Tutorial" IN BOOLEAN MODE);
|
|
id a b
|
|
3 Optimizing MySQL In this tutorial we will show ...
|
|
select * from t1 where MATCH(b) AGAINST("+stands +(DataBase)" IN BOOLEAN MODE);
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
select * from t1 where MATCH(b) AGAINST("+DataBase -(comparison)" IN BOOLEAN MODE);
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
select *, MATCH(a) AGAINST("Optimizing MySQL" IN BOOLEAN MODE) as x from t1;
|
|
id a b x
|
|
1 MySQL Tutorial DBMS stands for DataBase ... 0.000000001885928302414186
|
|
2 How To Use MySQL Well After you went through a ... 0.000000001885928302414186
|
|
3 Optimizing MySQL In this tutorial we will show ... 0.22764469683170319
|
|
select *, MATCH(b) AGAINST("collections support" IN BOOLEAN MODE) as x from t1;
|
|
id a b x
|
|
1 MySQL Tutorial DBMS stands for DataBase ... 0
|
|
2 How To Use MySQL Well After you went through a ... 0
|
|
3 Optimizing MySQL In this tutorial we will show ... 0
|
|
select * from t1 where MATCH a AGAINST ("+Optimiz* +Optimiz*" IN BOOLEAN MODE);
|
|
id a b
|
|
3 Optimizing MySQL In this tutorial we will show ...
|
|
select * from t1 where MATCH b AGAINST ('"DBMS stands"' IN BOOLEAN MODE);
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
select * from t1 where MATCH b AGAINST ('"DBMS STANDS"' IN BOOLEAN MODE);
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
select * from t1 where MATCH(b) AGAINST ("DataBase" WITH QUERY EXPANSION);
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
select * from t1 where MATCH(a) AGAINST ("Security" WITH QUERY EXPANSION);
|
|
id a b
|
|
ALTER TABLE t1 DROP INDEX idx_1;
|
|
ALTER TABLE t1 DROP INDEX idx_2;
|
|
ALTER TABLE t1 ADD FULLTEXT INDEX idx_1 (a);
|
|
ALTER TABLE t1 ADD FULLTEXT INDEX idx_2 (b);
|
|
SELECT * FROM t1 WHERE MATCH (a)
|
|
AGAINST ('Tutorial' IN NATURAL LANGUAGE MODE);
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
select * from t1 where MATCH(a) AGAINST("+mysql +Tutorial" IN BOOLEAN MODE);
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
select * from t1 where MATCH(b) AGAINST("+Tutorial" IN BOOLEAN MODE);
|
|
id a b
|
|
3 Optimizing MySQL In this tutorial we will show ...
|
|
select * from t1 where MATCH(b) AGAINST("+stands +(DataBase)" IN BOOLEAN MODE);
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
select * from t1 where MATCH(b) AGAINST("+DataBase -(comparison)" IN BOOLEAN MODE);
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
select *, MATCH(a) AGAINST("Optimizing MySQL" IN BOOLEAN MODE) as x from t1;
|
|
id a b x
|
|
1 MySQL Tutorial DBMS stands for DataBase ... 0.000000001885928302414186
|
|
2 How To Use MySQL Well After you went through a ... 0.000000001885928302414186
|
|
3 Optimizing MySQL In this tutorial we will show ... 0.22764469683170319
|
|
select *, MATCH(b) AGAINST("collections support" IN BOOLEAN MODE) as x from t1;
|
|
id a b x
|
|
1 MySQL Tutorial DBMS stands for DataBase ... 0
|
|
2 How To Use MySQL Well After you went through a ... 0
|
|
3 Optimizing MySQL In this tutorial we will show ... 0
|
|
select * from t1 where MATCH a AGAINST ("+Optimiz* +Optimiz*" IN BOOLEAN MODE);
|
|
id a b
|
|
3 Optimizing MySQL In this tutorial we will show ...
|
|
select * from t1 where MATCH b AGAINST ('"DBMS stands"' IN BOOLEAN MODE);
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
select * from t1 where MATCH b AGAINST ('"DBMS STANDS"' IN BOOLEAN MODE);
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
select * from t1 where MATCH(b) AGAINST ("DataBase" WITH QUERY EXPANSION);
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
select * from t1 where MATCH(a) AGAINST ("Security" WITH QUERY EXPANSION);
|
|
id a b
|
|
INSERT INTO t1 (a,b) VALUES ('test query expansion','for database ...');
|
|
INSERT INTO t1 (a,b) VALUES
|
|
('test proximity search, test, proximity and phrase',
|
|
'search, with proximity innodb');
|
|
INSERT INTO t1 (a,b) VALUES
|
|
('test proximity fts search, test, proximity and phrase',
|
|
'search, with proximity innodb');
|
|
INSERT INTO t1 (a,b) VALUES
|
|
('test more of proximity for fts search, test, more proximity and phrase',
|
|
'search, with proximity innodb');
|
|
SELECT * FROM t1
|
|
WHERE MATCH (a)
|
|
AGAINST ('"proximity search"@3' IN BOOLEAN MODE);
|
|
id a b
|
|
8 test proximity search, test, proximity and phrase search, with proximity innodb
|
|
9 test proximity fts search, test, proximity and phrase search, with proximity innodb
|
|
SELECT * FROM t1
|
|
WHERE MATCH (a)
|
|
AGAINST ('"proximity search"@2' IN BOOLEAN MODE);
|
|
id a b
|
|
8 test proximity search, test, proximity and phrase search, with proximity innodb
|
|
SELECT * FROM t1
|
|
WHERE MATCH (b)
|
|
AGAINST ('"proximity innodb"@4' IN BOOLEAN MODE);
|
|
id a b
|
|
8 test proximity search, test, proximity and phrase search, with proximity innodb
|
|
9 test proximity fts search, test, proximity and phrase search, with proximity innodb
|
|
10 test more of proximity for fts search, test, more proximity and phrase search, with proximity innodb
|
|
SELECT * FROM t1
|
|
WHERE MATCH (a)
|
|
AGAINST ('"test proximity"@3' IN BOOLEAN MODE);
|
|
id a b
|
|
8 test proximity search, test, proximity and phrase search, with proximity innodb
|
|
9 test proximity fts search, test, proximity and phrase search, with proximity innodb
|
|
10 test more of proximity for fts search, test, more proximity and phrase search, with proximity innodb
|
|
SELECT * FROM t1
|
|
WHERE MATCH (a)
|
|
AGAINST ('"more test proximity"@3' IN BOOLEAN MODE);
|
|
id a b
|
|
10 test more of proximity for fts search, test, more proximity and phrase search, with proximity innodb
|
|
SELECT * FROM t1
|
|
WHERE MATCH (a)
|
|
AGAINST ('"more test proximity"@2' IN BOOLEAN MODE);
|
|
id a b
|
|
SELECT * FROM t1
|
|
WHERE MATCH (a)
|
|
AGAINST ('"more fts proximity"@02' IN BOOLEAN MODE);
|
|
id a b
|
|
SELECT * FROM t1 WHERE CONCAT(t1.a,t1.b) IN (
|
|
SELECT CONCAT(a,b) FROM t1 AS t2 WHERE
|
|
MATCH (t2.a) AGAINST ('Tutorial' IN NATURAL LANGUAGE MODE)
|
|
) OR t1.id = 3 ;
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
3 Optimizing MySQL In this tutorial we will show ...
|
|
SELECT * FROM t1 WHERE CONCAT(t1.a,t1.b) IN (
|
|
SELECT CONCAT(a,b) FROM t1 AS t2
|
|
WHERE MATCH (t2.a) AGAINST ('Tutorial' IN NATURAL LANGUAGE MODE)
|
|
AND t2.id != 3) ;
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
SELECT * FROM t1 WHERE id IN (SELECT MIN(id) FROM t1 WHERE
|
|
MATCH (b) AGAINST ('Tutorial' IN NATURAL LANGUAGE MODE)) OR id = 3 ;
|
|
id a b
|
|
3 Optimizing MySQL In this tutorial we will show ...
|
|
SELECT * FROM t1 WHERE id NOT IN (SELECT MIN(id) FROM t1
|
|
WHERE MATCH (b) AGAINST ('Tutorial' IN NATURAL LANGUAGE MODE)) ;
|
|
id a b
|
|
1 MySQL Tutorial DBMS stands for DataBase ...
|
|
2 How To Use MySQL Well After you went through a ...
|
|
7 test query expansion for database ...
|
|
8 test proximity search, test, proximity and phrase search, with proximity innodb
|
|
9 test proximity fts search, test, proximity and phrase search, with proximity innodb
|
|
10 test more of proximity for fts search, test, more proximity and phrase search, with proximity innodb
|
|
SELECT * FROM t1 WHERE EXISTS (SELECT t2.id FROM t1 AS t2 WHERE
|
|
MATCH (t2.b) AGAINST ('Tutorial' IN NATURAL LANGUAGE MODE)
|
|
AND t1.id = t2.id) ;
|
|
id a b
|
|
3 Optimizing MySQL In this tutorial we will show ...
|
|
SELECT * FROM t1 WHERE NOT EXISTS (SELECT t2.id FROM t1 AS t2 WHERE
|
|
MATCH (t2.a) AGAINST ('Tutorial' IN NATURAL LANGUAGE MODE)
|
|
AND t1.id = t2.id) ;
|
|
id a b
|
|
2 How To Use MySQL Well After you went through a ...
|
|
3 Optimizing MySQL In this tutorial we will show ...
|
|
7 test query expansion for database ...
|
|
8 test proximity search, test, proximity and phrase search, with proximity innodb
|
|
9 test proximity fts search, test, proximity and phrase search, with proximity innodb
|
|
10 test more of proximity for fts search, test, more proximity and phrase search, with proximity innodb
|
|
SELECT * FROM t1 WHERE t1.id = (SELECT MAX(t2.id) FROM t1 AS t2 WHERE
|
|
MATCH(t2.a) AGAINST ('"proximity search"@3' IN BOOLEAN MODE));
|
|
id a b
|
|
9 test proximity fts search, test, proximity and phrase search, with proximity innodb
|
|
SELECT * FROM t1 WHERE t1.id > (SELECT MIN(t2.id) FROM t1 AS t2 WHERE
|
|
MATCH(t2.b) AGAINST ('"proximity innodb"@3' IN BOOLEAN MODE));
|
|
id a b
|
|
9 test proximity fts search, test, proximity and phrase search, with proximity innodb
|
|
10 test more of proximity for fts search, test, more proximity and phrase search, with proximity innodb
|
|
DROP TABLE t1;
|