[ Avaa Bypassed ]




Upload:

Command:

hmhc3928@18.222.164.252: ~ $
# This is the DDL function tests for innodb FTS
# Functional testing with FTS proximity search using '@'
# and try search default words

--disable_warnings
drop table if exists t1;
--enable_warnings

--disable_query_log
let $innodb_file_format_orig = `select @@innodb_file_format`;
let $innodb_file_per_table_orig = `select @@innodb_file_per_table`;
--enable_query_log

# Create FTS table
CREATE TABLE t1 (
        id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
        a VARCHAR(200),
        b TEXT
        ) ENGINE= InnoDB;

# Create the FTS index again
CREATE FULLTEXT INDEX idx on t1 (a,b);

# Insert rows
INSERT INTO t1 (a,b) VALUES
        ('MySQL from Tutorial','DBMS stands for DataBase ...')  ,
        ('when To Use MySQL Well','After that you went through a ...'),
        ('where will Optimizing MySQL','what In this tutorial we will show ...');

# Try to Search default stopword from innodb, "where", "will", "what"
# and "when" are all stopwords
SELECT * FROM t1 WHERE MATCH(a,b) AGAINST ("where will");
SELECT * FROM t1 WHERE MATCH(a,b) AGAINST ("when");
SELECT * FROM t1 WHERE MATCH(a,b) AGAINST ("what" WITH QUERY EXPANSION);

# boolean No result expected
SELECT * FROM t1 WHERE MATCH(a,b) AGAINST("whe*" IN BOOLEAN MODE);
SELECT * FROM t1 WHERE MATCH(a,b) AGAINST("+what +will" IN BOOLEAN MODE);
SELECT * FROM t1 WHERE MATCH(a,b) AGAINST("+from" IN BOOLEAN MODE);
SELECT * FROM t1 WHERE MATCH(a,b) AGAINST("+where +(show what)" IN BOOLEAN MODE);

# no result expected. Words are filtered out as stopwords
SELECT * FROM t1
        WHERE MATCH (a,b)
        AGAINST ('"where will"@6' IN BOOLEAN MODE);

# no result expected
SELECT * FROM t1
        WHERE MATCH (a,b)
        AGAINST ('"where will"@9' IN BOOLEAN MODE);

# insert record with @ character which is used in proximity search
INSERT INTO t1 (a,b) VALUES
        ('MySQL Tutorial','request docteam@oraclehelp.com ...')  ,
        ('Trial version','query performace @1255 minute on 2.1Hz Memory 2GB...')  ,
        ('when To Use MySQL Well','for free faq  mail@xyz.com ...');
# proximity search with @ charcter

# We don't need more than one word in proximity search. Single word
# treated as single word search
SELECT * FROM t1
        WHERE MATCH (a,b)
        AGAINST ('"request"@10' IN BOOLEAN MODE);

# If the distance is 0, it is treated as "phrase search"
SELECT * FROM t1
        WHERE MATCH (a,b)
        AGAINST ('"Trial version"@0' IN BOOLEAN MODE);

# @ is word seperator
SELECT * FROM t1
        WHERE MATCH (a,b)
        AGAINST ('"request docteam@oraclehelp.com"@10' IN BOOLEAN MODE);

# This should not return any document
SELECT * FROM t1
        WHERE MATCH (a,b)
        AGAINST ('"1255 minute"@1' IN BOOLEAN MODE);

# This should return the first document. That is "1255" and "minutes" are
# in a two-word range (adjacent)
SELECT * FROM t1
        WHERE MATCH (a,b)
        AGAINST ('"1255 minute"@2' IN BOOLEAN MODE);

SELECT * FROM t1
        WHERE MATCH (a,b)
        AGAINST ('"1255"@10' IN BOOLEAN MODE);

SELECT * FROM t1
        WHERE MATCH (a,b)
        AGAINST ('1255' WITH QUERY EXPANSION);

SELECT * FROM t1
        WHERE MATCH (a,b)
        AGAINST ('"request docteam"@2' IN BOOLEAN MODE);

SELECT * FROM t1
        WHERE MATCH (a,b)
        AGAINST ('"1255 minute"' IN BOOLEAN MODE);

SELECT * FROM t1
        WHERE MATCH (a,b)
        AGAINST ('request docteam@oraclehelp.com');

