heap_btree.test
上传用户:romrleung
上传日期:2022-05-23
资源大小:18897k
文件大小:5k
源码类别:

MySQL数据库

开发平台:

Visual C++

  1. #
  2. # Test of heap tables.
  3. #
  4. --disable_warnings
  5. drop table if exists t1;
  6. --enable_warnings
  7. create table t1 (a int not null,b int not null, primary key using BTREE (a)) engine=heap comment="testing heaps" avg_row_length=100 min_rows=1 max_rows=100;
  8. insert into t1 values(1,1),(2,2),(3,3),(4,4);
  9. delete from t1 where a=1 or a=0;
  10. #show table status like "t1";
  11. show keys from t1;
  12. select * from t1;
  13. select * from t1 where a=4;
  14. update t1 set b=5 where a=4;
  15. update t1 set b=b+1 where a>=3;
  16. replace t1 values (3,3);
  17. select * from t1;
  18. alter table t1 add c int not null, add key using BTREE (c,a);
  19. drop table t1;
  20. create table t1 (a int not null,b int not null, primary key using BTREE (a)) engine=heap comment="testing heaps";
  21. insert into t1 values(-2,-2),(-1,-1),(0,0),(1,1),(2,2),(3,3),(4,4);
  22. delete from t1 where a > -3;
  23. select * from t1;
  24. drop table t1;
  25. create table t1 (a int not null,b int not null, primary key using BTREE (a)) engine=heap comment="testing heaps";
  26. insert into t1 values(1,1),(2,2),(3,3),(4,4);
  27. alter table t1 modify a int not null auto_increment, engine=myisam, comment="new myisam table";
  28. #show table status like "t1";
  29. select * from t1;
  30. drop table t1;
  31. create table t1 (a int not null) engine=heap;
  32. insert into t1 values (869751),(736494),(226312),(802616);
  33. select * from t1 where a > 736494;
  34. alter table t1 add unique uniq_id using BTREE (a);
  35. select * from t1 where a > 736494;
  36. select * from t1 where a = 736494;
  37. select * from t1 where a=869751 or a=736494;
  38. select * from t1 where a in (869751,736494,226312,802616);
  39. alter table t1 engine=myisam;
  40. explain select * from t1 where a in (869751,736494,226312,802616);
  41. drop table t1;
  42. create table t1 (x int not null, y int not null, key x  using BTREE (x,y), unique y  using BTREE (y))
  43. engine=heap;
  44. insert into t1 values (1,1),(2,2),(1,3),(2,4),(2,5),(2,6);
  45. explain select * from t1 where x=1;
  46. select * from t1 where x=1;
  47. select * from t1,t1 as t2 where t1.x=t2.y;
  48. explain select * from t1,t1 as t2 where t1.x=t2.y;
  49. drop table t1;
  50. create table t1 (a int) engine=heap;
  51. insert into t1 values(1);
  52. select max(a) from t1;
  53. drop table t1;
  54. CREATE TABLE t1 ( a int not null default 0, b int not null default 0,  key  using BTREE (a,b),  key  using BTREE (b)  ) ENGINE=HEAP;
  55. insert into t1 values(1,1),(1,2),(2,3),(1,3),(1,4),(1,5),(1,6);
  56. select * from t1 where a=1; 
  57. insert into t1 values(1,1),(1,2),(2,3),(1,3),(1,4),(1,5),(1,6);
  58. select * from t1 where a=1;
  59. --replace_result 0 x 1 x 2 x 3 x 4 x 5 x 6 x 7 x 8 x 9 x 10 x 11 x 12 x 13 x 14 x
  60. explain select * from t1 where a=1 order by a,b;
  61. --replace_result 0 x 1 x 2 x 3 x 4 x 5 x 6 x 7 x 8 x 9 x 10 x 11 x 12 x 13 x 14 x
  62. explain select * from t1 where a=1 order by b;
  63. select * from t1 where b=1;
  64. --replace_result 0 x 1 x 2 x 3 x 4 x 5 x 6 x 7 x 8 x 9 x 10 x 11 x 12 x 13 x 14 x
  65. explain select * from t1 where b=1;
  66. drop table t1;
  67. create table t1 (id int unsigned not null, primary key  using BTREE (id)) engine=HEAP;
  68. insert into t1 values(1);
  69. select max(id) from t1; 
  70. insert into t1 values(2);
  71. select max(id) from t1; 
  72. replace into t1 values(1);
  73. drop table t1;
  74. create table t1 (n int) engine=heap;
  75. drop table t1;
  76. create table t1 (n int) engine=heap;
  77. drop table if exists t1;
  78. # Test of non unique index
  79. CREATE table t1(f1 int not null,f2 char(20) not 
  80. null,index(f2)) engine=heap;
  81. INSERT into t1 set f1=12,f2="bill";
  82. INSERT into t1 set f1=13,f2="bill";
  83. INSERT into t1 set f1=14,f2="bill";
  84. INSERT into t1 set f1=15,f2="bill";
  85. INSERT into t1 set f1=16,f2="ted";
  86. INSERT into t1 set f1=12,f2="ted";
  87. INSERT into t1 set f1=12,f2="ted";
  88. INSERT into t1 set f1=12,f2="ted";
  89. INSERT into t1 set f1=12,f2="ted";
  90. delete from t1 where f2="bill";
  91. select * from t1;
  92. drop table t1;
  93. #
  94. # Test when using part key searches
  95. #
  96. create table t1 (btn char(10) not null, key using BTREE (btn)) engine=heap;
  97. insert into t1 values ("hello"),("hello"),("hello"),("hello"),("hello"),("a"),("b"),("c"),("d"),("e"),("f"),("g"),("h"),("i");
  98. explain select * from t1 where btn like "i%";
  99. --replace_column 9 #
  100. explain select * from t1 where btn like "h%";
  101. explain select * from t1 where btn like "a%";
  102. explain select * from t1 where btn like "b%";
  103. # For the following the BTREE MAY notice that there is no possible matches
  104. select * from t1 where btn like "ff%";
  105. select * from t1 where btn like " %";
  106. select * from t1 where btn like "q%";
  107. alter table t1 add column new_col char(1) not null, add key using BTREE (btn,new_col), drop key btn;
  108. update t1 set new_col=left(btn,1);
  109. explain select * from t1 where btn="a";
  110. explain select * from t1 where btn="a" and new_col="a";
  111. drop table t1;
  112. #
  113. # Test of NULL keys
  114. #
  115. CREATE TABLE t1 (
  116.   a int default NULL,
  117.   b int default NULL,
  118.   KEY a using BTREE (a),
  119.   UNIQUE b using BTREE (b)
  120. ) engine=heap;
  121. INSERT INTO t1 VALUES (NULL,99),(99,NULL),(1,1),(2,2),(1,3);
  122. SELECT * FROM t1 WHERE a=NULL;
  123. explain SELECT * FROM t1 WHERE a IS NULL;
  124. SELECT * FROM t1 WHERE a<=>NULL;
  125. SELECT * FROM t1 WHERE b=NULL;
  126. explain SELECT * FROM t1 WHERE b IS NULL;
  127. SELECT * FROM t1 WHERE b<=>NULL;
  128. --error 1062
  129. INSERT INTO t1 VALUES (1,3);
  130. DROP TABLE t1;
  131. CREATE TABLE t1 (a int, b int, c int, key using BTREE (a, b, c)) engine=heap;
  132. INSERT INTO t1 VALUES (1, NULL, NULL), (1, 1, NULL), (1, NULL, 1);
  133. SELECT * FROM t1 WHERE a=1 and b IS NULL;
  134. SELECT * FROM t1 WHERE a=1 and c IS NULL;
  135. SELECT * FROM t1 WHERE a=1 and b IS NULL and c IS NULL;
  136. DROP TABLE t1;
  137. #
  138. # Test when deleting all rows
  139. #
  140. CREATE TABLE t1 (a int not null, primary key using BTREE (a)) engine=heap;
  141. INSERT into t1 values (1),(2),(3),(4),(5),(6),(7),(8),(9),(10),(11);
  142. DELETE from t1 where a < 100;
  143. SELECT * from t1;
  144. DROP TABLE t1;
  145. # End of 4.1 tests