C#存储过程调用的三个方法
//带参数的SQL语句
private void sql_param()
{
SqlConnection conn = new SqlConnection("server=WIN-OUD59R7EHCH;uid=sa;pwd=123456;database=china");
string sql = "select *from test where uid=@myid";
SqlCommand comm = new SqlCommand(sql,conn);
SqlParameter sp = comm.Parameters.Add("@myid",SqlDbType.Int);
sp.Value = ;
comm.CommandType = CommandType.Text;
SqlDataAdapter sda = new SqlDataAdapter(comm);
DataSet ds = new DataSet();
sda.Fill(ds,"test");
this.dataGridView1.DataSource = ds.Tables[];
} //标准的存储过程
private void sql_proc()
{
SqlConnection conn = new SqlConnection("server=WIN-OUD59R7EHCH;uid=sa;pwd=123456;database=china");
conn.Open();
string sql = "proc_out";
SqlCommand comm = new SqlCommand(sql, conn);
//将Command执行类型改为存储过程的方式,默认为Text
comm.CommandType = CommandType.StoredProcedure;
//传递一个输入参数,需要赋值
SqlParameter sp = comm.Parameters.Add("@uid",SqlDbType.Int);
sp.Value = ;
//定义一个输出参数,不许需要赋值。Direction用来描述参数的类型
//Direction默认为输入参数,还有输出参数和返回值
sp = comm.Parameters.Add("@output",SqlDbType.VarChar,);
sp.Direction = ParameterDirection.Output;
/*定义过程的返回值参数,过程执行完之后,将把过程的返回值
* 赋给myreturn的Parameters赋值
*/
sp = comm.Parameters.Add("myreturn",SqlDbType.Int);
sp.Direction = ParameterDirection.ReturnValue;
/*使用SqlDataAdapter将自动完成数据库的打开和关闭过程,
* 并将执行t-sql语句或存储过程
*
* 如果存储过程只是执行相关操作,如级联删除或者更新,
* 使用sqlcommand的execute方法即可
*
*/
try
{
SqlDataAdapter sda = new SqlDataAdapter(comm);
DataSet ds = new DataSet();
comm.ExecuteNonQuery();
//在执行完存储过程之后,可得到输出参数
string myout = comm.Parameters["@output"].Value.ToString();
//打印输出参数
MessageBox.Show("打印输出参数:" + myout);
//打印存储过程返回值
myout = comm.Parameters["myreturn"].Value.ToString();
MessageBox.Show("存储过程返回值:" + myout); sda.Fill(ds, "test");
this.dataGridView1.DataSource = ds.Tables[];
}
catch (Exception e)
{
MessageBox.Show(e.Message);
}
finally
{
conn.Close();
} } //简易的存储过程的使用
private void jyc()
{
SqlConnection conn = new SqlConnection("server=WIN-OUD59R7EHCH;uid=sa;pwd=123456;database=china");
string sql = "execute proc_out 1,'12'";
SqlCommand comm = new SqlCommand(sql,conn);
SqlDataAdapter da = new SqlDataAdapter(comm);
DataSet ds = new DataSet();
da.Fill(ds,"test");
this.dataGridView1.DataSource = ds.Tables[]; }
存储过程
create proc proc_out @uid int,@output varchar() output as
--select结果集
select *from test where uid=@uid
set @output = '记录总数:'+convert(varchar(),(select count(*) from test))
return ;
go
C#存储过程调用的三个方法的更多相关文章
- 获取SqlServer存储过程定义的三种方法
declare @p_text varchar(max) SELECT @p_text= text FROM syscomments WHERE id = ( SELECT id FROM sysob ...
- 使用游标、存储过程、pivot 三种方法导入数据
--使用游标循环 if (exists (select * from sys.objects where name = 'Base_RecordTend_Test')) drop proc Base_ ...
- ORACLE存储过程调用Web Service
1. 概述 最近在ESB项目中,客户在各个系统之间的服务调用大多都是在oracle存储过程中进行的,本文就oracle存储过程调用web service来进行说明.其他主流数据库,比如mysql和sq ...
- C# 中如何判断某个字符串是否为空的方法 分享了三个方法来判断字
1. 三种常用的字符串判空串方法:Length法:bool isEmpty = (str.Length == 0);Empty法:bool isEmpty = (str == String.Empty ...
- SpringBoot2.0.2 Application调用的三种方式
一.注解 @SpringBootApplication 点开查看源码是由多个注解合成的注解,其中主要的注解有: @SpringBootConfigurati ...
- Jquery如何序列化form表单数据为JSON对象 C# ADO.NET中设置Like模糊查询的参数 从客户端出现小于等于公式符号引发检测到有潜在危险的Request.Form 值 jquery调用iframe里面的方法 Js根据Ip地址自动判断是哪个城市 【我们一起写框架】MVVM的WPF框架(三)—数据控件 设计模式之简单工厂模式(C#语言描述)
jquery提供的serialize方法能够实现. $("#searchForm").serialize();但是,观察输出的信息,发现serialize()方法做的是将表单中的数 ...
- YbSoftwareFactory 代码生成插件【二十五】:Razor视图中以全局方式调用后台方法输出页面代码的三种方法
上一篇介绍了 MVC中实现动态自定义路由 的实现,本篇将介绍Razor视图中以全局方式调用后台方法输出页面代码的三种方法. 框架最新的升级实现了一个页面部件功能,其实就是通过后台方法查询数据库内容,把 ...
- java 调用 C# 类库搞定,三步即可,可以调用任何类及方法,很简单,非常爽啊
java 调用 C# 类库搞定,三步即可,可以调用任何类及方法,很简单,非常爽啊 java 调用 C# 类库搞定,可以调用任何类及方法,很简单,非常爽啊 总体分三步走: 一.准备一个 C# 类库 (d ...
- 三种dedecms调用相关文章的方法
在文章的末尾或侧边栏添加相关文章可以提高用户的黏度,提高pv,增加se的好印象(哈哈),那么dedecms如何调用相关文章呢?有三种方法可以实现. 第一种dedecms调用相关文章的方法,用默认的li ...
随机推荐
- day12:vcp考试
Q221. An administrator is creating a new Platform Service Controller Password Policy with the follow ...
- Microsoft SQL Server, 错误:4064的解决方法 (转载)
SQL SERVER – Fix : Error: 4064 – Cannot open user default database. Login failed. Login failed for u ...
- Linux CentOS6.6 NFS服务的配置与安装
一.简介 NFS(Network File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源.在NFS的应用中,本地NFS的客 ...
- 源码安装php时出现configure: error: xml2-config not found. Please check your libxml2 installation
1.检查是否安装了libxml 包 > rpm -qa|grep libxml2 2.如果没有则安装 > yum install libxml2 > yum install libx ...
- centos一键安装lnmp成功后无法访问ip(解决办法)
自己搞了个服务器 (我的服务器网络类型是 专有网络)如下图点击 配置规则 进入到 进.出端口规则配置 点击添加安全组规则 如图所配置 添加完成后 就如下面所示 (配置完成后 通过ip就已经可以访问了 ...
- [Fiddler] 开启Fiddler抓包的时候产品报“证书错误”
报错截图: 解决办法:同时开启产品和Fiddler,做如下处理:
- Java数据结构和算法(二)树的基本操作
Java数据结构和算法(二)树的基本操作 数据结构与算法目录(https://www.cnblogs.com/binarylei/p/10115867.html) 一.树的遍历 二叉树遍历分为:前序遍 ...
- 负值之美:负margin在页面布局中的应用
本文转载自:http://www.topcss.org/?p=94,有修改. 负数给人总是一种消极.否定.拒绝之感,不过有时利用负margin可以达到奇妙的效果,今天就表一表负值在页面布局中的应用.这 ...
- 《Just for Fun》---读后感
<Just for Fun>本书是Linux之父林纳斯自传,书名的意思是:只是为了好玩.主要是讲了林纳斯的人生经历,以及Linux的诞生过程.Linux从一个终端仿真器到一个世界瞩目的操作 ...
- 2018.10.22 bzoj1009: [HNOI2008]GT考试(kmp+矩阵快速幂优化dp)
传送门 f[i][j]f[i][j]f[i][j]表示从状态"匹配了前i位"转移到"匹配了前j位"的方案数. 这个东西单次是可以通过跳kmp的fail数组得到的 ...