# Test across fields search
SELECT * FROM t1
        WHERE MATCH (a,b)
	AGAINST ('"MySQL request"@3' IN BOOLEAN MODE);

# Two words are in 10 words range
SELECT * FROM t1
        WHERE MATCH (a,b)
	AGAINST ('"Trial memory"@10' IN BOOLEAN MODE);

SELECT * FROM t1
        WHERE MATCH (a,b)
	AGAINST ('"Trial memory"@9' IN BOOLEAN MODE);

DROP TABLE t1;

# test on utf8 encoded proximity search
CREATE TABLE t1 (
	id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
	a VARCHAR(200),
	b TEXT
	) CHARACTER SET = UTF8, ENGINE= InnoDB;

INSERT INTO t1 (a,b) VALUES
	('MySQL from Tutorial','DBMS stands for DataBase ...')  ,
	('when To Use MySQL Well','After that you went through a ...'),
	('where will Optimizing MySQL','what In this tutorial we will show ...');

CREATE FULLTEXT INDEX idx on t1 (a,b);

INSERT INTO t1 (a,b) VALUES
	('MySQL Tutorial','request docteam@oraclehelp.com ...')  ,
	('Trial version','query performace @1255 minute on 2.1Hz Memory 2GB...'),
	('when To Use MySQL Well','for free faq  mail@xyz.com ...');

# Should have 2 rows. Note proximity search does require words in order
SELECT * FROM t1
        WHERE MATCH (a,b)
        AGAINST ('"mysql use"@2' IN BOOLEAN MODE);

# Should return 0 row
SELECT * FROM t1
        WHERE MATCH (a,b)
        AGAINST ('"mysql use"@1' IN BOOLEAN MODE);

INSERT INTO t1 (a,b) VALUES   ('XYZ, long blob', repeat("a", 9000));

INSERT INTO t1 (a,b) VALUES   (repeat("b", 9000), 'XYZ, long blob');

# 2 rows match
SELECT count(*) FROM t1
        WHERE MATCH (a,b)
        AGAINST ('"xyz blob"@3' IN BOOLEAN MODE);

DROP TABLE t1;

set global innodb_file_format="Barracuda";
set global innodb_file_per_table=1;

# Test fts with externally stored long column
CREATE TABLE t1 (
	id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
	a TEXT,
	b TEXT,
	c TEXT
	) CHARACTER SET = UTF8, ROW_FORMAT=DYNAMIC, ENGINE= InnoDB;

INSERT INTO t1 (a,b,c) VALUES   (repeat("b", 19000), 'XYZ, long text', 'very long blob');
INSERT INTO t1 (a,b,c) VALUES   (repeat("b", 19000), 'XYZ, very little long blob very much blob', 'very long blob');

# Note 租车 is count as one word
INSERT INTO t1 (a,b,c) VALUES   (repeat("b", 19000),"very 租车 供 blob","new 供需分析information");
CREATE FULLTEXT INDEX idx on t1 (a,b,c);

INSERT INTO t1 (a,b,c) VALUES   (repeat("x", 19000), 'new, long text', 'very new blob');
INSERT INTO t1 (a,b,c) VALUES   ('interesting, long text', repeat("x", 19000), 'very very good new blob');

# 3 rows should match
SELECT count(*) FROM t1
        WHERE MATCH (a,b,c)
        AGAINST ('"very blob"@3' IN BOOLEAN MODE);

SELECT count(*) FROM t1
        WHERE MATCH (a,b,c)
        AGAINST ('"very long blob"@0' IN BOOLEAN MODE);

# 4 rows should match
SELECT count(*) FROM t1
        WHERE MATCH (a,b,c)
        AGAINST ('"very blob"@4' IN BOOLEAN MODE);

# 1 row should match
SELECT count(*) FROM t1
         WHERE MATCH (a,b,c)
         AGAINST ('"interesting blob"@9' IN BOOLEAN MODE);

# should have 3 rows
SELECT COUNT(*) FROM t1
	 WHERE MATCH (a,b,c)
	 AGAINST ('"interesting blob"@9  "very long blob"@0' IN BOOLEAN MODE);

