在决策表SQL中实现规则的补充

时间:2013-07-13 18:03:33

标签: mysql sql

我有一个查询,可以使用决策表根据多个条件做出决策。

假设在这里我需要知道一个结果(是或否),具体取决于一个人拥有的属性,如表所示。

DROP    TABLE IF EXISTS `tbl_decision`; 
CREATE TABLE `tbl_decision` (
  id_rule       INT NOT NULL primary key AUTO_INCREMENT,
  rule_name     VARCHAR(25) NOT NULL,
  minVal        INT NOT NULL,
  maxVal        INT NOT NULL,    
  decision      CHAR(1) NOT NULL,
  CONSTRAINT `uc_decision` UNIQUE (`id_rule`)           
) ENGINE=InnoDB  DEFAULT CHARSET=utf8 AUTO_INCREMENT=1;

Insert into `tbl_decision` VALUES
(1, 'WEIGHT'      , 60  ,100 ,'Y'),
(2, 'HEIGHT'      , 0   ,170 ,'Y'),
(3, 'Special rate', 10  ,30  ,'Y'),
(4, 'Consumption' , 0   ,3300,'N');

以下是我要比较的表格:

DROP    TABLE IF EXISTS `tbl_guy`; 
CREATE TABLE `tbl_guy` (
  id_guy    INT NOT NULL primary key AUTO_INCREMENT,
  guy_name     VARCHAR(25)  NOT NULL,
  weight        INT NOT NULL,
  height        INT NOT NULL,    
  rate          INT NOT NULL,    
  consumption   INT NOT NULL,    
  CONSTRAINT `uc_guy` UNIQUE (`id_guy`)           
) ENGINE=InnoDB  DEFAULT CHARSET=utf8 AUTO_INCREMENT=1;


Insert into `tbl_guy` VALUES
(1, 'John'      , 200,220,10,1000),
(2, 'Mary'      , 100,160,11,5100),
(3, 'Diana'     , 80 ,155,19,4000),
(4, 'Ruthanne'  , 82 ,165, 5,2000);

决定由以下查询确定。

SELECT *  FROM 
(
 SELECT id_guy,decision,
CASE WHEN rule_name = 'WEIGHT'       THEN tbl_guy.weight
     WHEN rule_name = 'HEIGHT'       THEN tbl_guy.height
     WHEN rule_name = 'Special rate' THEN tbl_guy.rate
     WHEN rule_name = 'Consumption'  THEN tbl_guy.consumption
END AS testQnty, rule_name, minVal, maxVal
FROM tbl_guy CROSS JOIN tbl_decision
) t 
WHERE minVal <= testQnty AND testQnty < maxVal 
ORDER BY id_guy;

我使用最小值和最大值来判断决策是否为是,但我不知道如何定义相反的规则。例如,我定义:

(3,'特价',10,30,'Y')

如果场频率的值在10到30之间则为是

但是如果它在0到3300之间的场消耗决定是否

(4,'消费',0,3300,'N');

我知道你总是可以使用补语制定相反的规则 如果0 <= x <= 3300成为x < 0 AND x > 3300 但是如何在查询中启用它?

Here is my fiddle

other

1 个答案:

答案 0 :(得分:2)

您的变量decision似乎体现了两个概念。一个是规则的方向(是“之间”还是“不介于”之间),另一个是规则是否通过。为了澄清事情,以下内容保留所有规则以及新变量以确定规则是否通过:

SELECT t.*,
       (case when decision = 'Y' and minVal <= testQnty AND testQnty < maxVal
             then 'Passed'
             when decision = 'N' and not (minVal <= testQnty AND testQnty < maxVal)
             then 'Passed'
             else 'Not Passed'
        end) as RuleResult
FROM (SELECT id_guy, decision,
             (CASE WHEN rule_name = 'WEIGHT'       THEN tbl_guy.weight
                   WHEN rule_name = 'HEIGHT'       THEN tbl_guy.height
                   WHEN rule_name = 'Special rate' THEN tbl_guy.rate
                   WHEN rule_name = 'Consumption'  THEN tbl_guy.consumption
              END) AS testQnty, rule_name, minVal, maxVal
      FROM tbl_guy CROSS JOIN tbl_decision
     ) t 
ORDER BY id_guy;

如果您只想要通过的规则:

SELECT t.*
FROM (SELECT id_guy, decision,
             (CASE WHEN rule_name = 'WEIGHT'       THEN tbl_guy.weight
                   WHEN rule_name = 'HEIGHT'       THEN tbl_guy.height
                   WHEN rule_name = 'Special rate' THEN tbl_guy.rate
                   WHEN rule_name = 'Consumption'  THEN tbl_guy.consumption
              END) AS testQnty, rule_name, minVal, maxVal
      FROM tbl_guy CROSS JOIN tbl_decision
     ) t
where (decision = 'Y' and minVal <= testQnty AND testQnty < maxVal) or
      (decision = 'N' and not (minVal <= testQnty AND testQnty < maxVal))
ORDER BY id_guy;