gpt4 book ai didi

tsql - 动态字段定义 - 这可以在 T-SQL 中完成吗?

转载 作者:行者123 更新时间:2023-12-04 06:27:50 28 4
gpt4 key购买 nike

我有一个我正在努力实现的要求。如果可能,我想用 native T-SQL 来实现这一点。

我有以下表格:

CUSTOMER
========
ID,
Name

FIELDDEF
========
ID,
Name
FieldType (Char T, N, D for Text, Number or Date)

CUSTOMERFIELD
=============
ID,
CustomerID,
FieldDefID,
CaptureDate,
ValueText,
ValueNumber,
ValueDate

基本上,这些表的目的是提供一个可扩展的自定义字段系统。这个想法是用户创建新的字段定义,可以是文本、数字或日期字段。然后,他们在 ValueText、ValueNumber OR ValueDate 字段中为这些字段创建值。

例子:
*Customer*
1,BOB
2,JIM

*FieldDef*
1,Mobile,T
1,DateOfBirth,D

*CustomerField*
ID,CustomerID,FieldDefID,CaptureDate,ValueText,ValueNumber,ValueDate
1,1,1,2011-01-1,07123456789,NULL,NULL
2,1,2,2011-01-1,NULL,NULL,09-DEC-1980
3,1,1,2011-01-2,07123498787,NULL,NULL

我需要创建一个如下所示的 View :
*CustomerView*
ID,Name,Mobile,DateOfBirth
1,BOB,07123498787,09-DEC-1980

请注意,Bob 的手机是列表中的第二个,因为它使用了最近的拍摄日期。

理想情况下,我需要它是可扩展的,所以如果我将来创建一个新字段 def,它会自动在 CustomerView 中选取。

这在 T-SQL 中可能吗?

谢谢,

西蒙。

最佳答案

这对于 View 是不可能的,除非每次都动态重新创建 View FieldDef更改是因为 View 模式在创建时被锁定。但是,使用存储过程可能是可能的,这取决于您使用它的方式,这可能会或可能不会起作用。

编辑 1

这是一个仅适用于您当前的字段名称的示例查询,并且必须通过动态 SQL 进行修改才能正常工作:

编辑 2

修改为从客户字段表中获取最新值

with CustomerFieldNewest as (
select
cf1.*
from
customerfield cf1
inner join
(
select
customerid,
fielddefid,
max(capturedate) as maxcapturedate
from
customerfield cf2
group by
customerid,
fielddefid
) cf2 on cf1.customerid = cf2.customerid
and cf1.fielddefid = cf2.fielddefid
and cf1.capturedate = cf2.maxcapturedate
)
,CustomerFieldPivot as (
select
C.ID as ID
,max(case when F.Name = 'Mobile' then CF.ValueText end) as Mobile
,max(case when F.Name = 'DateOfBirth' then CF.ValueDate end) as DateOfBirth
from
Customer C
left join
CustomerFieldNewest CF on C.ID = CF.CustomerID
left join
FieldDef F on F.ID = CF.FieldDefID
group by
C.ID
)
select
C.*
,P.Mobile
,P.DateOfBirth
from
Customer C
left join
CustomerFieldPivot P on C.ID = P.ID

编辑 3

这是基于 FieldDef 中的当前字段集动态生成 View 的 T-SQL 代码(假设 View CustomerView 已经存在,因此您需要首先将其创建为空白定义,否则您将获得一个错误)。我不确定所有这些的性能,但它应该可以正常工作。
declare @sql varchar(max)
declare @fielddef varchar(max)
declare @fieldlist varchar(max)

select
@fielddef = coalesce(@fielddef + ', ' + CHAR(13) + CHAR(10), '') +
' max(case when F.Name = ''' + F.Name + ''' then CF.' +
case F.FieldType
when 'T' then 'ValueText'
when 'N' then 'ValueNumber'
when 'D' then 'ValueDate'
end
+ ' end) as [' + F.Name + ']'

,@fieldlist = coalesce(@fieldlist + ', ' + CHAR(13) + CHAR(10), '') +
' [' + F.Name + ']'
from
FieldDef F

set @sql = '
alter view [CustomerView] as

with CustomerFieldNewest as (
select
cf1.*
from
customerfield cf1
inner join
(
select
customerid,
fielddefid,
max(capturedate) as maxcapturedate
from
customerfield cf2
group by
customerid,
fielddefid
) cf2 on cf1.customerid = cf2.customerid
and cf1.fielddefid = cf2.fielddefid
and cf1.capturedate = cf2.maxcapturedate
)
,CustomerFieldPivot as (
select
C.ID as ID,
' + @fielddef + '
from
Customer C
left join
CustomerFieldNewest CF on C.ID = CF.CustomerID
left join
FieldDef F on F.ID = CF.FieldDefID
group by
C.ID
)
select
C.*,
' + @fieldlist + '
from
Customer C
left join
CustomerFieldPivot P on C.ID = P.ID
'

print @sql
exec(@sql)

select * from CustomerView

关于tsql - 动态字段定义 - 这可以在 T-SQL 中完成吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5819338/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com