根据另一列设置默认值?

Posted

技术标签:

【中文标题】根据另一列设置默认值?【英文标题】:Set a default value based on another column? 【发布时间】:2018-09-09 05:15:33 【问题描述】:

我有带有列的表 Employee

IdEmp int 非空主键, PhotoEmp 图片默认 'D:\Avatars\maleSilhouette.png', GenderEmp nchar(1) 检查 GenderEmp in ('M','F')

因此,每次我插入 EMPLOYEE (IdEmp,GenderEmp) 值 ('1001','M') 时,此脚本默认存储男性图像(无论性别),但 我想存储女性剪影 (D:\Avatars\femaleSilhouette.png) 如果性别是“F”

【问题讨论】:

为什么首先在数据库中放置一个默认占位符?对于没有上传自己照片的用户,存储 null 不是更好吗? 如果有员工照片怎么办? 【参考方案1】:

您可以将您的 PhotoEmp 列设为计算列,并按如下方式设置值:

ALTER TABLE dbo.Employee ADD PhotoEmp AS CAST
(
  CASE
  WHEN GenderEmp = 'M' THEN 'D:\Avatars\maleSilhouette.png' 
  ELSE 'D:\Avatars\femaleSilhouette.png'
  END AS image
)
GO 

【讨论】:

谢谢。我只是用其他数据类型对其进行了测试,它确实有效。【参考方案2】:

您可以使用虚拟列来实现这一点。但是之后您将无法在该列中插入任何其他值。你会得到 ORA-54013。

【讨论】:

以上是关于根据另一列设置默认值?的主要内容,如果未能解决你的问题,请参考以下文章