注册 登录
编程论坛 SQL Server论坛

访问SQL Server 数据库 SQL语句 如何使用 IF 条件

MXG825 发布于 2010-11-21 16:16, 4664 次点击
Sql = "select 日期,摘要,iif(借贷标志,金额,金额*-1) from vouch where 日期 between '2010-10-26' and '2010-11-20'"

在一张表中vouch表中几列字段,一列字段是金额,一列是借贷标志(值为true或false),我现在是重新在此表上直接把金额那列按正负数取出来

金额那列全是正数,没有负数的。如果借贷标志那列是True的话,就为金额那列的数。如果借贷标志是false的话就为金额*-1

这语句在VB 访问ACC 数据库可以用

如何改成 访问SQL Server 数据库
5 回复
#2
hbsstt2010-11-21 16:30
回复 楼主 MXG825
在excel的vba 中用ado访问工作表中的表,用iif()也是直接可以转换的.在sqlserver中好象确实不行,不知道为啥?
#3
aei1352010-11-22 15:27
借贷标志数据类型是bit的吧?SQL用CASE WHEN 就行
select 日期,摘要,CASE WHEN 借贷标志=1 THEN 金额 ELSE 金额*(-1) END 金额 from vouch where 日期 between '2010-10-26' and '2010-11-20'

#4
cnfarer2010-11-22 19:35
SQL Server中根本就不存在这个IIF()可以使用CASE函数
#5
hbsstt2010-11-23 13:34
回复 4楼 cnfarer
提示when附近有语法错误。我的这个是excel 的vba环境卫,有人说好象excel的vba不支持case啊啥的。咋办呢?
#6
hbsstt2010-11-23 13:41
以下是引用aei135在2010-11-22 15:27:48的发言:

借贷标志数据类型是bit的吧?SQL用CASE WHEN 就行
select 日期,摘要,CASE WHEN 借贷标志=1 THEN 金额 ELSE 金额*(-1) END 金额 from vouch where 日期 between '2010-10-26' and '2010-11-
可以了,谢谢了啊!
1