摘自:http://www.cnblogs.com/smhy8187/articles/677742.html

声明:本例用的数据库是系统提供的pubs数据库,表是是employee,编程语言用C#

1.执行不带参数的存储过程存储过程:

create proc example1
as
begin
select top 6 emp_id,fname,lname
from employee
end

执行代码:

SqlConnection Conn = new SqlConnection("server=.;database=pubs;uid=sa;pwd=");
Conn.Open();
SqlCommand cmd = new SqlCommand("example1", Conn);
cmd.CommandType = CommandType.StoredProcedure;
SqlDataReader dr = cmd.ExecuteReader();

//输出执行结果
string table = "<table border='1'><tr>";
int field = dr.FieldCount;

for (int i = 0; i <= field - 1; i++)
{
table += "<TD>" + dr.GetName(i) + "</td>";
}

table += "</tr>";
while (dr.Read())
{
table += "<tr>";
for (int i = 0; i <= field - 1; i++)
{
table += "<TD>" + dr.GetValue(i) + "</td>";
}
table += "</tr>";
}
table += "</table>";
Conn.Close();
Response.Write(table);

2.执行带普通参数的存储过程
    存储过程:

create proc example2

@empid varchar(9)

as

begin

select emp_id,fname,lname from employee

where emp_id=@empid

end

执行代码:

SqlConnection Conn = new SqlConnection("server=.;database=pubs;uid=sa;pwd=");Conn.Open(); SqlCommand cmd = new SqlCommand("example2", Conn); cmd.CommandType = CommandType.StoredProcedure;

cmd.Parameters.Add("@empid", SqlDbType.VarChar, 9);

cmd.Parameters["@empid"].Value = "PMA42628M";

SqlDataReader dr = cmd.ExecuteReader();

//显示执行结果

string table = "<table border='1'><tr>";
int field = dr.FieldCount;

for (int i = 0; i <= field - 1; i++)
{
table += "<TD>" + dr.GetName(i) + "</td>";
}

table += "</tr>";
while (dr.Read())
{
table += "<tr>";
for (int i = 0; i <= field - 1; i++)
{
table += "<TD>" + dr.GetValue(i) + "</td>";
}
table += "</tr>";
}
table += "</table>";
Conn.Close();
Response.Write(table);

3.执行带output型参数的存储过程
存储过程:

 create proc example3 @Count int output as begin select @Count=(select count(*) from employee) end

执行代码:

SqlConnection Conn = new SqlConnection("server=.;database=pubs;uid=sa;pwd=");

Conn.Open();

SqlCommand cmd = new SqlCommand("example3", Conn); cmd.CommandType =andType.StoredProcedure;

cmd.Parameters.Add("@Count", SqlDbType.VarChar, 9);

cmd.Parameters["@count"].Direction = ParameterDirection.Output;

SqlDataReader dr = cmd.ExecuteReader();

Conn.Close();

int c =Convert.ToInt32(cmd.Parameters["@count"].Value); Response.Write(c.ToString());

4.执行用return返回的存储过程
存储过程:

create proc example4as

Begin

declare @Count int

select @Count=(select count(*) from employee)

return @Countend

执行代码:

 
SqlConnection Conn = new SqlConnection("server=.;database=pubs;uid=sa;pwd=");

Conn.Open();

SqlCommand cmd = new SqlCommand("example4", Conn); cmd.CommandType = CommandType.StoredProcedure; cmd.Parameters.Add("Count", SqlDbType.VarChar, 9); cmd.Parameters["count"].Direction = ParameterDirection.ReturnValue;

SqlDataReader dr = cmd.ExecuteReader();

Conn.Close();

int c =Convert.ToInt32(cmd.Parameters["count"].Value); Response.Write(c.ToString());

ASP.NET技巧(二)-在asp.net中执行存储过程 
 
2006-12-18 20:27:15 
 
大中小 
声明:本例用的数据库是系统提供的pubs数据库,表是是employee,编程语言用C#
1.执行不带参数的存储过程存储过程:

create proc example1
as
begin
select top 6 emp_id,fname,lname
from employee
end

执行代码:

SqlConnection Conn = new SqlConnection("server=.;database=pubs;uid=sa;pwd=");
Conn.Open();
SqlCommand cmd = new SqlCommand("example1", Conn);
cmd.CommandType = CommandType.StoredProcedure;
SqlDataReader dr = cmd.ExecuteReader();

//输出执行结果
string table = "<table border='1'><tr>";
int field = dr.FieldCount;

for (int i = 0; i <= field - 1; i++)
{
table += "<TD>" + dr.GetName(i) + "</td>";
}

table += "</tr>";
while (dr.Read())
{
table += "<tr>";
for (int i = 0; i <= field - 1; i++)
{
table += "<TD>" + dr.GetValue(i) + "</td>";
}
table += "</tr>";
}
table += "</table>";
Conn.Close();
Response.Write(table);

2.执行带普通参数的存储过程
    存储过程:

create proc example2

@empid varchar(9)

as

begin

select emp_id,fname,lname from employee

where emp_id=@empid

end

执行代码:

SqlConnection Conn = new SqlConnection("server=.;database=pubs;uid=sa;pwd=");Conn.Open(); SqlCommand cmd = new SqlCommand("example2", Conn); cmd.CommandType = CommandType.StoredProcedure;

cmd.Parameters.Add("@empid", SqlDbType.VarChar, 9);

cmd.Parameters["@empid"].Value = "PMA42628M";

SqlDataReader dr = cmd.ExecuteReader();

//显示执行结果

string table = "<table border='1'><tr>";
int field = dr.FieldCount;

for (int i = 0; i <= field - 1; i++)
{
table += "<TD>" + dr.GetName(i) + "</td>";
}

table += "</tr>";
while (dr.Read())
{
table += "<tr>";
for (int i = 0; i <= field - 1; i++)
{
table += "<TD>" + dr.GetValue(i) + "</td>";
}
table += "</tr>";
}
table += "</table>";
Conn.Close();
Response.Write(table);

3.执行带output型参数的存储过程
存储过程:

create proc example3 @Count int output as begin select @Count=(select count(*) from employee) end

执行代码:

SqlConnection Conn = new SqlConnection("server=.;database=pubs;uid=sa;pwd=");

Conn.Open();

SqlCommand cmd = new SqlCommand("example3", Conn); cmd.CommandType =andType.StoredProcedure;

cmd.Parameters.Add("@Count", SqlDbType.VarChar, 9);

cmd.Parameters["@count"].Direction = ParameterDirection.Output;

SqlDataReader dr = cmd.ExecuteReader();

Conn.Close();

int c =Convert.ToInt32(cmd.Parameters["@count"].Value); Response.Write(c.ToString());

4.执行用return返回的存储过程
存储过程:

create proc example4as

Begin

declare @Count int

select @Count=(select count(*) from employee)

return @Countend

执行代码:

SqlConnection Conn = new SqlConnection("server=.;database=pubs;uid=sa;pwd="); 
Conn.Open();

SqlCommand cmd = new SqlCommand("example4", Conn); cmd.CommandType = CommandType.StoredProcedure; cmd.Parameters.Add("Count", SqlDbType.VarChar, 9); cmd.Parameters["count"].Direction = ParameterDirection.ReturnValue;

SqlDataReader dr = cmd.ExecuteReader();

Conn.Close();

int c =Convert.ToInt32(cmd.Parameters["count"].Value); Response.Write(c.ToString());

