中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档 | 网通镜像
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 数据库开发 > MSSQL Server
存储过程 与 SQL Server语句大比拼
作者:佚名 时间:2007-06-25 16:35 出处:knowsky.com 责编:月夜寒箫
              摘要:存储过程 与 SQL Server语句大比拼

本文从多个角度阐述了SQL Server与存储过程的比较。

①为什么要使用存储过程?

因为它比SQL语句执行快。

②存储过程是什么?

把一堆SQL语句罗在一起,还可以根据条件执行不通SQL语句。

③来一个最简单的存储过程:

CREATE PROCEDURE dbo.testProcedure_AX
            AS
            select userID from
            USERS order by userid desc

注:dbo.testProcedure_AX是你创建的存储过程名,可以改为:AXzhz等,别跟关键字冲突就行了.AS下面就是一条SQL语句,不会写SQL语句的请回避。

④怎么在ASP.NET中调用这个存储过程:

 

public static string GetCustomerCName
            (ref ArrayList arrayCName,ref ArrayList arrayID)
            {
            SqlConnection con=ADConnection.createConnection();
            SqlCommand cmd=new SqlCommand("testProcedure_AX",con);
            cmd.CommandType=CommandType.StoredProcedure;
            con.Open();
            try
            {
            SqlDataReader dr=cmd.ExecuteReader();
            while(dr.Read())
            {
            if(dr[0].ToString()=="")
            {
            arrayCName.Add(dr[1].ToString());
            }
            }
            con.Close();
            return "OK!";
            }
            catch(Exception ex)
            {
            con.Close();
            return ex.ToString();
            }
            }

注:其实就是把以前:

SqlCommand cmd=new SqlCommand("select
            userID from USERS order by userid desc",con);

中的SQL语句替换为存储过程名,再把cmd的类型标注为CommandType.StoredProcedure(存储过程)。

 

⑤写个带参数的存储过程:

 

 

CREATE PROCEDURE dbo.AXzhz
            /*
            这里写注释
            */
            @startDate varchar(16),
            @endDate varchar(16)
            AS
            select id  from table_AX where commentDateTime>
            @startDate and commentDateTime<@endDate order
            by contentownerid DESC

注:@startDate varchar(16)是声明@startDate 这个变量,多个变量名间用【,】隔开.后面的SQL就可以使用这个变量了。

 

⑥我怎么在ASP.NET中调用这个带参数的存储过程:

 

public static string GetCustomerCNameCount
            (string startDate,string endDate,ref DataSet ds)
            {
            SqlConnection con=ADConnection.createConnection();
            //-----------------------注意这一段-------------------
            --------------------------------------------------------
            -----------------------------
            SqlDataAdapter da=new SqlDataAdapter("AXzhz",con);
            para0=new SqlParameter("@startDate",startDate);
            para1=new SqlParameter("@endDate",endDate);
            da.SelectCommand.Parameters.Add(para0);
            da.SelectCommand.Parameters.Add(para1);
            da.SelectCommand.CommandType=CommandType.StoredProcedure;
            //-------------------------------------------------------------
            ------------------------------------------------------------------
            try
            {
            con.Open();
            da.Fill(ds);
            con.Close();
            return "OK";
            }
            catch(Exception ex)
            {
            return ex.ToString();
            }
            }

注:把命令的参数添加进去,就可以了。

⑦重新验证SQL命令执行是否成功。

 

CREATE PROCEDURE dbo.AXzhz
            /*
            @parameter1 用户名
            @parameter2 新密码
            */
            @password nvarchar(20),
            @userName nvarchar(20)
            AS
            declare @err0 int
            update WL_user set password=@password where UserName=@userName
            set @err0=@@error
            select  @err0 as err0

注:先声明一个整型变量@err0,再给其赋值为@@error(这个是系统自动给出的语句是否执行成功,0为成功,其它为失败),最后通过select把它选择出来。

⑧那怎么从后台获得这个执行成功与否的值:

下面这段代码可以告诉你答案:

public static string GetCustomerCName()
            {
            SqlConnection con=ADConnection.createConnection();
            SqlCommand cmd=new SqlCommand("AXzhz",con);
            cmd.CommandType=CommandType.StoredProcedure;
            para0=new SqlParameter("@startDate","2006-9-10");
            para1=new SqlParameter("@endDate","2006-9-20");
            da.SelectCommand.Parameters.Add(para0);
            da.SelectCommand.Parameters.Add(para1);
            con.Open();
            try
            {
            Int32 re=(int32)cmd.ExecuteScalar();
            con.Close();
            if (re==0)
            return "OK!";
            else
            return "false";
            }
            catch(Exception ex)
            {
            con.Close();
            return ex.ToString();
            }
            }

注:就是通过SqlCommand的ExecuteScalar()方法取回这个值。

⑨我要根据传入的参数判断执行哪条SQL语句:

 

ALTER PROCEDURE dbo.selectCustomerCNameCount
            @customerID int
            AS
            if @customerID=-1
            begin
            select contentownerid ,userCName,count(*)
            as countAll from view_usercomment group by
            contentownerid,userCName order by contentownerid DESC
            end
            else
            begin
            select contentownerid ,userCName,count(*)
            as countAll from view_usercomment where
            contentownerid=@customerID group by contentownerid
            ,userCName order by contentownerid DESC
            end
关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有