我的存储过程学习2

存储过程

业务系统需要一个关于合同状态的报表,主要显示合同的状态,地区,合同客户类型,合同金额,利息金额等信息.
在数据库中存在4个表
crec01c,sysc01,sysc03d,crmc02分别是'合同主表','区域及业务伙伴','系统状态代码','法人信息表'
下面第一个存储过程是我第一次写的,执行时间是5秒
 ------------------效率较差的存储过程---------------------------
 CREATE TABLE #tmptba --创建一个临时表,用于储存我们的结果
 (
  colID int IDENTITY(1,1) PRIMARY KEY CLUSTERED,
  khlx varchar(20),
  dq varchar(20),
  ywhb varchar(40),
  htzt varchar(20),
  htbs int ,
  htje numeric(13,2),
  lxje numeric(13,2)
 )
DECLARE  @bkhlx char(1), @ikhid int, @cywdbd char(10), @chtzt char(1), @njkje numeric(13,2), @iqx int, @nhtyll numeric(8,6) --FOR Progress
DECLARE @t_khlx varchar(20), @t_dq varchar(20), @t_ywhb varchar(40), @t_htzt varchar(20), @t_htbs int, @t_htje numeric(13,2), @t_lxje numeric(13,2)--FOR INSERT INTO #tmptba
--DECLARE @index int
--SET @index = 1
DECLARE cur1 CURSOR FOR SELECT bkhlx, ikhid, cywdbd, chtzt, njkje, iqx, nhtyll FROM crec01c
OPEN cur1
FETCH NEXT FROM cur1 INTO @bkhlx, @ikhid, @cywdbd, @chtzt, @njkje, @iqx, @nhtyll
WHILE @@FETCH_STATUS = 0
BEGIN
  IF @bkhlx = '1'
      BEGIN
          SET @t_khlx = '自然人'
          SET @t_dq  = (SELECT vjgmc FROM sysc01 WHERE cjgdm = left(@cywdbd,6))
      END
  ELSE
      BEGIN
          SET @t_khlx = '法人'
          SET @t_dq = (SELECT vjgmc FROM sysc01 WHERE cjgdm = (SELECT cbmdm FROM crmc02 WHERE frid = @ikhid ) )
      END
    SET @t_htbs = 1-- @index--合同笔数

    SET @t_ywhb = (SELECT vjgmc FROM sysc01 WHERE cjgdm = @cywdbd)--业务伙伴
    SET @t_htzt = (SELECT vsjxc FROM sysc03d WHERE czddm = 'htzt' AND csjxm = @chtzt)--合同状态
    SET @t_htje = @njkje
    SET @t_lxje = @njkje * @iqx * @nhtyll * 0.001

   INSERT INTO #tmptba (khlx, dq, ywhb, htzt, htbs, htje, lxje) VALUES (@t_khlx, @t_dq, @t_ywhb, @t_htzt, @t_htbs, @t_htje, @t_lxje)
      --SET @index  1
  FETCH NEXT FROM cur1 INTO @bkhlx, @ikhid, @cywdbd, @chtzt, @njkje, @iqx, @nhtyll
END
CLOSE cur1
DEALLOCATE cur1
SELECT * FROM #tmptba
GO
 ------------------效率较高的存储过程执行时间是1秒---------------------------
 CREATE TABLE #tmptbl --创建一个临时表,用于储存我们的结果
 (
  colID int IDENTITY(1,1) PRIMARY KEY CLUSTERED,
  khlx varchar(20),
  dq varchar(20),
  ywhb varchar(40),
  htzt varchar(20),
  htbs int ,
  htje numeric(13,2),
  lxje numeric(13,2)
 )
INSERT INTO #tmptbl SELECT CASE WHEN a.bkhlx = '1' THEN '自然人' ELSE '法人' END AS khlx, dq = (SELECT vjgmc FROM sysc01 WHERE cjgdm = left(a.cywdbd,6)), ywhb = (SELECT vjgmc FROM sysc01 WHERE cjgdm = a.cywdbd), htzt = (SELECT vsjxc FROM sysc03d WHERE czddm = 'htzt' AND csjxm = a.chtzt), htbs = 1, htje = a.njkje, lxje = a.njkje * a.iqx * a.nhtyll * 0.001 FROM crec01c a WHERE a.bkhlx = '1'

INSERT INTO #tmptbl SELECT CASE WHEN a.bkhlx = '1' THEN '自然人' ELSE '法人' END AS khlx, dq = (SELECT vjgmc FROM sysc01 WHERE cjgdm = (SELECT cbmdm FROM crmc02 WHERE frid = a.ikhid)), ywhb = '无', htzt = (SELECT vsjxc FROM sysc03d WHERE czddm = 'htzt' AND csjxm = a.chtzt), htbs = 1, htje = a.njkje, lxje = a.njkje * a.iqx * a.nhtyll * 0.001 FROM crec01c a WHERE a.bkhlx = '2'

SELECT * FROM #tmptbl
GO

可以看到,第二个存储过程只用了两条sql语句就完成了第一个存储过程的工作。

时间: 2024-10-28 04:43:46

我的存储过程学习2的相关文章