在asp.net中执行存储过程(转)的更多相关文章

  1. Oracle中执行存储过程call和exec区别

    Oracle中执行存储过程call和exec区别 在sqlplus中这两种方法都可以使用: exec pro_name(参数1..); call pro_name(参数1..); 区别: 1. 但是e ...

  2. 在SQL Server数据库中执行存储过程很快,在c#中调用很慢的问题

    记录工作中遇到的问题,分享出来: 原博客地址:https://blog.csdn.net/weixin_40782680/article/details/85038281 今天遇到一个比较郁闷的问题, ...

  3. ASP.NET中调用存储过程方法

    两种不同的存储过程调用方法 为了突出新方法的优点,首先介绍一下在.NET中调用存储过程的“官方”方法.另外,本文的所有示例程序均工作于SqlServer数据库上,其它情况类似,以后不再一一说明.本文所 ...

  4. 转载MSDN 在ASP.NET 中执行 URL 重写

    转载文章原网址 http://msdn.microsoft.com/zh-cn/library/ms972974.aspx 摘要:介绍如何使用 Microsoft ASP.NET 执行动态 URL 重 ...

  5. Java中执行存储过程和函数(web基础学习笔记十四)

    一.概述 如果想要执行存储过程,我们应该使用 CallableStatement 接口. CallableStatement 接口继承自PreparedStatement 接口.所以CallableS ...

  6. C#中执行存储过程并在SQL server中调试

    1.编写存储过程 ) drop PROCEDURE [dbo].[sp_calcPci_of_baseRcd_GTmpTbl] CREATE PROCEDURE [dbo].[sp_calcPci_o ...

  7. Java中执行存储过程和函数

    装载于:http://www.cnblogs.com/liunanjava/p/4261242.html 一.概述 如果想要执行存储过程,我们应该使用 CallableStatement 接口. Ca ...

  8. EFCore 中执行存储过程返回DataSet DataTable

    在项目中由于需求,需要返回复杂的数据,需要执行存储过程,但是在DONETCORE2.0中,看官网文档执行的sql的有点操蛋,满足不了需求,就想到了ADO.NET 于是找资料,也没有合适的,就动手自己封 ...

  9. EF中执行存储过程,获取output返回值

    EF不能直接支持执行存储过程,于是使用转化成执行SQL语句的形式,却怎么也获取不到output的值,折腾的好久,终于解决了,分享下曲折的经历: public int AddVote(int title ...

随机推荐

  1. 自用广告过滤规则,整合xwhyc大大的,非常小才79K

    xwhyc大大 好久没更新了,自己弄了一点 更新: $third-party选项过滤多个站点的第三方广告:dy1000.com.yatu.tv,greasyfork.org 主流视频站点,请配合我的脚 ...

  2. git 经常使用操作集锦

    创建仓库 新建普通仓库: jxdong@ubuntu-server:~/workspace/git$ git init Reinitialized existing Git repository in ...

  3. jsonConfig使用方法

    1.先编写jsonConfig的初始化代码 private JsonConfig jsonConfig; public action构造方法() { jsonConfig = new JsonConf ...

  4. C# 模拟网站登陆

    实现此功能首先需要借助一些抓包工具,对相应的网站登陆过程进行分析,此过程根据网站的不同,可能复杂,也可能很简单.常用的抓包工具FF下FireBug和IE下的HttpWatch.这两个工具很强大,以此工 ...

  5. Git remotes/origin/pr/* 分支清理

    代码在gitHub上托管,每次git pull完后,用git branch -a都可以看到一堆remotes/origin/pr/*分支: 可以通过两种方式去除: 1,修改git的config文件找到 ...

  6. 【BZOJ】【3668】【NOI2014】起床困难综合症

    贪心 位运算的题……基本都是按位来做的?... 从高位到低位,贪心来搞就可以了…… 这都算不上是数位DP吧= = /****************************************** ...

  7. JavaBean示例

    例1.通过非可视化的JavaBean,封装邮箱地址对象,通过JSP页面调用该对象来验证邮箱地址是否合法. (1)创建名称为Email的JavaBean对象,用于封装邮箱地址,关键代码如下: packa ...

  8. Redis:ERR operation not permitted

    Redis服务开启之后: D:\Redis\redis>redis-server.exe redis.conf 那么另外开一个命令窗口 D:\Redis\redis>redis-cli.e ...

  9. Java主流Web Service框架介绍:CXF和Axis2

    CXF和Axis2是目前java平台上最主流的两个框架,虽然两个项目都隶属ASF,但却是基于不同思想和风格实现的,因此也各有所长.   CXF:http://cxf.apache.org/ 是由过去的 ...

  10. SparkMLlib分类算法之决策树学习

    SparkMLlib分类算法之决策树学习 (一) 决策树的基本概念 决策树(Decision Tree)是在已知各种情况发生概率的基础上,通过构成决策树来求取净现值的期望值大于等于零的概率,评价项目风 ...