mysql中union可以怎样优化_mysql union,union all的优化

1 建表如下

CREATE TABLE t92 (

a1 int(10) unsigned NOT NULL ,

b1 int(10) DEFAULT NULL,

UNIQUE KEY (a1)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

CREATE TABLE t93 (

a2 int(10) unsigned NOT NULL,

b2 int(10) DEFAULT NULL,

UNIQUE KEY (a2)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

INSERT INTO t92 (a1, b1) VALUES (1, 11);

INSERT INTO t92 (a1, b1) VALUES (2, 12);

INSERT INTO t92 (a1, b1) VALUES (3, 13);

INSERT INTO t92 (a1, b1) VALUES (4, 14);

INSERT INTO t92 (a1, b1) VALUES (5, 15);

INSERT INTO t92 (a1, b1) VALUES (6, 16);

INSERT INTO t92 (a1, b1) VALUES (7, 17);

INSERT INTO t92 (a1, b1) VALUES (8, 18);

INSERT INTO t92 (a1, b1) VALUES (9, 19);

INSERT INTO t92 (a1, b1) VALUES (10, 20);

INSERT INTO t93 (a2, b2) VALUES (1, 21);

INSERT INTO t93 (a2, b2) VALUES (2, 22);

INSERT INTO t93 (a2, b2) VALUES (3, 23);

INSERT INTO t93 (a2, b2) VALUES (4, 24);

INSERT INTO t93 (a2, b2) VALUES (5, 25);

INSERT INTO t93 (a2, b2) VALUES (6, 26);

INSERT INTO t93 (a2, b2) VALUES (7, 27);

INSERT INTO t93 (a2, b2) VALUES (8, 28);

INSERT INTO t93 (a2, b2) VALUES (9, 29);

INSERT INTO t93 (a2, b2) VALUES (10, 30);

2 查询执行计划如下

mysql> EXPLAIN EXTENDED (SELECT a1 FROM t92 WHERE a1>=1 ORDER BY a1) UNION ALL (SELECT a2 FROM t93 WHERE a2>=1 ORDER BY a2);

+——+————–+————+——-+—————+——+———+——+——+———-+————————–+

| id | select_type | table | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+——+————–+————+——-+—————+——+———+——+——+———-+————————–+

| 1 | PRIMARY | t92 | index | a1 | a1 | 4 | NULL | 10 | 100 | Using where; Using index |

| 2 | UNION | t93 | index | a2 | a2 | 4 | NULL | 10 | 100 | Using where; Using index |

| NULL | UNION RESULT |

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值