//带参数的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. 【校招面试 之 C/C++】第6题 C++深拷贝与浅拷贝

    1.两个的区别(1)在未定义显示拷贝构造函数的情况下,系统会调用默认的拷贝函数——即浅拷贝,它能够完成成员的一一复制.当数据成员中没有指针时,浅拷贝是可行的: 但当数据成员中有指针时,如果采用简单的浅 ...

  2. Binary Tree Traversal 二叉树的前中后序遍历

    [抄题]:二叉树前序遍历 [思维问题]: 不会递归.三要素:下定义.拆分问题(eg root-root.left).终止条件 [一句话思路]: 节点非空时往左移,否则新取一个点 再往右移. [输入量] ...

  3. window.location.origin

    当前页面的域名+端口号 var HTTP_REMOTE = (function () { var origin = window.location.origin; if (origin.match(/ ...

  4. Jmeter的log输出控制

    Jmeter的log输出控制(jmeter.log) log_level.jmeter=ERROR log_level.jmeter.junit=DEBUG 在jmeter.properties中,修 ...

  5. 661. Image Smoother

    static int wing=[]() { std::ios::sync_with_stdio(false); cin.tie(NULL); ; }(); class Solution { publ ...

  6. 2018.06.27Going Home(二分图匹配)

    Going Home Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 24716 Accepted: 12383 Descript ...

  7. 2018.08.06 bzoj1503: [NOI2004]郁闷的出纳员(非旋treap)

    传送门 平衡树简单题. 直接用fhgtreap实现分裂和合并就没了. 代码: #include<bits/stdc++.h> #define N 100005 using namespac ...

  8. 19. Fight over Fox-hunting 猎狐引发的冲突

    . Fight over Fox-hunting 猎狐引发的冲突 ① Foxes and farmers have never got on well.These small dog-like ani ...

  9. 在windows7下创建ftp服务站点

    1.开始->控制面板->程序(点击“卸载程序”)->启动或关闭windows功能->Internet Information Services(Internet信息服务)-&g ...

  10. 字典树Java实现

    Trie树的原理 Trie树也称字典树,因为其效率很高,所以在在字符串查找.前缀匹配等中应用很广泛,其高效率是以空间为代价的. 利用串构建一个字典树,这个字典树保存了串的公共前缀信息,因此可以降低查询 ...