# should have 3 rows
SELECT COUNT(*) FROM t1
         WHERE MATCH (a,b,c)
         AGAINST ('"very blob"@4 - "interesting blob"@9' IN BOOLEAN MODE);

DROP TABLE t1;

CREATE TABLE t1 (
	id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
	a VARCHAR(200),
	b TEXT
	) CHARACTER SET = UTF8, ENGINE= InnoDB;

# Space and special characters are not counted as word
INSERT INTO t1 (a,b) VALUES
	('MySQL from Tutorial','DBMS stands for    + DataBase ...');

CREATE FULLTEXT INDEX idx on t1 (a,b);

SELECT * FROM t1
WHERE MATCH (a,b)
AGAINST ('"stands database"@3' IN BOOLEAN MODE);

DROP TABLE t1;

# Test fts with externally stored long column
CREATE TABLE t1 (
	id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
	a TEXT,
	b TEXT,
	c TEXT
	) CHARACTER SET = UTF8, ROW_FORMAT=DYNAMIC, ENGINE= InnoDB;

INSERT INTO t1 (a,b,c) VALUES   (repeat("b", 19000), 'XYZ, long text', 'very long blob');
INSERT INTO t1 (a,b,c) VALUES   ('XYZ, 租车 very little long blob very much blob', repeat("b", 19000), 'very long but smaller blob');

CREATE FULLTEXT INDEX idx on t1 (a,b,c);

DELETE FROM t1;

INSERT INTO t1 (a,b,c) VALUES   (repeat("b", 19000), 'XYZ, long text', 'very long blob');
INSERT INTO t1 (a,b,c) VALUES   ('XYZ, 租车 very little long blob is a very much longer blob', repeat("b", 19000), 'this is very long but smaller blob');

SELECT count(*) FROM t1
        WHERE MATCH (a,b,c)
        AGAINST ('"very blob"@4' IN BOOLEAN MODE);

SELECT count(*) FROM t1
        WHERE MATCH (a,b,c)
        AGAINST ('"very blob"@3' IN BOOLEAN MODE);

DROP TABLE t1;

eval SET GLOBAL innodb_file_format=$innodb_file_format_orig;
eval SET GLOBAL innodb_file_per_table=$innodb_file_per_table_orig;

Filemanager

Name Type Size Permission Actions
disabled.def File 404 B 0644
fts_compatibility.test File 9.74 KB 0644
fts_compatibility_win.test File 9.58 KB 0644
fulltext.test File 22.1 KB 0644
fulltext2.test File 8.27 KB 0644
fulltext3.test File 988 B 0644
fulltext_cache.test File 1.55 KB 0644
fulltext_distinct.test File 1.18 KB 0644
fulltext_left_join.test File 4.54 KB 0644
fulltext_misc.test File 7.75 KB 0644
fulltext_multi.test File 919 B 0644
fulltext_order_by.test File 5.57 KB 0644
fulltext_plugin-master.opt File 19 B 0644
fulltext_update.test File 1.02 KB 0644
fulltext_var.test File 1.36 KB 0644
innobase_drop_fts_index_table.test File 407 B 0644
innodb-fts-basic.test File 8.74 KB 0644
innodb-fts-ddl.test File 9.15 KB 0644
innodb-fts-fic.test File 7.12 KB 0644
innodb-fts-stopword.test File 30.48 KB 0644
innodb_fts_index_table.test File 3.32 KB 0644
innodb_fts_large_records.test File 12.15 KB 0644
innodb_fts_misc.test File 55.24 KB 0644
innodb_fts_misc_1.test File 33.01 KB 0644
innodb_fts_misc_debug.test File 6.81 KB 0644
innodb_fts_multiple_index.test File 6.34 KB 0644
innodb_fts_opt.test File 14.02 KB 0644
innodb_fts_plugin.test File 1.35 KB 0644
innodb_fts_proximity.test File 7.98 KB 0644
innodb_fts_result_cache_limit.test File 1.76 KB 0644
innodb_fts_savepoint.test File 9.09 KB 0644
innodb_fts_stopword_charset.test File 13.79 KB 0644
innodb_fts_transaction.test File 31.11 KB 0644
phrase.test File 1.01 KB 0644
subexpr.test File 2.09 KB 0644
sync.test File 5.33 KB 0644
sync_block.test File 3.48 KB 0644