# Testing of feature statistics -- source include/have_geometry.inc -- source include/protocol.inc --disable_warnings drop table if exists t1; --enable_warnings set sql_mode=""; flush status; show status like "feature%"; --echo # --echo # Feature GIS --echo # CREATE TABLE t1 (g POINT); SHOW FIELDS FROM t1; INSERT INTO t1 VALUES (PointFromText('POINT(10 10)')), (PointFromText('POINT(20 10)')), (PointFromText('POINT(20 20)')), (PointFromWKB(AsWKB(PointFromText('POINT(10 20)')))); drop table t1; show status like "feature_gis"; --echo # --echo # Feature dynamic columns --echo # set @a= COLUMN_CREATE(1, 1212 AS int); set @b= column_add(@a, 2, 1212 as integer); select column_get(@b, 2 as integer); show status like "feature_dynamic_columns"; --echo # --echo # Feature fulltext --echo # CREATE TABLE t1 (a VARCHAR(200), b TEXT, FULLTEXT (a,b)) engine=myisam; INSERT INTO t1 VALUES('MySQL has now support', 'for full-text search'), ('Full-text indexes', 'are called collections'), ('Only MyISAM tables','support collections'), ('Function MATCH ... AGAINST()','is used to do a search'), ('Full-text search in MySQL', 'implements vector space model'); select * from t1 where MATCH(a,b) AGAINST ("collections"); select * from t1 where MATCH(a,b) AGAINST ("indexes"); drop table t1; # We need the following when running with --ps-protocol --replace_result 4 2 show status like "feature_fulltext"; --echo # --echo # Feature locale --echo # SET lc_messages=sr_RS; SET lc_messages=en_US; show status like "feature_locale"; --echo # --echo # Feature subquery --echo # select (select 2); SELECT (SELECT 1) UNION SELECT (SELECT 2); create table t1 (a int); insert into t1 values (2); select (select a from t1 where t1.a=t2.a), a from t1 as t2; drop table t1; --replace_result 8 4 show status like "feature_subquery"; --echo # --echo # Feature timezone --echo # SELECT FROM_UNIXTIME(unix_timestamp()) > "1970-01-01"; set time_zone="+03:00"; SELECT FROM_UNIXTIME(unix_timestamp()) > "1970-01-01"; set time_zone= @@global.time_zone; show status like "feature_timezone"; --echo # --echo # Feature triggers --echo # create table t1 (i int); --echo # let us test some very simple trigger create trigger trg before insert on t1 for each row set @a:=1; set @a:=0; select @a; insert into t1 values (1),(2); select @a; --replace_column 6 # SHOW TRIGGERS IN test like 't1'; drop trigger trg; drop table t1; show status like "%trigger%"; --echo # --echo # Feature xml --echo # SET @xml='a1b1c1b2a2'; SELECT extractValue(@xml,'/a'); select updatexml('
12
', '/','12') as upd1; --replace_result 4 2 show status like "feature_xml"; --echo # --echo # Feature delayed_keys --echo # create table t1 (a int, key(a)) engine=myisam delay_key_write=1; insert into t1 values(1); insert into t1 values(2); drop table t1; create table t1 (a int, key(a)) engine=aria delay_key_write=1; insert into t1 values(1); insert into t1 values(2); drop table t1; show status like "feature_delay_key_write"; --echo # --echo # Feature CHECK CONSTRAINT --echo # create table t1 (a int check (a > 5)); create table t2 (b int, constraint foo check (b < 10)); drop table t1, t2; show status like "feature_check_constraint"; --echo # --echo # Feature insert...returning --echo # create table t1(id1 int); insert into t1 values (1),(2) returning *; drop table t1; show status like "feature_insert_returning";