开发者社区 问答 正文

在表设计中执行SELECT语句以设置表列的默认值

在RegionID的默认属性中,我想执行以下SELECT语句以在添加新行时建立单元格的值:

select regionID from tRegion where IsNone = 1 当我尝试保存表格设计时,出现“验证列'RegionID'的默认值时出错。

展开
收起
祖安文状元 2020-01-05 13:57:51 692 分享
分享
版权
举报
1 条回答
写回答
取消 提交回答
  • 的限制之一Computed Column是它不能直接访问表外的任何列。因此,您也可以创建一个User Defined Functionas:

    -- Create UDF to use in computed column
    CREATE FUNCTION UDF_GetDefaultRegionId ()
    RETURNS int
    AS
    BEGIN
      DECLARE @DefRegionId int
      SELECT @DefRegionId = regionID 
      from tRegion 
      where IsNone = 1
    
      RETURN @DefRegionId
    END;
    
    

    然后在“测试”表中用作:

    CREATE TABLE Test
    ( 
      StoreId int,
      --set default value here:
      RegionId  as ([dbo].UDF_GetDefaultRegionId())
     )
    
    

    示例代码在这里..希望这会有所帮助!!!

    2020-01-05 13:58:04 举报
    赞同 评论

    评论

    全部评论 (0)

    登录后可评论
问答地址:
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等