首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >是否可以将一个计算字段用于其他字段的计算列规范?

是否可以将一个计算字段用于其他字段的计算列规范?
EN

Stack Overflow用户
提问于 2015-01-19 14:25:07
回答 1查看 92关注 0票数 0

我有两个子表1.借款人列表,2.还款列表。

我在Return list表中有以下字段:

代码语言:javascript
运行
复制
1.RETURNLISTID-->PKEY
2.MEMBERSHIPID -->FKEY
3.BOOKREFID--FKEY
4.MEMBERFULLNAME-->CALCULATED FIELD(FOR THE CORRESPONDING MEMBERSHIPID GET    VALUE FROM MEMBERS TABLE)
5.BORROWDATE-->CALCULATED FIELD(FOR THE CORRESPONDING MEMBERSHIPID,BOOKREFID GET VALUE FROM BORROWERLIST TABLE)
6.ACTUALRETURNDATE--> CALCULATED FIELD(FOR THE CORRESPONDING MEMBERSHIPID,BOOKREFID GET VALUE FROM BORROWERLIST TABLE)
7.USERRETURNDATE-->USER WILL ENTER
8.FINEAMT-->IT SHOULD BE A CALCULATED FIELD.I HAVE CREATED A FUNCTION.

我已经创建了一个使用ACTUALRETURNDATE和USERRETURNDATE计算fineamt的函数。当我在字段中调用我的函数时,我得到了错误。

所以,我的疑问是,我是否可以使用一个计算字段来执行函数?

在下面找到我的函数。

代码语言:javascript
运行
复制
create function dbo.GETFINEAMT(@ACTUALRETURNDATE DATETIME ,@USERRETURNDATE    DATETIME)
RETURNS INT
AS
BEGIN
DECLARE @FINEAMT INT
DECLARE @DATEDIFF INT
SET @DATEDIFF=CONVERT(INT,(DATEDIFF(DD,'@ACTUALRETURNDATE','@USERRETURNDATE')))
SET @DATEDIFF = ABS(@DATEDIFF)
SET @FINEAMT=@DATEDIFF *10
RETURN @FINEAMT
END
GO
EN

回答 1

Stack Overflow用户

发布于 2015-01-19 15:32:24

如果所有的计算列值都来自于UDF,那么你一定是弄错了,somewhere.So会让你看到你的代码。

看看这个直接的抛出错误示例,

代码语言:javascript
运行
复制
Declare @t table(col int,col2 as col+1 PERSISTED,col3 as col2+1)
insert into @t values(1)
select * from @t
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28019001

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档