data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
have a custom year begin and end year table that the DDL section will
create. Thus, I use the t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
1 of any year starting with the date in the w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
last w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
Is there a way I could return the same results created by my CODE section in
Northwind except use custom w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
need a fix to properly sort the w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
field.
CODE:
SELECT CAST(DATEPART(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
CAST(DATEPART(yyyy, OrderDate) AS char(4)) AS w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
sumFreight
FROM Orders
GROUP BY CAST(DATEPART(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
CAST(DATEPART(yyyy, OrderDate) AS char(4))
ORDER BY CAST(DATEPART(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
CAST(DATEPART(yyyy, OrderDate) AS char(4))
DDL ****************************************
*****
USE [Northwind]
GO
CREATE TABLE [t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
[w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
[w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
[w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
[w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
) ON [PRIMARY]
GO
insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
('19951226', '19961230', '1996')
insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
('19961231', '19971229', '1997')
insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
('19971230', '19981228', '1998')
insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
('19981229', '19981227', '1999')
insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
('19991228', '20001225', '2000')A sub-query, like
SELECT CAST(DATEDIFF(dd, (SELECT w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
would get you the custom w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
sub-queries in a GROUP BY clause. The solution here is to create a function.
The function below formats OrderDate into yyyy-ww
CREATE FUNCTION udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
RETURNS varchar(7)
AS
BEGIN
DECLARE @.output varchar(7)
SELECT @.output = CAST(DATEPART(yyyy, @.date) AS char(4)) + '-'
+ RIGHT('0' + CAST(DATEDIFF(dd, (SELECT w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
WHERE w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
RETURN @.output
END
You can then use the function to both group and order by
SELECT dbo.udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
FROM Orders
GROUP BY dbo.udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
ORDER BY dbo.udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
"Scott" wrote:
> In CODE section below, I'm grouping the Sum of Freight by the w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
e
> have a custom year begin and end year table that the DDL section will
> create. Thus, I use the t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
ek
> 1 of any year starting with the date in the w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
he
> last w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> Is there a way I could return the same results created by my CODE section
in
> Northwind except use custom w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
so
> need a fix to properly sort the w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
r
> field.
>
> CODE:
> SELECT CAST(DATEPART(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> CAST(DATEPART(yyyy, OrderDate) AS char(4)) AS w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> sumFreight
> FROM Orders
> GROUP BY CAST(DATEPART(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> CAST(DATEPART(yyyy, OrderDate) AS char(4))
> ORDER BY CAST(DATEPART(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> CAST(DATEPART(yyyy, OrderDate) AS char(4))
>
> DDL ****************************************
*****
> USE [Northwind]
> GO
> CREATE TABLE [t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> ) ON [PRIMARY]
> GO
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
s
> ('19951226', '19961230', '1996')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
s
> ('19961231', '19971229', '1997')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
s
> ('19971230', '19981228', '1998')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
s
> ('19981229', '19981227', '1999')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
s
> ('19991228', '20001225', '2000')
>
>
>|||You almost have it. Please run my DDL below (I simulated my production db).
The only thing wrong is for example at the end of 2004, your w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
should be w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
2005. otherwise, the w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
I think this is happening because you aren't taking the year ending dates
into consideration.
DDL *********************************
CREATE TABLE [dbo].[test_prod](
[prod_id] [int] IDENTITY(1,1) NOT NULL,
[prod_date] [datetime] NULL,
[log_count] [int] NULL
) ON [PRIMARY]
CREATE TABLE [t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
[w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
[w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
[w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
[w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
) ON [PRIMARY]
GO
insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
('19951226', '19961230', '1996')
insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
('19961231', '19971229', '1997')
insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
('19971230', '19981228', '1998')
insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
('19981229', '19981227', '1999')
insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
('19991228', '20001225', '2000')
CREATE FUNCTION udfW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
RETURNS varchar(7)
AS
BEGIN
DECLARE @.output varchar(7)
SELECT @.output = CAST(DATEPART(yyyy, @.date) AS char(4)) + '-'
+ RIGHT('0' + CAST(DATEDIFF(dd, (SELECT w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
WHERE w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
RETURN @.output
END
insert into test_prod (prod_date, log_count) values
('20041220', '6456')
insert into test_prod (prod_date, log_count) values
('20041221', '5830')
insert into test_prod (prod_date, log_count) values
('20041222', '3480')
insert into test_prod (prod_date, log_count) values
('20041227', '6542')
insert into test_prod (prod_date, log_count) values
('20041228', '6669')
insert into test_prod (prod_date, log_count) values
('20041229', '6524')
insert into test_prod (prod_date, log_count) values
('20041230', '6541')
insert into test_prod (prod_date, log_count) values
('20050104', '6370')
insert into test_prod (prod_date, log_count) values
('20050105', '6926')
insert into test_prod (prod_date, log_count) values
('20050106', '5002')
insert into test_prod (prod_date, log_count) values
('20050107', '6736')
insert into test_prod (prod_date, log_count) values
('20050108', '5822')
-- execute to see results
SELECT dbo.udfW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
FROM dbo.test_prod
GROUP BY dbo.udfW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
ORDER BY dbo.udfW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
"Mark Williams" <MarkWilliams@.discussions.microsoft.com> wrote in message
news:EBE692C6-1006-4E89-8ED9-985ED5F58F7B@.microsoft.com...
>A sub-query, like
> SELECT CAST(DATEDIFF(dd, (SELECT w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> would get you the custom w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> sub-queries in a GROUP BY clause. The solution here is to create a
> function.
> The function below formats OrderDate into yyyy-ww
> CREATE FUNCTION udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> RETURNS varchar(7)
> AS
> BEGIN
> DECLARE @.output varchar(7)
> SELECT @.output = CAST(DATEPART(yyyy, @.date) AS char(4)) + '-'
> + RIGHT('0' + CAST(DATEDIFF(dd, (SELECT w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> WHERE w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> RETURN @.output
> END
> You can then use the function to both group and order by
> SELECT dbo.udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> FROM Orders
> GROUP BY dbo.udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> ORDER BY dbo.udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> "Scott" wrote:
>|||Yep, I realized my mistake about 15 minutes after my post, but couldn't get
back to it until after a few hours. This should do it:
DROP FUNCTION udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
GO
CREATE FUNCTION udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
RETURNS varchar(7)
AS
BEGIN
DECLARE @.output varchar(7)
SELECT @.output = CAST(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
+ RIGHT('0' + CAST(DATEDIFF(dd, w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
varchar(3)), 2)
FROM t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
RETURN @.output
END
SELECT dbo.udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
FROM Orders
GROUP BY dbo.udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
ORDER BY dbo.udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
The function should now pick up the dates in late December correctly. For
example,
select dbo.udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
Your example t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
a table that has dates in 2005; is the table cyclic?
"Scott" wrote:
> You almost have it. Please run my DDL below (I simulated my production db)
.
> The only thing wrong is for example at the end of 2004, your w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> should be w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> 2005. otherwise, the w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> I think this is happening because you aren't taking the year ending dates
> into consideration.
> DDL *********************************
> CREATE TABLE [dbo].[test_prod](
> [prod_id] [int] IDENTITY(1,1) NOT NULL,
> [prod_date] [datetime] NULL,
> [log_count] [int] NULL
> ) ON [PRIMARY]
>
> CREATE TABLE [t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> ) ON [PRIMARY]
> GO
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
s
> ('19951226', '19961230', '1996')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
s
> ('19961231', '19971229', '1997')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
s
> ('19971230', '19981228', '1998')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
s
> ('19981229', '19981227', '1999')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
s
> ('19991228', '20001225', '2000')
> CREATE FUNCTION udfW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> RETURNS varchar(7)
> AS
> BEGIN
> DECLARE @.output varchar(7)
> SELECT @.output = CAST(DATEPART(yyyy, @.date) AS char(4)) + '-'
> + RIGHT('0' + CAST(DATEDIFF(dd, (SELECT w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> WHERE w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> RETURN @.output
> END
> insert into test_prod (prod_date, log_count) values
> ('20041220', '6456')
> insert into test_prod (prod_date, log_count) values
> ('20041221', '5830')
> insert into test_prod (prod_date, log_count) values
> ('20041222', '3480')
> insert into test_prod (prod_date, log_count) values
> ('20041227', '6542')
> insert into test_prod (prod_date, log_count) values
> ('20041228', '6669')
> insert into test_prod (prod_date, log_count) values
> ('20041229', '6524')
> insert into test_prod (prod_date, log_count) values
> ('20041230', '6541')
> insert into test_prod (prod_date, log_count) values
> ('20050104', '6370')
> insert into test_prod (prod_date, log_count) values
> ('20050105', '6926')
> insert into test_prod (prod_date, log_count) values
> ('20050106', '5002')
> insert into test_prod (prod_date, log_count) values
> ('20050107', '6736')
> insert into test_prod (prod_date, log_count) values
> ('20050108', '5822')
>
> -- execute to see results
> SELECT dbo.udfW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> FROM dbo.test_prod
> GROUP BY dbo.udfW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> ORDER BY dbo.udfW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
>
> "Mark Williams" <MarkWilliams@.discussions.microsoft.com> wrote in message
> news:EBE692C6-1006-4E89-8ED9-985ED5F58F7B@.microsoft.com...
>
>|||First, thanks big for solving this head-hurter. My t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
the last 5 years plus always 1 year in advance. I had the old years so it'd
work in northwind.
what did you mean by the table being "cyclic"?
"Mark Williams" <MarkWilliams@.discussions.microsoft.com> wrote in message
news:602D1125-A792-40A5-B505-7B31B7524A94@.microsoft.com...
> Yep, I realized my mistake about 15 minutes after my post, but couldn't
> get
> back to it until after a few hours. This should do it:
> DROP FUNCTION udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> GO
> CREATE FUNCTION udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> RETURNS varchar(7)
> AS
> BEGIN
> DECLARE @.output varchar(7)
> SELECT @.output = CAST(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> + RIGHT('0' + CAST(DATEDIFF(dd, w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> varchar(3)), 2)
> FROM t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> RETURN @.output
> END
> SELECT dbo.udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> FROM Orders
> GROUP BY dbo.udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> ORDER BY dbo.udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> The function should now pick up the dates in late December correctly. For
> example,
> select dbo.udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> Your example t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> against
> a table that has dates in 2005; is the table cyclic?
> "Scott" wrote:
>|||Just curious - what kind of w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
William Stacey [MVP]
"Scott" <sbailey@.mileslumber.com> wrote in message
news:%23UoMFlnCGHA.3876@.tk2msftngp13.phx.gbl...
> In CODE section below, I'm grouping the Sum of Freight by the w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> We have a custom year begin and end year table that the DDL section will
> create. Thus, I use the t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> and the last w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> Is there a way I could return the same results created by my CODE section
> in Northwind except use custom w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> also need a fix to properly sort the w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
>
> CODE:
> SELECT CAST(DATEPART(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> CAST(DATEPART(yyyy, OrderDate) AS char(4)) AS w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> sumFreight
> FROM Orders
> GROUP BY CAST(DATEPART(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> CAST(DATEPART(yyyy, OrderDate) AS char(4))
> ORDER BY CAST(DATEPART(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> CAST(DATEPART(yyyy, OrderDate) AS char(4))
>
> DDL ****************************************
*****
> USE [Northwind]
> GO
> CREATE TABLE [t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> ) ON [PRIMARY]
> GO
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> values
> ('19951226', '19961230', '1996')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> values
> ('19961231', '19971229', '1997')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> values
> ('19971230', '19981228', '1998')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> values
> ('19981229', '19981227', '1999')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> values
> ('19991228', '20001225', '2000')
>
>
>|||That the start and end year dates repeat in a pattern, every 5 years or so.
I
got from your second post that you were adjusting your data to fit Northwind
so a solution could be tested (and that's appreciated!)
I noticed when I ran the query against Northwind, one of the years (1996 I
think) shows up as having 53 w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
start date and end date for 1996 in your sample is 370 days, so that does go
beying 52 w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
the year being in w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
an adjusted version later.
"scott" wrote:
> First, thanks big for solving this head-hurter. My t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> the last 5 years plus always 1 year in advance. I had the old years so it'
d
> work in northwind.
> what did you mean by the table being "cyclic"?
>
> "Mark Williams" <MarkWilliams@.discussions.microsoft.com> wrote in message
> news:602D1125-A792-40A5-B505-7B31B7524A94@.microsoft.com...
>
>|||Should have been this way from the start.
CREATE FUNCTION udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
RETURNS varchar(7)
AS
BEGIN
DECLARE @.output varchar(7)
SELECT @.output = CAST(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
+ RIGHT('0' + CAST(CEILING(DATEDIFF(dd, w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
AS
varchar(3)), 2)
FROM t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
RETURN @.output
END
Now the last (364th) day of the year shows up as being in w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
that go beyond 364 days, you will still end up with a w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
function.
"scott" wrote:
> First, thanks big for solving this head-hurter. My t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> the last 5 years plus always 1 year in advance. I had the old years so it'
d
> work in northwind.
> what did you mean by the table being "cyclic"?
>
> "Mark Williams" <MarkWilliams@.discussions.microsoft.com> wrote in message
> news:602D1125-A792-40A5-B505-7B31B7524A94@.microsoft.com...
>
>|||Are these calendar w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
William Stacey [MVP]
"Scott" <sbailey@.mileslumber.com> wrote in message
news:%23UoMFlnCGHA.3876@.tk2msftngp13.phx.gbl...
> In CODE section below, I'm grouping the Sum of Freight by the w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> We have a custom year begin and end year table that the DDL section will
> create. Thus, I use the t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> and the last w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> Is there a way I could return the same results created by my CODE section
> in Northwind except use custom w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> also need a fix to properly sort the w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
>
> CODE:
> SELECT CAST(DATEPART(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> CAST(DATEPART(yyyy, OrderDate) AS char(4)) AS w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> sumFreight
> FROM Orders
> GROUP BY CAST(DATEPART(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> CAST(DATEPART(yyyy, OrderDate) AS char(4))
> ORDER BY CAST(DATEPART(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> CAST(DATEPART(yyyy, OrderDate) AS char(4))
>
> DDL ****************************************
*****
> USE [Northwind]
> GO
> CREATE TABLE [t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> [w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> ) ON [PRIMARY]
> GO
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> values
> ('19951226', '19961230', '1996')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> values
> ('19961231', '19971229', '1997')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> values
> ('19971230', '19981228', '1998')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> values
> ('19981229', '19981227', '1999')
> insert into t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> values
> ('19991228', '20001225', '2000')
>
>
>|||what's the difference in this 2nd correct function and the 1st or previous
correct function?
"Mark Williams" <MarkWilliams@.discussions.microsoft.com> wrote in message
news:D4583358-03D7-4EAD-9B4C-F1E69B884861@.microsoft.com...
> Should have been this way from the start.
> CREATE FUNCTION udfCustomW
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> RETURNS varchar(7)
> AS
> BEGIN
> DECLARE @.output varchar(7)
> SELECT @.output = CAST(w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> + RIGHT('0' + CAST(CEILING(DATEDIFF(dd, w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> AS
> varchar(3)), 2)
> FROM t_w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> RETURN @.output
> END
> Now the last (364th) day of the year shows up as being in w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> years
> that go beyond 364 days, you will still end up with a w
data:image/s3,"s3://crabby-images/5d952/5d952a66f5add0bbc22f17923814081639aa741b" alt=""
> function.
> "scott" wrote:
>
No comments:
Post a Comment