开发者社区> 问答> 正文

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

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

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

展开
收起
祖安文状元 2020-01-05 13:57:51 657 0
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
    赞同 展开评论 打赏
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载