[MDEV-8167] XOR returns bad results for an indexed column Created: 2015-05-15  Updated: 2015-06-09  Resolved: 2015-06-09

Status: Closed
Project: MariaDB Server
Component/s: Optimizer
Affects Version/s: 5.5, 10.0, 10.1
Fix Version/s: 10.1.6

Type: Bug Priority: Major
Reporter: Alexander Barkov Assignee: Alexander Barkov
Resolution: Fixed Votes: 0
Labels: None


 Description   

This script:

DROP TABLE IF EXISTS t1;
CREATE TABLE t1 (
  id INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
   k INTEGER UNSIGNED DEFAULT '0' NOT NULL,
   c CHAR(120) DEFAULT '' NOT NULL,
   pad CHAR(60) DEFAULT '' NOT NULL,
   PRIMARY KEY (id)
) ENGINE=MyISAM;
INSERT INTO t1 (k, c, pad) VALUES (10, 'a', 'xxx');
INSERT INTO t1 (k, c, pad) VALUES (11, 'a', 'xxx');
INSERT INTO t1 (k, c, pad) VALUES (12, 'a', 'xxx');
INSERT INTO t1 (k, c, pad) VALUES (13, 'a', 'xxx');
INSERT INTO t1 (k, c, pad) VALUES (14, 'a', 'xxx');
INSERT INTO t1 (k, c, pad) VALUES (15, 'a', 'xxx');
INSERT INTO t1 (k, c, pad) VALUES (16, 'a', 'xxx');
SELECT * FROM t1 WHERE id XOR 0;

erroneously returns empty set.

If I add IGNORE KEY:

SELECT * FROM t1 IGNORE KEY(PRIMARY) WHERE id XOR 0;

it correctly returns rows:

+----+----+---+-----+
| id | k  | c | pad |
+----+----+---+-----+
|  1 | 10 | a | xxx |
|  2 | 11 | a | xxx |
|  3 | 12 | a | xxx |
|  4 | 13 | a | xxx |
|  5 | 14 | a | xxx |
|  6 | 15 | a | xxx |
|  7 | 16 | a | xxx |
+----+----+---+-----+
7 rows in set (0.00 sec)


Generated at Thu Feb 08 07:25:08 UTC 2024 using Jira 8.20.16#820016-sha1:9d11dbea5f4be3d4cc21f03a88dd11d8c8687422.