~ubuntu-branches/ubuntu/natty/mysql-5.1/natty

« back to all changes in this revision

Viewing changes to mysql-test/r/partition_range.result

Tags: 5.1.54-1ubuntu1
* Synchronize from Debian Experimental:
* Merge from debian unstable:
  + debian/control:
     * Update maintainer according to spec.
     * Move section from "misc" to "database".
     * Added libmysqlclient16-dev an empty transitional package. 
     * Added mysql-client-core-5.1 package.
     * Suggest mailx for mysql-server-5.1
     * Add mysql-testsuite package so you can run the testsuite seperately.
  + debian/additions/my.cnf:
    * Remove language options. Error message files are located in a different directory in Mysql
      5.0. Setting the language option to use /usr/share/mysql/english breaks Mysql 5.0. Both 5.0
      and 5.1 use a different value that works. (LP: #316974)
  + Add apparmor profile:
    + debian/apparmor-profile: apparmor-profile
    + debian/rules, debian/mysql-server-5.1.files: install apparmor profile
    + debian/mysql-server-5.1.dirs: add etc/apparmor.d/fore-complain
    + debian/mysql-server-5.1.postrm: remove symlink in force-complain/ on purge.
    + debian/mysql-server-5.1.README.Debian: add apparmor documentation.
    + debian/additions/my.cnf: Add warning about apparmor. (LP: #201799)
    + debian/mysql-server-5.1.postinst: reload apparmor profiles
  * Convert the package from sysvinit to upstart:
    + debian/mysql-server-5.1.mysql.upstart: Add upstart script.
    + debian/mysql-server-5.1.mysql.init: Dropped, unused now with upstart.
    + debian/additions/mysqld_safe_syslog.cnf: Dropped, unused now with upstart.
    + debian/additons/my.cnf: Remove pid declaration and setup error logging to /var/log/mysql since
      we're not piping anything around logger anymore.
    + debian/rules, debian/mysql-server-5.1.logcheck.ignore.{paranoid,worstation},
      debian/mysql-server-5.1.logcheck.ignore.server: : Remove references to mysqld_safe
    + debian/patches/38_scripts_mysqld_safe.sh_signals.dpatch: Dropped
  * Added -fno-strict-aliasing to CFLAGS to get around mysql testsuite build failures.
  * Add Apport hook (LP: #354188):
    + debian/mysql-server-5.1.py: apport package hook
    + debian/rules: Make it installable
  * debian/mysql-server-5.1.mysql-server.logrotate: Check to see if mysql is running before
    running logrotate. (LP: #513135)
  * Make the testsuite installable. (LP: #530752)
    + debian/mysql-server-5.1.files, debian/rules: install apport package hook
  * debian/mysql-server-5.1.preinst: Set mysql user's home directory
    to /nonexistent to protect against having the /var/lib/mysql
    user-writeable. If an attacker can trick mysqld into creating
    dot files in the home directory, he could do .rhost-like attacks
    on the system. (LP: #293258)
  * debian/control: mysql-client-5.1 should depend on mysql-core-client-5.1.
    (LP: #590952)
  * debian/mysql-server.5.1.postinst: Specify the mysql user when installing 
    the mysql databases. (LP: #591875)
  * Installing mysql_config_pic in /usr/bin so users of libmysqld-pic
    can extract the appropriate compile flags. (LP: #605021) 

Show diffs side-by-side

added added

removed removed

Lines of Context:
73
73
1       SIMPLE  t1      pnull   system  NULL    NULL    NULL    NULL    1       
74
74
explain partitions select * from t1 where a >= 0;
75
75
id      select_type     table   partitions      type    possible_keys   key     key_len ref     rows    Extra
76
 
1       SIMPLE  t1      p0,p1   ALL     NULL    NULL    NULL    NULL    3       Using where
 
76
1       SIMPLE  t1      p0,p1   ALL     NULL    NULL    NULL    NULL    2       Using where
77
77
explain partitions select * from t1 where a < 0;
78
78
id      select_type     table   partitions      type    possible_keys   key     key_len ref     rows    Extra
79
79
1       SIMPLE  NULL    NULL    NULL    NULL    NULL    NULL    NULL    NULL    Impossible WHERE noticed after reading const tables
80
80
explain partitions select * from t1 where a <= 0;
81
81
id      select_type     table   partitions      type    possible_keys   key     key_len ref     rows    Extra
82
 
1       SIMPLE  t1      pnull,p0        ALL     NULL    NULL    NULL    NULL    3       Using where
 
82
1       SIMPLE  t1      pnull,p0        ALL     NULL    NULL    NULL    NULL    2       Using where
83
83
explain partitions select * from t1 where a > 1;
84
84
id      select_type     table   partitions      type    possible_keys   key     key_len ref     rows    Extra
85
85
1       SIMPLE  NULL    NULL    NULL    NULL    NULL    NULL    NULL    NULL    Impossible WHERE noticed after reading const tables
112
112
a       b
113
113
explain partitions select * from t1 where a is null;
114
114
id      select_type     table   partitions      type    possible_keys   key     key_len ref     rows    Extra
115
 
1       SIMPLE  t1      pnull_pnullsp0,pnull_pnullsp1   ALL     NULL    NULL    NULL    NULL    6       Using where
 
115
1       SIMPLE  t1      pnull_pnullsp0,pnull_pnullsp1   ALL     NULL    NULL    NULL    NULL    2       Using where
116
116
explain partitions select * from t1 where a >= 0;
117
117
id      select_type     table   partitions      type    possible_keys   key     key_len ref     rows    Extra
118
 
1       SIMPLE  t1      p0_p0sp0,p0_p0sp1,p1_p1sp0,p1_p1sp1     ALL     NULL    NULL    NULL    NULL    6       Using where
 
118
1       SIMPLE  t1      p0_p0sp0,p0_p0sp1,p1_p1sp0,p1_p1sp1     ALL     NULL    NULL    NULL    NULL    4       Using where
119
119
explain partitions select * from t1 where a < 0;
120
120
id      select_type     table   partitions      type    possible_keys   key     key_len ref     rows    Extra
121
 
1       SIMPLE  t1      pnull_pnullsp0,pnull_pnullsp1   ALL     NULL    NULL    NULL    NULL    6       Using where
 
121
1       SIMPLE  t1      pnull_pnullsp0,pnull_pnullsp1   ALL     NULL    NULL    NULL    NULL    2       Using where
122
122
explain partitions select * from t1 where a <= 0;
123
123
id      select_type     table   partitions      type    possible_keys   key     key_len ref     rows    Extra
124
 
1       SIMPLE  t1      pnull_pnullsp0,pnull_pnullsp1,p0_p0sp0,p0_p0sp1 ALL     NULL    NULL    NULL    NULL    6       Using where
 
124
1       SIMPLE  t1      pnull_pnullsp0,pnull_pnullsp1,p0_p0sp0,p0_p0sp1 ALL     NULL    NULL    NULL    NULL    4       Using where
125
125
explain partitions select * from t1 where a > 1;
126
126
id      select_type     table   partitions      type    possible_keys   key     key_len ref     rows    Extra
127
127
1       SIMPLE  NULL    NULL    NULL    NULL    NULL    NULL    NULL    NULL    Impossible WHERE noticed after reading const tables
808
808
sum(count)
809
809
579
810
810
drop table t1, t2;
 
811
#
 
812
# Bug#50939: Loose Index Scan unduly relies on engine to remember range 
 
813
# endpoints
 
814
#
 
815
CREATE TABLE t1 (
 
816
a INT,
 
817
b INT,
 
818
KEY ( a, b )
 
819
) PARTITION BY HASH (a) PARTITIONS 1;
 
820
CREATE TABLE t2 (
 
821
a INT,
 
822
b INT,
 
823
KEY ( a, b )
 
824
);
 
825
INSERT INTO t1 VALUES (1, 1), (2, 2), (3, 3), (4, 4), (5, 5);
 
826
INSERT INTO t1 SELECT a +  5, b +  5 FROM t1;
 
827
INSERT INTO t1 SELECT a + 10, b + 10 FROM t1;
 
828
INSERT INTO t1 SELECT a + 20, b + 20 FROM t1;
 
829
INSERT INTO t1 SELECT a + 40, b + 40 FROM t1;
 
830
INSERT INTO t2 SELECT * FROM t1;
 
831
# plans should be identical
 
832
EXPLAIN SELECT a, MAX(b) FROM t1 WHERE a IN (10,100) GROUP BY a;
 
833
id      select_type     table   type    possible_keys   key     key_len ref     rows    Extra
 
834
1       SIMPLE  t1      range   a       a       5       NULL    1       Using where; Using index for group-by
 
835
EXPLAIN SELECT a, MAX(b) FROM t2 WHERE a IN (10,100) GROUP BY a;
 
836
id      select_type     table   type    possible_keys   key     key_len ref     rows    Extra
 
837
1       SIMPLE  t2      range   a       a       5       NULL    2       Using where; Using index for group-by
 
838
FLUSH status;
 
839
SELECT a, MAX(b) FROM t1 WHERE a IN (10, 100) GROUP BY a;
 
840
a       MAX(b)
 
841
10      10
 
842
# Should be no more than 4 reads.
 
843
SHOW status LIKE 'handler_read_key';
 
844
Variable_name   Value
 
845
Handler_read_key        4
 
846
FLUSH status;
 
847
SELECT a, MAX(b) FROM t2 WHERE a IN (10, 100) GROUP BY a;
 
848
a       MAX(b)
 
849
10      10
 
850
# Should be no more than 4 reads.
 
851
SHOW status LIKE 'handler_read_key';
 
852
Variable_name   Value
 
853
Handler_read_key        4
 
854
DROP TABLE t1, t2;