网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

MySQLSQL实现上下行相加减

测试用表:
  1. CREATE TABLE `test` (
  2.   `id` int(11) NOT NULL auto_increment,
  3.   `value` int(11) default NULL,
  4.   PRIMARY KEY  (`id`)
  5. ) ENGINE=InnoDB DEFAULT CHARSET=utf8


随意加入测试数据:
  1. MySQL> SELECT * FROM test;
  2. +------+-------+
  3. | id   | value |
  4. +------+-------+
  5. |    1 |     2 | 
  6. |    2 |     5 | 
  7. |    3 |     6 | 
  8. |    4 |    10 | 
  9. +------+-------+


目的:
row2-row1
row3-row2
row4-row3 以此类推,输出。

先做个自连接,连接条件为id1=id2+1,让id1正好为id2的下一个自增。
  1. mysql> SELECT a.id id1, b.id id2, a.value value1, b.value value22
  2.     -> FROM test a JOIN test b ON a.id = b.id + 1;
  3. +------+------+--------+---------+
  4. | id1  | id2  | value1 | value2  |
  5. +------+------+--------+---------+
  6. |    2 |    1 |      5 |       2 | 
  7. |    3 |    2 |      6 |       5 | 
  8. |    4 |    3 |     10 |       6 | 
  9. +------+------+--------+---------+
  10. 3 rows in set (0.00 sec)


因为id1为id2的下一个自增,故value1-value2相减为最后的结果。


将上述的自连接结果集写作临时表,让value1与value2相减得到最后的结果:
  1. mysql> SELECT value1 - value2 RESULT
  2.     -> FROM (
  3.     -> SELECT a.value value1, b.value value2
  4.     -> FROM test a JOIN test b ON a.id = b.id + 1
  5.     -> ) t;
  6. +--------+
  7. | RESULT |
  8. +--------+
  9. |      3 | 
  10. |      1 | 
  11. |      4 | 
  12. +--------+
  13. 3 rows in set (0.00 sec)

3、1、4即为 5-2、6-4、10-6。
同理可得上下行相加。


作者微信公众号(持续更新)
MySQL SQL实现上下行相加减


分享标题:MySQLSQL实现上下行相加减
URL网址:http://bjjierui.cn/article/gsgehi.html

其他资讯