//带参数的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#存储过程调用的三个方法的更多相关文章

  1. 获取SqlServer存储过程定义的三种方法

    declare @p_text varchar(max) SELECT @p_text= text FROM syscomments WHERE id = ( SELECT id FROM sysob ...

  2. 使用游标、存储过程、pivot 三种方法导入数据

    --使用游标循环 if (exists (select * from sys.objects where name = 'Base_RecordTend_Test')) drop proc Base_ ...

  3. ORACLE存储过程调用Web Service

    1. 概述 最近在ESB项目中,客户在各个系统之间的服务调用大多都是在oracle存储过程中进行的,本文就oracle存储过程调用web service来进行说明.其他主流数据库,比如mysql和sq ...

  4. C# 中如何判断某个字符串是否为空的方法 分享了三个方法来判断字

    1. 三种常用的字符串判空串方法:Length法:bool isEmpty = (str.Length == 0);Empty法:bool isEmpty = (str == String.Empty ...

  5. SpringBoot2.0.2 Application调用的三种方式

    一.注解 @SpringBootApplication            点开查看源码是由多个注解合成的注解,其中主要的注解有:            @SpringBootConfigurati ...

  6. Jquery如何序列化form表单数据为JSON对象 C# ADO.NET中设置Like模糊查询的参数 从客户端出现小于等于公式符号引发检测到有潜在危险的Request.Form 值 jquery调用iframe里面的方法 Js根据Ip地址自动判断是哪个城市 【我们一起写框架】MVVM的WPF框架(三)—数据控件 设计模式之简单工厂模式(C#语言描述)

    jquery提供的serialize方法能够实现. $("#searchForm").serialize();但是,观察输出的信息,发现serialize()方法做的是将表单中的数 ...

  7. YbSoftwareFactory 代码生成插件【二十五】:Razor视图中以全局方式调用后台方法输出页面代码的三种方法

    上一篇介绍了 MVC中实现动态自定义路由 的实现,本篇将介绍Razor视图中以全局方式调用后台方法输出页面代码的三种方法. 框架最新的升级实现了一个页面部件功能,其实就是通过后台方法查询数据库内容,把 ...

  8. java 调用 C# 类库搞定,三步即可,可以调用任何类及方法,很简单,非常爽啊

    java 调用 C# 类库搞定,三步即可,可以调用任何类及方法,很简单,非常爽啊 java 调用 C# 类库搞定,可以调用任何类及方法,很简单,非常爽啊 总体分三步走: 一.准备一个 C# 类库 (d ...

  9. 三种dedecms调用相关文章的方法

    在文章的末尾或侧边栏添加相关文章可以提高用户的黏度,提高pv,增加se的好印象(哈哈),那么dedecms如何调用相关文章呢?有三种方法可以实现. 第一种dedecms调用相关文章的方法,用默认的li ...

随机推荐

  1. 5.Longest Palindromic Substring (String; DP, KMP)

    Given a string S, find the longest palindromic substring in S. You may assume that the maximum lengt ...

  2. django的流程分析

    首先实现一个前端输入网址,后端返回不同的html文件的步骤 一.配置django 1.创建工程 2.创建app 二.配置setting 1.配置templates路径 2.注释跨站请求 三.配置pro ...

  3. 找峰值I II · Find Peak Element I ii

    一句话思路:找最大的元素.没有target? 一刷报错: 一定要用二分,否则复杂度不是最优. 判断条件是nums[mid] < nums[mid + 1],还是基于中位数比较的原理.不是nums ...

  4. Mac 终端便利工具: 管理工具-Homebrew 和提示工具oh my zsh

    命令行提示工具 第一步: Homebrew - 安装与使用 https://blog.csdn.net/sir_coding/article/details/77509602 Homebrew安装问题 ...

  5. php Pthread 多线程 (一) 基本介绍

    我们可以通过安装Pthread扩展来让PHP支持多线程.   线程,有时称为轻量级进程,是程序执行的最小单元.线程是进程中的一个实体,是被系统独立调度和分派的基本单位,线程自己不拥有系统资源,它与同属 ...

  6. C#开发中常用加密解密方法解析

    一.MD5加密算法 我想这是大家都常听过的算法,可能也用的比较多.那么什么是MD5算法呢?MD5全称是message-digest algorithm 5,简单的说就是单向的加密,即是说无法根据密文推 ...

  7. 【SQL模板】二.创建表视图模板TSQL

    ---Name: 创建表视图模板.sql ---Purpose: 用于创建 数据库中 新的数据表/视图 ---Author: xx ---Time: 2015-12-18 10:26:06 ---Re ...

  8. python yaml

    一.安装PyYAML http://pyyaml.org/ 二.入门参考 http://www.cnblogs.com/c9com/archive/2013/01/05/2845539.html ht ...

  9. Loadrunner12.5-同一个网址通过vugen不能打开,但是直接在ie11中就可以打开

    一:录制选项修改成“WinINet级别数据”,重新录制就可以成功打开网页了. 注:运行时设置--首选项--高级--“使用WinINet回放而非套接字(仅限Windows)”需要勾选上:否则录制脚本结束 ...

  10. php调用C#写的dll包

    1.转到需要注册的dll路径下 2.输入regasm命令+文件名 3问题解决