【问题标题】:using select statement to define a default column value in create table syntax使用 select 语句在创建表语法中定义默认列值
【发布时间】:2015-09-22 13:50:27
【问题描述】:

我正在尝试创建一个表,对于其中一个列,我希望指定默认值 - 请参阅下面的代码:

CREATE TABLE dbo.PSTest(
modDate datetime default getdate()
, [Date] datetime default (SELECT CONVERT (DATE, GETDATE()))
);

我收到以下错误

Msg 1046, Level 15, State 1, Line 28
Subqueries are not allowed in this context. Only scalar expressions are allowed.

我知道我不能这样做,但是有没有办法解决这个问题?

提前谢谢你

【问题讨论】:

  • Date 是否总是与modDate 在同一天?如果是这样,计算列几乎肯定是更好的选择。
  • 不。 modDate 将是 datetime 但在 Date 我不想要任何时间输出元素。只是纯粹的 yyyy-mm-dd 没有时间延长。使用当前答案,我在 modDate as-2015-09-22 14:02:31.870 和日期为 2015-09-22 00:00:00.000 上得到输出。我根本不想要日期列中的时间
  • 这并没有回答我提出的问题。我在问这两列是否总是会有两个相关的值(即如果modDate 被更新,Date 也会更新到匹配的日期)?

标签: sql tsql ddl


【解决方案1】:

您不需要子查询:

CREATE TABLE dbo.PSTest(
    modDate datetime default getdate(),
    [Date] datetime default cast(getdate() as date)
);

【讨论】:

  • 好的,这很好,但是当我将数据插入表中时,日期列的输出为 2015-09-22 00:00:00.000。我不希望那个时间在那里显示。
  • @FaizSaiyed - 然后将其声明为date,而不是datetime。您已经给它一个具有时间组件的数据类型。它必须设置为 something.
  • 是的,也可以。刚刚被告知,如果我最后有 0 就可以了。不过谢谢大家#
  • @FaizSaiyed 仅供参考,通常可以在您使用的任何客户端应用程序/报告工具中格式化日期。业务人员很少直接查看 SQL 查询窗口的输出。
猜你喜欢
  • 2013-04-08
  • 2015-09-20
  • 2019-10-03
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2019-06-18
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多