作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
是否可以在 MSSQL 中将列标记为不可变
?
看起来这将是一个有用的 DDL 功能;一旦在行中设置了值(“行”被定义为值与主键的特定关系),则在不删除该行的情况下无法更改该值。
显然(像大多数事情一样)这在应用程序层中是完全可行的,但 SQL DDL 的一半乐趣在于对应用程序代码进行错误检查。
最佳答案
如果执行 DML 的用户不是对象的所有者,也不是数据库本身的“db_owner”,则您可以只授予该表的“插入”权限,但不能授予该表的更新权限:
假设一个表有id, col1, col2
grant insert, select, delete on the_table to the_user;
grant update (id, col2) on the_table to the_user;
通过这些授权,the_user 可以插入行并为所有三列提供值。他还可以更新 id
和 col2
列,但不能更新 col1
列。
db_owner(可能还有表的创建者/所有者)始终可以更新所有列。我不知道是否有办法撤销这些角色的特权。
关于sql - 不可变的 SQL 列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12166523/
COW 不是奶牛,是 Copy-On-Write 的缩写,这是一种是复制但也不完全是复制的技术。 一般来说复制就是创建出完全相同的两份,两份是独立的: 但是,有的时候复制这件事没多大必要
我是一名优秀的程序员,十分优秀!