SQLSERVER视图错位的解决办法

原始需求如下:

有一个表T1

create table t1
(id int not null primary key
,v1 varchar(10)
)

insert into t1 values(1,'aaa');
insert into t1 values(2,'bbb');

 

有一个表TS,用于记录T1中 每条记录的更新时间(触发器实现,此处略过)

create table ts 
(id int not null primary key
,updatetime datetime
)
insert into ts values(1,getdate());
insert into ts values(2,getdate());

 

创建两个视图:

--视图1
create
view view1 as select a.*,b.updatetime from t1 a left join ts b on a.id=b.id
--视图2
create view view2 as select b.updatetime,a.* from t1 a left join ts b on a.id=b.id

 

这样做是希望记录表t1更新的时间戳,同时当t1新增字段时视图会包含新的字段。相当于 视图 = t1.*+ts.updateime

问题1:t1新增字段后,视图不会自动新增字段
alter table t1 add v2 int not null default -1;

查看一下视图:

select * from view1;
select * from view2;

结果如下:

两个 视图中均没有新增的字段v2.

这个问题暂时用刷新视图的方法处理,是否有其它方式暂未找到。

  sp_refreshview view1

 

问题2:新增字段会造成视图与原始表的列错位。

仔细看上图中的第1个结果,updatetime并不是显示它的值getdate(),而是显示的view1中新增的字段v2的值。

而view2中不会有这个问题

 

转载于:https://www.cnblogs.com/champaign/p/10968929.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值