积分获取和消费的存储过程学习示例

  这篇文章主要介绍了积分获取和消费的存储过程学习示例,这个只是学习一下存储过程的使用方法,需要的朋友可以参考下 1.GM_JF客户账户积分表 2. GM_JF_DETAIL客户账户积分消费记录 3. GM_JF_ACTION _RULES积分动作规则表 4.GM_JF_GOODS _RULES积分商品规则表   -- ===============测试======================================================= /* declare @Stat

MySql存储过程学习知识小结_Mysql

什么是存储过程: 存储过程可以说是一个记录集吧,它是由一些T-SQL语句组成的代码块,这些T-SQL语句代码像一个方法一样实现一些功能(对单表或多表的增删改查),然后再给这个代码块取一个名字,在用到这个功能的时候调用他就行了. 存储过程的好处: 1.由于数据库执行动作时,是先编译后执行的.然而存储过程是一个编译过的代码块,所以执行效率要比T-SQL语句高. 2.一个存储过程在程序在网络中交互时可以替代大堆的T-SQL语句,所以也能降低网络的通信量,提高通信速率. 3.通过存储过程能够使没有权限的

MySql的存储过程学习小结 附pdf文档下载_Mysql

存储过程是一种存储在数据库库中的程序(就像正规语言里的子程序一样),准确的来说,MySql支持的"routine(例程)"有两种:一是我们说的存储过程,二是在其它sql语句中可以返回值的函数(使用起来和mysql预装载的函数一样,如pi()). 一个存储过程包括名字,参数列表,以及可以包括很多sql语句的sql语句集.在这里对局部变量,异常处理,循环控制和if条件语句有新的语法定义. 下面是一个包括存储过程的实例声明: 复制代码 代码如下: CREATE PROCEDURE proce

购物车的存储过程学习

存储过程|购物车 从来没有接触过存储过程,为了这个项目写了几个存储过程.就当是学习了,呵呵,这个购物车的存储过程中使用了Table(表),Cursor(游标)变量. 要求如下: 一个商品表[Ware],里面包含有的字段有ID,MarketPrice,MemberPrice,VipPrice等等,还一个会员购物车[MemberCar]数据表.包括的有ID,MemberID,WareID,WareNum等等.现要求是能取得购物车表里的所有数据和MarketPrice*WareNum(所有商品和)的总

MSSQL存储过程学习笔记一 关于存储过程_MsSql

一. 存储过程的概念,优点,语法 在写笔记之前,首先需要整理好这些概念性的东西,否则的话,就会在概念上产生陌生或者是混淆的感觉. 概念:将常用的或者是很复杂的工作,预先利用SQL语句写好并用一个指定的名称存储起来,那么以后要是调用这些SQL语句的时候,只需要利用Execute/Exec执行以下,即可. 优点:当然了,使用存储过程的优点是很多的,下面来一一说明. 1. 存储过程只是在创造的时候进行编译,以后每次执行的时候,就不需要编译了,但是直接利用SQL的话,需要每次运行的时候都重新编译一次,所

mySql-数据库之存储过程学习总结

之前在工作中总是听别人提到存储过程,觉得是个很高深的东西,利用工作之余,看了下相关的知识,现将学习知识总结如下,希望可以为刚学习的人提供些许帮助. 开发环境:Navicat For Mysql. MySQL存储过程 1.1.CREATE  PROCEDURE  (创建)CREATE PROCEDURE存储过程名 (参数列表)   BEGIN         SQL语句代码块END注意:由括号包围的参数列必须总是存在.如果没有参数,也该使用一个空参数列().每个参数默认都是一个IN参数.要指定为其

MSSQL存储过程学习笔记一 关于存储过程

一. 存储过程的概念,优点,语法 在写笔记之前,首先需要整理好这些概念性的东西,否则的话,就会在概念上产生陌生或者是混淆的感觉. 概念:将常用的或者是很复杂的工作,预先利用SQL语句写好并用一个指定的名称存储起来,那么以后要是调用这些SQL语句的时候,只需要利用Execute/Exec执行以下,即可. 优点:当然了,使用存储过程的优点是很多的,下面来一一说明. 1. 存储过程只是在创造的时候进行编译,以后每次执行的时候,就不需要编译了,但是直接利用SQL的话,需要每次运行的时候都重新编译一次,所

MSSQL数据库:存储过程学习

存储过程|数据|数据库 这个例子里面我们从两个表中取出头两行,然后合并到一个表中. 在现实中我们常常会遇到这样的情况,在一个数据库中存在两个表,假设表1储存着公司个产品本季度销售信息,表2储存着公司本季度欠款金额情况.在一个页面中我们想把这两个信息显示出来.通常的做法是在程序中进行两次SQL查询,返回两个结果集,在分别显示出来,非常麻烦. 下面是实现这个功能的代码: CREATE PROCEDURE test AS  SET NOCOUNT ON --指示存储过程不返回查询影响的行数  DECL

sql存储过程学习实例

什么是存储过程呢? 定义: 将常用的或很复杂的工作,预先用SQL语句写好并用一个指定的名称存储起来, 那么以后要叫数据库提供与已定义好的存储过程的功能相同的服务时,只需调用execute,即可自动完成命令. 讲到这里,可能有人要问:这么说存储过程就是一堆SQL语句而已啊? Microsoft公司为什么还要添加这个技术呢? 那么存储过程与一般的SQL语句有什么区别呢? 存储过程的优点: 1.存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以