C#--使用存储过程
过程:
1、连接数据库
2、设置执行类型为存储过程,区别于SQL语句
3、得到执行结果,返回值、输出参数等
//连接数据库
string connstr = "Data Source=ZGC-20131104001;Initial Catalog=JvJin;Integrated Security=True";
SqlConnection sqlconn = new SqlConnection(connstr);
string cmdtext = "getstu2";//设置执行的文本为存储过程名
SqlCommand sqlcom = new SqlCommand(cmdtext, sqlconn);
sqlcom.CommandType =CommandType.StoredProcedure;//设置执行命令类型是存储过程,而不是SQL语句
///设置输入参数,输出参数,和返回值,输出参数和返回值的得到都需要由SqlCommand对象的参数来保存
sqlcom.Parameters.Add("@id", SqlDbType.VarChar,); //输入参数,有默认值的,不用再添加值
sqlcom.Parameters.Add("@name", SqlDbType.VarChar, );//输入参数,没有默认值,后面要添加输入值
sqlcom.Parameters.Add("@class", SqlDbType.VarChar, );//output类型的参数,输出参数,用来接收输出的数据
sqlcom.Parameters.Add("ret", SqlDbType.SmallInt);//这个参数来接收返回值 sqlcom.Parameters["@name"].Value = "";
sqlcom.Parameters["@class"].Direction = ParameterDirection.Output;//为输出参数的设置
sqlcom.Parameters["ret"].Direction = ParameterDirection.ReturnValue;//为返回值的设置
sqlconn.Open();
SqlDataReader datareader= sqlcom.ExecuteReader();
datareader.Read();//取一行数据
dataGridView1.Rows.Add(new string[] { datareader.GetString(), datareader.GetString(), datareader.GetString() });
sqlconn.Close();
//只在关闭连接后才能进行得到数据
textBox1.Text = sqlcom.Parameters["@class"].Value.ToString();
textBox1.Text += "\r\n" + sqlcom.Parameters["ret"].Value.ToString();
/*
注意要点:1,设置参数类型(输出参数,返回值),如果是输入参数不需要设置类型
* 2,在关闭连接后,才能接收返回值和输出参数,
* 3,输入参数是设置值
*/
C#--使用存储过程的更多相关文章
- 将表里的数据批量生成INSERT语句的存储过程 增强版
将表里的数据批量生成INSERT语句的存储过程 增强版 有时候,我们需要将某个表里的数据全部或者根据查询条件导出来,迁移到另一个相同结构的库中 目前SQL Server里面是没有相关的工具根据查询条件 ...
- Dapper逆天入门~强类型,动态类型,多映射,多返回值,增删改查+存储过程+事物案例演示
Dapper的牛逼就不扯蛋了,答应群友做个入门Demo的,现有园友需要,那么公开分享一下: 完整Demo:http://pan.baidu.com/s/1i3TcEzj 注 意 事 项:http:// ...
- MySQL主从环境下存储过程,函数,触发器,事件的复制情况
下面,主要是验证在MySQL主从复制环境下,存储过程,函数,触发器,事件的复制情况,这些确实会让人混淆. 首先,创建一张测试表 mysql),age int); Query OK, rows affe ...
- mysql进阶之存储过程
往往看别人的代码会有这样的感慨: 看不懂 理还乱 是离愁 别是一番滋味在心头 为什么要使用存储过程? 在mysql开发中使用存储过程的理由: 当希望在不同的应用程序或平台上执行相同的函数,或者封装特定 ...
- MySQL 系列(三)你不知道的 视图、触发器、存储过程、函数、事务、索引、语句
第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...
- 参数探测(Parameter Sniffing)影响存储过程执行效率解决方案
如果SQL query中有参数,SQL Server 会创建一个参数嗅探进程以提高执行性能.该计划通常是最好的并被保存以重复利用.只是偶尔,不会选择最优的执行计划而影响执行效率. SQL Server ...
- MSSQL 事务,视图,索引,存储过程,触发器
事务 事务是一种机制.是一种操作序列,它包含了一组数据库操作命令,这组命令要么全部执行,要么全部不执行. 在数据库系统上执行并发操作时事务是作为最小的控制单元来使用的.这特别适用于多用户同时操作的数据 ...
- Mysql - 存储过程/自定义函数
在数据库操作中, 尤其是碰到一些复杂一些的系统, 不可避免的, 会用到函数/自定义函数, 或者存储过程. 实际项目中, 自定义函数和存储过程是越少越好, 因为这个东西多了, 也是一个非常难以维护的地方 ...
- SQL Server存储过程
创建于2016-12-24 16:12:19 存储过程 概念: 1.存储过程是在数据库管理系统中保存的.预先编译的.能实现某种功能的SQL程序,它是数据库应用中运用比较广泛的 一种数据对象. 2.存储 ...
- SQL Server 批量删除存储过程
原理很简单的'drop proc xxx'即可,下面有提供了两种方式来删除存储过程,其实本质是相同的,方法一是生成删除的sql后直接执行了,方法二会生成SQL,但需要检查后执行,个人推荐第二种做法. ...
随机推荐
- git 常用命令使用
1. 初始化仓库 git init 2. 查看当前状态 git status(1)Changes not staged for commit:(2)Changes to be committed: 3 ...
- 【BZOJ 2818】gcd 欧拉筛
枚举小于n的质数,然后再枚举小于n/这个质数的Φ的和,乘2再加1即可.乘2是因为xy互换是另一组解,加1是x==y==1时的一组解.至于求和我们只需处理前缀和就可以啦,注意Φ(1)的值不能包含在前缀和 ...
- 关于二叉排序树 BST
#include<stdio.h> #include<stdlib.h> typedef struct node { double w; struct node *l,*r; ...
- oracle 知识
sqlplus / as sysdba; 使用操作系统登录oracle数据库 conn panie/panie; 使用普通用户连接数据库 --开启归档模式shutdown immediate;s ...
- js-处理千分符
<html> <head> <title> JS千分位处理 </title> </head> <script> functi ...
- json:There is a cycle in the hierarchy!
在使用JSONObject.fromObject的时候,出现“There is a cycle in the hierarchy”异常. 意思是出现了死循环,也就是Model之间有循环包含关系: 解决 ...
- socket入门
结构图如下 一个套接字就是socket模块中的socket类的一个实例.实例化时需要3个参数 地址族:默认(socket.AF_INET) 流:默认(socket.SOCK_STREAM) 或数据报 ...
- 【bzoj2190】 SDOI2008—仪仗队
http://www.lydsy.com/JudgeOnline/problem.php?id=2190 (题目链接) 题意 一个N*N的方阵,问右下角的人能看到几个人. Solution 如果一个人 ...
- Linux修改密码passwd用法
语法: passwd [-k] [-l] [-u [-f]] [-d] [-S] [username] 必要参数:-d 删除密码-f 强制执行-k 更新只能发送在过期之后-l 停止账号使用-S 显示密 ...
- 洛谷P3398 仓鼠找sugar
题目描述 小仓鼠的和他的基(mei)友(zi)sugar住在地下洞穴中,每个节点的编号为1~n.地下洞穴是一个树形结构.这一天小仓鼠打算从从他的卧室(a)到餐厅(b),而他的基友同时要从他的卧室(c) ...