怎么样解决重复问题?

damoyang 2010-08-26 10:02:46
USE [helkadata]
GO
/****** Object: UserDefinedFunction [dbo].[fn_GetJobContainerCntNo] Script Date: 08/26/2010 09:10:31 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

ALTER FUNCTION [dbo].[fn_GetJobContainerCntNo]
(@JobNo varchar(20))
RETURNS varchar(250)
AS
BEGIN
DECLARE @STEMP VARCHAR(250)
SELECT @STEMP=''
SELECT @STEMP=@STEMP+ ISNULL(CNTNo,'')+',' FROM BIZ.JOBCONTAINER WHERE parentJOBNO=@JobNo
RETURN @STEMP
END

怎样可以让CNTNO不在重复?995
...全文
147 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
百年树人 2010-08-26
  • 打赏
  • 举报
回复
ALTER FUNCTION [dbo].[fn_GetJobContainerCntNo]
(@JobNo varchar(20))
RETURNS varchar(250)
AS
BEGIN
DECLARE @STEMP VARCHAR(250)
SELECT @STEMP=ISNULL(@STEMP+',','')+ISNULL(CNTNo,'')
from
(SELECT DISTINCT CNTNO FROM BIZ.JOBCONTAINER WHERE parentJOBNO=@JobNo)T
RETURN @STEMP
END

不过如果字段中间有NULL值的话,这个多余的逗号也不好处理
damoyang 2010-08-26
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 w_mojian180 的回复:]
引用 5 楼 damoyang 的回复:
如果只有一个CntNo就不要显示逗号了。应该怎么样了?

t 可以理解为表名
要去掉逗号可以这个样

SQL code

ALTER FUNCTION [dbo].[fn_GetJobContainerCntNo]
(@JobNo varchar(20))
RETURNS varchar(250)
AS
BEGIN
DECLAR……
[/Quote]

我的意思是逗号还是要的。。当CntNo只有一个时不显示。多个时,最后一个Cntno后面不显示
路伊阑珊 2010-08-26
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 damoyang 的回复:]
如果只有一个CntNo就不要显示逗号了。应该怎么样了?
[/Quote]
t 可以理解为表名
要去掉逗号可以这个样

ALTER FUNCTION [dbo].[fn_GetJobContainerCntNo]
(@JobNo varchar(20))
RETURNS varchar(250)
AS
BEGIN
DECLARE @STEMP VARCHAR(250)
SELECT @STEMP=''
SELECT @STEMP=@STEMP+ ISNULL(CNTNo,'')
from
(SELECT DISTINCT CNTNO FROM BIZ.JOBCONTAINER WHERE parentJOBNO=@JobNo)T
RETURN @STEMP
END
damoyang 2010-08-26
  • 打赏
  • 举报
回复
如果只有一个CntNo就不要显示逗号了。应该怎么样了?
damoyang 2010-08-26
  • 打赏
  • 举报
回复
还有就是最后一个CntNO还会带上一个逗号。怎么去掉它。。谢谢
damoyang 2010-08-26
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 josy 的回复:]
SQL code
ALTER FUNCTION [dbo].[fn_GetJobContainerCntNo]
(@JobNo varchar(20))
RETURNS varchar(250)
AS
BEGIN
DECLARE @STEMP VARCHAR(250)
SELECT @STEMP=''
SELECT @STEMP=@STEMP+ ISNULL(CNTNo,'')+'……
[/Quote]

(SELECT DISTINCT CNTNO FROM BIZ.JOBCONTAINER WHERE parentJOBNO=@JobNo)T

这个T 是什么意思???
jaydom 2010-08-26
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 josy 的回复:]
SQL code
ALTER FUNCTION [dbo].[fn_GetJobContainerCntNo]
(@JobNo varchar(20))
RETURNS varchar(250)
AS
BEGIN
DECLARE @STEMP VARCHAR(250)
SELECT @STEMP=''
SELECT @STEMP=@STEMP+ ISNULL(CNTNo,'')+'……
[/Quote]
up
百年树人 2010-08-26
  • 打赏
  • 举报
回复
ALTER FUNCTION [dbo].[fn_GetJobContainerCntNo]
(@JobNo varchar(20))
RETURNS varchar(250)
AS
BEGIN
DECLARE @STEMP VARCHAR(250)
SELECT @STEMP=''
SELECT @STEMP=@STEMP+ ISNULL(CNTNo,'')+','
from
(SELECT DISTINCT CNTNO FROM BIZ.JOBCONTAINER WHERE parentJOBNO=@JobNo)T
RETURN @STEMP
END
damoyang 2010-08-26
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 josy 的回复:]
SQL code
ALTER FUNCTION [dbo].[fn_GetJobContainerCntNo]
(@JobNo varchar(20))
RETURNS varchar(250)
AS
BEGIN
DECLARE @STEMP VARCHAR(250)
SELECT @STEMP=ISNULL(@STEMP+',','')+ISNULL(CNTNo,'')
from……
[/Quote]

已经相当感谢了。。。

34,575

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