SQL Server 消息 241,级别 16,状态 1,从字符串转换日期和/或时间时转换失败

新手上路,请多包涵

执行我创建的 stored procedure 时出现此错误

消息 241,级别 16,状态 1,过程 UDP_INITIAL_CUSTOMER_DIM_POPULATION,第 28 行

从字符串转换日期和/或时间时转换失败。

该过程的代码是:

 CREATE PROCEDURE UDP_INITIAL_CUSTOMER_DIM_POPULATION
AS
BEGIN
    SET NOCOUNT ON

    EXEC UDP_REMOVE_NULLS_FROM_CUSTOMER_STG

    INSERT INTO dbo.customer_dim(customer_no, first_name, middle_name, last_name,
                                 street_number, street_name, po_address, zip_code, city,
                                 region, country)
        SELECT DISTINCT
            CAST(customer_no AS VARCHAR),
            first_name,
            middle_name,
            last_name,
            street_number,
            street_name,
            po_address,
            zip_code,
            city,
            region,
            country
        FROM
            dbo.customer_stg

    PRINT 'Initial customer data in place!'
    SET NOCOUNT OFF
END

并且创建 customer_dim 表的代码是:

 CREATE PROCEDURE dbo.UDP_CREATE_CUSTOMER_DIM
AS
BEGIN
    IF OBJECT_ID('customer_dim', 'U') IS NOT NULL
    BEGIN
        DROP TABLE customer_dim
    END

    CREATE TABLE [dbo].[customer_dim]
    (
        [customer_sk] INT IDENTITY (1,1) PRIMARY KEY,
        [customer_no] [varchar](50) NULL,
        [first_name] [varchar](50) NULL,
        [middle_name] [varchar](50) NULL,
        [last_name] [varchar](50) NULL,
        [customer_name] [varchar](50) NULL,
        [street_number] [varchar](50) NULL,
        [street_name] [varchar](50) NULL,
        [customer_address] [varchar](100) NULL,
        [po_address] [varchar](50) NULL,
        [zip_code] [varchar](50) NULL,
        [city] [varchar](50) NULL,
        [region] [varchar](50) NULL,
        [country] [varchar](50) NULL,
        [effective_date] DATE NULL DEFAULT GETDATE(),
        [expiry_date] DATE NULL DEFAULT '999-12-31'
    ) ON [PRIMARY]
    END

我曾尝试寻找解决方案,但因为我没有尝试在日期或时间做任何事情,所以我找不到任何对我有意义的事情。

原文由 Luke L 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 2k
2 个回答

该错误是由 expiry_date 的默认值引起的。跑步

SELECT CAST('999-12-31'AS DATE)

会产生错误:

从字符串转换日期和/或时间时转换失败。

你想要的是

[expiry_date] DATE NULL DEFAULT '9999-12-31'

原文由 Felix Pamittan 发布,翻译遵循 CC BY-SA 3.0 许可协议

我正在 SQL 2017 中进行字符串到日期的转换,它可以正确处理 m/d/yyyy 格式的字符串,其中包含一位数和两位数的日期或月份以及两位或四位数的年份。例如,以下字符串转换干净:

 2/6/2012
1/20/2020
12/21/2017
6/14/21

就我而言,我发现问题出在一条值为“5/15/161”的记录上。要查找错误数据,请使用 ISDATE() 函数。就我而言:

 SELECT [EMPLOYER NUMBER],[PLAN],[EMPLOYER NAME],[LAST UPDATED]
FROM [CONTACT NAME ADDRESS]
where [last updated] is not null
  and isdate([last updated]) <> 1

原文由 Ken 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进