SQL更改空日期或1-1-1900 00:00:00到当前日期

时间:2018-04-30 19:31:19

标签: sql date coalesce nullif

到目前为止,我用Google搜索了几个小时,并尝试了很多不同的东西,但不管怎样,与其他人一起工作的东西似乎对我的数据集不起作用。

*编辑:DBMS:SQL Server。 +以下代码

假设这是数据集:

ID,VALIDFROM,VALIDTO

1,1-1-2012,1-1-1900 00:00:00

2,1-1-2016,1-3-2017 00:00:00

3,1-1-2017,1-3,2018 00:00:00

4,1-1-2017,1-1-1900 00:00:00

5,1-1-2018,1-1-1900 00:00:00

我想将NULL转换为今天的日期,但每当我尝试使用NULLIFCOALESCE时,SQL都会返回1-1-1900 00:00:00

SELECT
A.CONTRACTLINEID,
A.CONTRACTID AS 'Contract ID',
COALESCE(C.RENTALCOSTTYPEID, 'LEEG') AS 'Component ID',
A.NAME AS 'Component',
A.LINETYPE AS 'Componenttype ID',
B.ENUMITEMLABEL AS 'Componenttype',
A.RENTALOBJECTID AS 'Vastgoed Object ID',
A.VALIDFROM,
--A.VALIDTO, -- 1-1-1900 00:00:00
--COALESCE(A.VALIDTO,Sysdate()) AS VALIDTO, -- ERROR
--COALESCE(A.VALIDTO,GETDATE()) AS VALIDTO, -- 1-1-1900 00:00:00
--COALESCE(A.VALIDTO,CURRENT_DATE) AS VALIDTO, -- ERROR
--NULLIF(A.VALIDTO,GETDATE()) AS VALIDTO, -- 1-1-1900 00:00:00
--NULLIF(A.VALIDTO,CURRENT_DATE) AS VALIDTO, -- ERROR
A.COSTSETTLEMENTID,
A.PRICEPERIODID,
A.DATAAREAID,
C.PRICEPRICEID AS 'Prijs ID',
COALESCE(C.PRICE, '0') AS 'Prijs',
C.FROMDATE AS 'Prijs Vanaf Datum',
C.TODATE AS 'Prijs T/m Datum',
COALESCE(C.NAME, 'LEEG') AS 'Component-Prijs',
D.CONTRACTSTATUS AS 'Contract Status'
FROM MRPMCCONTRACTLINES A
LEFT JOIN MRENUMS B ON
B.ENUMITEMVALUE = A.LINETYPE
AND B.ENUMID = 40021
OUTER APPLY
(
    SELECT  TOP 1 *
    FROM    MRPMCINVOICELINE C
    WHERE   C.CONTRACTLINEID = A.CONTRACTLINEID AND C.DATAAREAID = '1'
    ORDER BY
            C.TODATE DESC
    ) C
LEFT JOIN PMCCONTRACT D ON
D.CONTRACTID = A.CONTRACTID --Following doesn't do anything so far 
UPDATE MRPMCCONTRACTLINES
SET VALIDTO = '01/01/2050' 
WHERE VALIDTO IS NULL 
OR LTRIM(RTRIM(VALIDTO)) = ''        

2 个答案:

答案 0 :(得分:3)

COALESCE()会将NULL替换为值,这样就是您想要的。 NULLIF()NULL替换值,但不适用于此处。

我猜你正在做COALESCE(TODATE,''),它会将NULL替换为默认日期时间1-1-1900 00:00:00

确保您今天正确地喂食它的日期COALESCE(TODATE,GETDATE())

获取今天日期的功能将根据您的DBMS而有所不同。始终使用您的DBMS(SQL Server,MySQL,Oracle等)标记您的问题,以获得最佳答案。

答案 1 :(得分:0)

你不应该使用NULLIF,其目的是比较价值观。如果要在select语句中将值替换为null,则可以使用isnull(对于SQL服务器)或ifnull(对于MySQL)