通过嵌套,根据表中记录的表名与列名到指定位置取值。

--声明存储过程   ProPIMS
if (exists (select * from sys.objects where name = 'ProPIMS'))
drop proc ProPIMS
go
create procedure ProPIMS
@dcsgroupinfo varchar(100),@dcsmcinfo varchar (150)
AS
BEGIN declare @dcsgroup varchar(50),@mc varchar(50),@dw varchar(50),@tablename varchar(50),@columnname varchar(50),@Columncount int;
if exists(select * from tempdb..sysobjects where id=object_id('tempdb..##dcs_tablevalue'))
drop table ##dcs_tablevalue;
create table ##dcs_tablevalue
(
tablename varchar(50),
columnname varchar(50),
value varchar(50)
)
declare @charsql varchar(500)
if cursor_status('global','mycursor')=-3 and cursor_status('local','mycursor')=-3
declare mycursor cursor for
select distinct dcsgroup,mc,dw,tablename,columnname
from
(
select a.dcsgroup,a.mc,a.dw,b.tablename,a.columnname
from dcsdata.dcsdatainf a
left join dcsdata.dcsgroup b on a.dcsgroup = b.groupname
)total
open mycursor
fetch next from mycursor into @dcsgroup,@mc,@dw,@tablename,@columnname
while(@@FETCH_STATUS = 0)
begin
set @Columncount = 0;
SELECT @Columncount = count(*) from syscolumns where name= @columnname and id=object_id(@tablename);
if(@Columncount = 1)
set @charsql = 'insert into ##dcs_tablevalue select top 1 '''+@tablename+''','''+@columnname+''',(select top 1 ' +@columnname +' from '+ @tablename+');'
exec(@charsql);
fetch next from mycursor into @dcsgroup,@mc,@dw,@tablename,@columnname
end
close mycursor if(@dcsgroupinfo is not null and @dcsgroupinfo != '' and (@dcsmcinfo is null or @dcsmcinfo = ''))--取一整个模块的数据
--查询结果集
select distinct total.dcsgroup,total.mc,total.dw,##dcs_tablevalue.value,##dcs_tablevalue.tablename,##dcs_tablevalue.columnname
from ##dcs_tablevalue
left join
(
select a.dcsgroup,a.mc,a.dw,b.tablename,a.columnname
from dcsdata.dcsdatainf a
left join dcsdata.dcsgroup b on a.dcsgroup = b.groupname
)total on total.tablename = ##dcs_tablevalue.tablename and total.columnname = ##dcs_tablevalue.columnname
where total.dcsgroup = @dcsgroupinfo
else if (@dcsmcinfo = 'all')--取39个全厂概貌
--查询结果集
select distinct total.dcsgroup,total.mc,total.dw,##dcs_tablevalue.value,##dcs_tablevalue.tablename,##dcs_tablevalue.columnname
from ##dcs_tablevalue
left join
(
select a.dcsgroup,a.mc,a.dw,b.tablename,a.columnname
from dcsdata.dcsdatainf a
left join dcsdata.dcsgroup b on a.dcsgroup = b.groupname
)total on total.tablename = ##dcs_tablevalue.tablename and total.columnname = ##dcs_tablevalue.columnname
where mc in
('中压蒸汽压力','低压蒸汽压力','下段气总管压力','中段气总管压力','清洗气总管压力',
'滤过真空度','循环水压力','下段气总流量','中段气总流量','清洗气总流量',
'重碱皮带秤','真空淡液塔淡液流量','热母液总管流量','蒸馏灰乳总流量','取出液总流量',
'淡氨盐水总流量','冷母液流量','碳化尾气总管压力','热氨盐水桶液位','冷氨盐水桶液位',
'中和水贮桶液位','1#热母液液位','2#热母液液位','1#冷母液桶液位','2#冷母液桶液位',
'I组中和水温度','II组中和水温度','III组中和水温度','滤过吹风压力','循环水温度',
'冷冻水温度','氨盐水总管温度','重碱精盐水总流量','氨气总管温度','精盐水温度',
'淡液塔中部温度','去盐水循环水温度','滤过洗水温度','滤碱机总洗水流量')
and dcsgroup in ('重碱碳滤DCS','煅烧DCS')
else if(@dcsgroupinfo is null or @dcsgroupinfo = '')--取所有数据
--查询结果集
select distinct total.dcsgroup,total.mc,total.dw,##dcs_tablevalue.value,##dcs_tablevalue.tablename,##dcs_tablevalue.columnname
from ##dcs_tablevalue
left join
(
select a.dcsgroup,a.mc,a.dw,b.tablename,a.columnname
from dcsdata.dcsdatainf a
left join dcsdata.dcsgroup b on a.dcsgroup = b.groupname
)total on total.tablename = ##dcs_tablevalue.tablename and total.columnname = ##dcs_tablevalue.columnname
else--取相关模块相关子模块的数据
--查询结果集
select distinct total.dcsgroup,total.mc,total.dw,##dcs_tablevalue.value,##dcs_tablevalue.tablename,##dcs_tablevalue.columnname
from ##dcs_tablevalue
left join
(
select a.dcsgroup,a.mc,a.dw,b.tablename,a.columnname
from dcsdata.dcsdatainf a
left join dcsdata.dcsgroup b on a.dcsgroup = b.groupname
)total on total.tablename = ##dcs_tablevalue.tablename and total.columnname = ##dcs_tablevalue.columnname
where total.dcsgroup = @dcsgroupinfo and total.mc like @dcsmcinfo
END
--执行存储过程

Sqlserver 游标&存储过程&临时表混合使用实例的更多相关文章

  1. 查询Table name, Column name, 拼接执行sql文本, 游标, 存储过程, 临时表

    018_Proc_UpdateTranslations.sql: SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO if (exists (select ...

  2. T-SQL应用,视图、存储过程、触发器、游标、临时表等

    sqlserver常用操作: 视图.存储过程.触发器.函数 --*********************批处理********************* --[在一个批处理中存有一个语法错误,则所有 ...

  3. Java调用oracle存储过程通过游标返回临时表数据

    注:本文来源于 <  Java调用oracle存储过程通过游标返回临时表数据   > Java调用oracle存储过程通过游标返回临时表数据 项目开发过程中,不可避免的会用到存储过程返回结 ...

  4. Sqlserver中存储过程,触发器,自定义函数(一)

    Sqlserver中存储过程,触发器,自定义函数 1.存储过程有关内容存储过程的定义:存储过程的分类:存储过程的创建,修改,执行:存储过程中参数的传递,返回与接收:存储过程的返回值:存储过程使用游标. ...

  5. SQLServer 的存储过程与java交互

    一.   存储过程简介 Sql Server的存储过程是一个被命名的存储在服务器上的Transacation-Sql语句集合,是封装重复性工作的一种方法,它支持用户声明的变量.条件执行和其他强大的编程 ...

  6. Sqlserver中存储过程,触发器,自定义函数

    Sqlserver中存储过程,触发器,自定义函数: 1. 触发器:是针对数据库表或数据库的特殊存储过程,在某些行为发生的时候就会被激活 触发器的分类: DML触发器:发生在数据操作语言执行时触发执行的 ...

  7. Oracle创建表语句(Create table)语法详解及示例、、 C# 调用Oracle 存储过程返回数据集 实例

    Oracle创建表语句(Create table)语法详解及示例 2010-06-28 13:59:13|  分类: Oracle PL/SQL|字号 订阅 创建表(Create table)语法详解 ...

  8. SQLServer 中存储过程

    SQLServer 中存储过程返回的三种方式( 包括存储过程的创建, 在存储过程中调用, 在VS中调用的方法)存储过程有三种返回:   1.   用return返回数字型数据   2.   用返回参数 ...

  9. Sqlserver中存储过程,触发器,自定义函数(二)

    Sqlserver中存储过程,触发器,自定义函数: 自定义函数:1.函数类型:2.函数的参数和返回值: 1.函数类型:标量值函数,返回的是一个标量值表值函数:内联表值函数:多语句表值函数. 标量值函数 ...

随机推荐

  1. php工具箱使用

    linux安装过程 1,去网盘下载(本人网盘也有,如果找不到,contact me)http://pan.baidu.com/s/1cxHQge 我解压以后放在/mnt/hgfs/root/phpto ...

  2. PHP加密解密数字,适用于URL加密。

    本博主最近正在建设一个9元包邮的网站,希望各位光临指导一些意见: 9元包邮 http://www.jiubaou.com/ <?php /** * 加密解密类 * 该算法仅支持加密数字.比较适用 ...

  3. Idea与Eclipse操作代码的快捷方式

    1.Idea格式化代码的快捷键:ctrl+alt+L 2.在IDEA中创建了properties文件,发现默认中文不会自动进行unicode转码.如下 在project settings - File ...

  4. redis实战笔记(1)-第1章 初识Redis

    第1章 初识Redis 注:本书在redis3.0版本的,比如redis3.0以后支持服务端集群.3.0之前只能客户端分片.    本章主要内容 1.Redis与其他软件的相同之处和不同之处 2.Re ...

  5. 编译android源码遇到错误及其解决方法

    升级ubuntu的14.04后,android的源码又编译错误了,一下是错误说明赫解决方法: 1.make: *** [out/host/linux-x86/obj/EXECUTABLES/aidl_ ...

  6. easyui多选与接收不一致解决方案

    附代码: function batchRefund(){ if(editIndex != undefined) { $('#refundList').datagrid('endEdit', editI ...

  7. CSS浮动的3个特性(高手绕行)

    1.  浮动元素会脱离正常的文档流,按照其外边距指定的位置相对于它的上一个块级元素(或父元素)显示: 代码示例: <!DOCTYPE HTML > <html> <hea ...

  8. EF fluent API如何配置主键不自动增长

    在Dbcontext中作如下添加: protected override void OnModelCreating(DbModelBuilder modelBuilder) { modelBuilde ...

  9. 十三、curator recipes之SharedCounter

    简介 我们可以通过curator实现对一个分布式环境下共享变量的访问,zookeeper将共享变量维护在同一个路径下. 官方文档:http://curator.apache.org/curator-r ...

  10. 撩课-Java每天5道面试题第25天

    156.mvc:view-controller有什么作用? 当我们发送一个请求时,如果没有找到对应的mapping 则会对配置文件当中匹配mvc:view-controller 注意点:使用时要添加后 ...