SQL中一个不明的错误

ERROR>>未能找到 ID 为 104 的数据库。可能该数据库尚未激活,也可能正在转换过程中。
这个错误我是认为比较诡异了。请高手解释一下

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[fn]') and xtype in (N'FN', N'IF', N'TF'))
drop function [dbo].[fn]
GO
CREATE FUNCTION  fn
(
    @type     varchar(32)
)
RETURNS varchar(32)
AS
Begin
    declare @Status_for  varchar(32)
    set @Status_for=case @type
                    when 'd'  then  'd'
                    when 'c'  then  'c'                   
                    else  'UnKnow'
                  end
    return @Status_for   
End
GO


create table #t
(
  col1     varchar(32),
  col2     varchar(32),
  col3     int
)
insert into #t(col1, col2, col3) values('#t1', 'd', 1)
insert into #t(col1, col2, col3) values('#t2', 'd', 2)
insert into #t(col1, col2, col3) values('#t3', 'c', 1)
insert into #t(col1, col2, col3) values('#t4', 'c', 2)

create table #b
(
  b1     int,
  b2     varchar(32),
  b3     varchar(32)
)
insert into #b(b1, b2, b3) values(1, 'd', 'd1')
insert into #b(b1, b2, b3) values(2, 'd', 'd2')
insert into #b(b1, b2, b3) values(1, 'c', 'c1')
insert into #b(b1, b2, b3) values(2, 'c', 'c2')

--下面的查询没有问题
select *
from       #t a
left join  #b b on b.b1 = a.col3 and b.b2 = dbo.fn(a.col2)

--这个子查询,错误就比较诡异了
select * from
(
select *
from       #t a
left join  #b b on b.b1 = a.col3 and b.b2 = dbo.fn(a.col2)
) a


--clear the garbage
drop table #t
drop table #b
drop function dbo.fn

转载于:https://www.cnblogs.com/Meyer/archive/2004/12/09/75018.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值