首页 - 数据库 - SQL Server

元数据不一致解决的一个实例

发布时间: 2007-04-19 05:04    作者: 未知    来源: 未知    浏览:    评论

存储过程如下:
ALTER  procedure d_sel_bj_xcl
 @filter varchar(2000),@sortstr varchar(2000),@iskw bit
as  
 set @sortstr='spzyflid,spkw,spid'
 declare @sql varchar(8000)
 set @sql='
 select spid,ckid,spmc,spgg,czmc,bzmc,cdmc,zlmc,spjldw,spkw,'
 if @iskw=1
  set @sql=@sql+'kwh,'
 set @sql=@sql+'
  sum(case when a.crklbfx=1 then sl else -sl end) as spxcl from (
  select a.*,b.spzyflid,b.spmc,b.spgg,cz.czmc,bz.bzmc,cd.cdmc,zl.zlmc,b.spjldw,
   spkw=case when patindex(''%([0-9][0-9][0-9][0-9])'',b.spmc)>0
     then right(spmc,6) else '''' end,
   c.crklbfx from bjlsb a
   join crklb c on a.crlb=c.crklbid
   left join sp b on a.spid=b.spid
   left join cz on b.spczid=cz.czid
   left join bz on b.spbzid=bz.bzid
   left join zl on b.spzlid=zl.zlid
   left join cd on b.spcdid=cd.cdid
   where a.iszf is null '
 if len(@filter)>0
  set @sql=@sql+' and '+@filter
 set @sql=@sql+') a   
  group by spid,spzyflid,ckid,spmc,spgg,czmc,bzmc,cdmc,zlmc,spjldw,spkw'
 if @iskw=1
  set @sql=@sql+',kwh'
 if len(@sortstr)>0
  set @sql=@sql+' order by '+@sortstr
 exec(@sql)


调用的过程如下:
select * from
openrowset('sqloledb',
 'jszg';'sa';'6162900',
 'execute zgerp..d_sel_bj_xcl ''ckid=''''45'''''','''',0') as a

结果为:
服务器: 消息 7355,级别 16,状态 1,行 1
OLE DB 提供程序 'sqloledb' 为列提供的元数据不一致。执行时更改了名称。
OLE DB 错误跟踪[Non-interface error:  OLE DB provider returned different names for a column: ProviderName='sqloledb', CompileTimeColumnName='kwh', RunTimeColumnName='spxcl', Rowset=execute zgerp..d_sel_bj_xcl 'ckid=''45''','',0]。

仔细看一下就可以看到kwh列的存在,如果使用库位管理,那么,库位号就是一个汇总的依据,但查询时设为0,这和编译产生的列不同,编译产生所有的列,所以就出现了这个错误,实在想不出什么好办法,就将查询时将0设为1,反正不使用库位来管理,得出的数是不受影响的:)

TAG

Smile Big Smile Surprise Stick out tongue Wink Sad Tongue Tied Indifferent Crying Embarrassed Cool Angry Angel Devil [8-|] [:#] [:-*] [:^)] [<:o)] [|-)] Yes Beer Left Hug Music Star Time Snail Pizza Automobile Umbrella Computer Storm [mo] [8o|] [^o)] [+o(] [*-)] [8-)] Coffee No Drinks [Z] Right Hug Cake Broken Heart Gift Wilted Flower Movie Dog Idea Sleep Email Travel Paradise
呢称:

加粗 斜体 下划线 链接 图片 代码 邮件地址 引用 列表

最多只能输入100个字符

Tags

SQL 数据库 asp.net C# XML 控件 .NET教程 程序 事件 数据 安全 代码 Server 客户端 验证 数据库专栏 接口 文件 Oracle DataSet 函数 DataGrid 问题 .net return C#语言 JavaScript 服务 IIS 对象 语句 windows 继承 时间 web.config 设计 开发 参数 变量 解决 字符 ADO.net 环境 VB.Net语言 web 异常 工具 服务器 计算 实例 OLEDB Application VB Word WebService insert asp net 安装 记录

精华推荐

更多

精品下载

更多