将mysql boolean返回为'yes'或'no'

时间:2013-06-05 21:52:30

标签: mysql

我的表中有一个BOOLEAN类型列。我想在返回结果时将0/1转换为是/否。

我在这个帖子上找到了回复:Echo boolean field as yes/no or other values

响应中提到了IF THEN语句,但是当我尝试时,我只收到来自MySQL的抱怨语法错误。这是我正在使用的行:

IF qz.quiz_enabled == 1 THEN 'yes' ELSE 'no' AS enabled

这是错误:

use near 'qz.quiz_enabled == 1 THEN 'yes' ELSE 'no' AS enabled

2 个答案:

答案 0 :(得分:24)

select case when qz.quiz_enabled 
            then 'yes' 
            else 'no' 
       end

select if(qz.quiz_enabled, 'yes', 'no')

SQLFiddle demo

答案 1 :(得分:0)

http://dev.mysql.com/doc/refman/5.0/en/if.html

BEGIN
DECLARE s VARCHAR(20);

IF n > m THEN SET s = '>';
ELSEIF n = m THEN SET s = '=';
ELSE SET s = '<';
END IF;

SET s = CONCAT(n, ' ', s, ' ', m);

RETURN s;
END