【问题标题】: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 不是更好吗?
  • 如果有员工照片怎么办?

标签: sql-server image database-design default-value sqldatatypes


【解决方案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。

【讨论】:

    猜你喜欢
    • 2022-01-08
    • 2014-12-19
    • 1970-01-01
    • 1970-01-01
    • 2016-08-03
    • 2021-06-22
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多