Tsql 我应该为常见的大型SQL联接生成表值函数吗
仅使用SQL几个月(这个地方到目前为止帮了我很大的忙,谢谢大家!) 但是,尽管我是一个DB程序员初学者,我已经注意到有许多大型连接,我发现自己在一遍又一遍地重复。我正在考虑为常用联接创建一个表值函数,并允许将一个参数传递到该函数中,该函数将过滤结果 例如。 而不是写作Tsql 我应该为常见的大型SQL联接生成表值函数吗,tsql,join,sql-function,query-parameters,Tsql,Join,Sql Function,Query Parameters,仅使用SQL几个月(这个地方到目前为止帮了我很大的忙,谢谢大家!) 但是,尽管我是一个DB程序员初学者,我已经注意到有许多大型连接,我发现自己在一遍又一遍地重复。我正在考虑为常用联接创建一个表值函数,并允许将一个参数传递到该函数中,该函数将过滤结果 例如。 而不是写作 SELECT * FROM T1 join T2 on T1.A = T2.A join T3 on T2.B = T3.B join T4 on T3.C = T4.D WHERE T1.D
SELECT *
FROM T1 join T2 on T1.A = T2.A
join T3 on T2.B = T3.B
join T4 on T3.C = T4.D
WHERE T1.D = '15' AND T2.D = '20' AND T3.C = '12'
我会写
SELECT *
FROM dbo.SOME_FUNCTION(' T1.D = '15' AND T2.D = '20' AND T3.C = '12' ')
我的问题很简单。这是我应该尝试做的事情吗?还是我想这么做太懒了
我整天都在尝试研究/编写这个函数,但在这方面遇到了很多问题。我知道最终我能/会成功,只是想知道这是否值得我花时间
PS:对不起,如果这个问题很愚蠢的话,这不是我想在这个网站上问的第一个问题,但问题来了。我想也许你的想法是正确的,但方法不是很理想。这可能有两种体面的方式。第一种方法是创建一个视图:
CREATE VIEW dbo.SOME_VIEW AS
(
SELECT
-- [list out the columns here], do not use *
FROM
T1
JOIN
T2 on T1.A = T2.A
JOIN
T3 on T2.B = T3.B
JOIN
T4 on T3.C = T4.D
)
因此,您的查询是:
SELECT * FROM SOME_VIEW
WHERE ...
函数方法可以工作,但我会将函数更改为接受三个参数,而不是您在示例中展示的单字符串方法,因此您可以这样做:
SELECT * FROM dbo.SOME_FUNCTION('15', '20', '12')
同样,根据您访问数据的方式,存储过程可能更合适:
EXEC dbo.spSomeStoredProcedure @T1D = '15', @T2D = '20', @T3C = '12'
编辑:表值函数和存储过程都应使用上述视图。表值函数是避免重复SELECT语句的好方法,但它不是唯一的方法。我会把语句放在一个视图中,因为它可以被索引。您仍然可以使用表值函数,该函数使用参数从视图中选择记录 假设您的视图中有以下两种类型的检索: 1,
选择。。。其中Column1=@p1
2、选择。。。其中Column2=@p2和Column3=@p3
在这种情况下,应该将匹配的两个索引添加到视图中
- 专栏1
- 第2列+第3列