存储过程入门

2016-01-29 19:44 5 1 收藏

存储过程入门,存储过程入门

【 tulaoshi.com - ASP 】

       存储过程入门
  
  Create procedure procedue_name
  [@parameter data_type][output]
  [with]{recompile|encryption}
  as
  sql_statement
  
  解释 output:表示此参数是可传回的.
  with {recompile|encryption}
  recompile:表示每次执行此存储过程时都重新编译一次
  encryption:所创建的存储过程的内容会被加密
  
  
  
  表book的内容如下
  
   编号 书名价格
  
   001 C语言入门 $30
  
   002 PowerBuilder报表开发 $52
  
  实例1:查询表Book的内容
  
  create proc query_book
   as
   select * from book
   go
  exec query_book
  
  实例2:加入一笔记录到表book,并查询此表中所有书籍的总金额
  
   Create proc insert_book
  
   @param1 char(10),@param2 varchar(20),@param3 money,@param4 money output
  
   with encryption ---------加密
  
   as
  
   insert book(编号,书名,价格) Values(@param1,@param2,@param3)
   select @param4=sum(价格) from book
   go
  
  执行例子:
   declare @total_price money
   exec insert_book '003','Delphi 开发指南',$100,@total_price
   print '总金额为'+convert(varchar,@total_price)
   go
  
  
  实例3:设有两个表为Product,Order,其表内容如下:
   Product
   产品编号 产品名称 客户订数
   001 钢笔 30
   002 毛笔 50
   003 铅笔 100
   Order
   产品编号 客户名 客户订金
   001 南山区 $30
   002 罗湖区 $50
   003 宝安区 $4
  请实现按编号为连接条件,将两个表连接成一个临时表,该表只含编号.产品名.客户名.订金.总金额,
  总金额=订金*订数,临时表放在存储过程中
  
  代码如下:
   Create proc temp_sale
   as
   select a.产品编号,a.产品名称,b.客户名,b.客户订金,a.客户订数* b.客户订金 as总金额
   into #temptable from Product a inner join Order b on a.产品编号=b.产品编号
   if @@error=0
   print 'Good'
   else
   print 'Fail'
   go
  
  
  

 

来源:https://www.tulaoshi.com/n/20160129/1510003.html

延伸阅读
标签: Web开发
1.调用存储过程的一般方法 先假设在sql server中有一存储过程dt_users: CREATE PROCEDURE [dbo].[dt_users] AS select * from users return GO 第一种方法是不利用command对象,直接用recordset对象 set rs=server.createobject("adodb.recordset") sql="exec dt_users" rs.open sql,c...
不过在网上找了一些,发现都有一个特点——就是不能传出总记录数,干脆自己研究吧。终于,算是搞出来了,效率可能不是很好,但是我也觉得不错了。贴代码吧直接:也算是对自己学习mysql的一个记录。 代码如下: CREATE PROCEDURE p_pageList ( m_pageNo int , m_perPageCnt int , m_column varchar(1000) , m_tab...
sql语句执行的时候要先编译,然后执行。存储过程就是编译好了的一些sql语句。用的时候直接就可以用了。所以效率会高 一 存储过程介绍 存储过程是由流控制和SQL语句书写的过程,这个过程经编译和优化 后存储在数据库服务器中,使用时只要调用即可。在ORACLE中,若干个 有联系的过程可以组合在一起构成程序包。 使用存储过程有以下的优点: * 存...
标签: SQLServer
/*--用存储过程实现的分页程序 显示指定表、视图、查询结果的第X页 对于表中主键或标识列的情况,直接从原表取数查询,其它情况使用临时表的方法 如果视图或查询结果中有主键,不推荐此方法 --邹建 2003.09--*/ /*--调用示例 exec p_show '地区资料' exec p_show '地区资料',5,3,'地区编号,地区名称,助记码','地区编号' --*/ /* 因为要顾及...
标签: ASP
1、调用没有参数的存储过程 <% set conn=server.CreateObject("adodb.connection") set cmd=server.CreateObject("adodb.command") strconn="dsn=pubs;uid=sa;pwd" conn.Open strconn set cmd.ActiveConnection=conn cmd.CommandText="{call nono}" 'set rs=cmc.exe 或者cmd.execute set rs=cmd.Execute() % 2、一个输入的参数的存储过...

经验教程

939

收藏

96
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部