using System.Data.SqlClient;
//如果存储过程没有输入和输出参数,而且不返回查询结果 SqlCommand cmd = new SqlCommand("存储过程名", conn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.ExecuteNonQuery();
                         //如果存储过程带输入参数

   SqlCommand cmd = new SqlCommand("存储过程名", conn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add(new SqlParameter("存储过程输入参数变量名", 数据类型));
//如cmd.Parameters.Add(new SqlParameter("@riqi", SqlDbType.DateTime, 8));
//把具体的值传给输入参数
cmd.Parameters["存储过程输入参数"].Value =具体的值;
//如cmd.Parameters["@riqi"].Value = this.textBox1.Text;
//执行存储过程
cmd.ExecuteNonQuery();
                           //如果存储过程带输出参数

   SqlCommand cmd = new SqlCommand("存储过程名", conn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add(new SqlParameter("存储过程输出参数变量名", 数据类型));
cmd.Parameters["存储过程输出参数变量名"].Direction = ParameterDirection.Output;
cmd.ExecuteNonQuery();
//显示输出参数的值cmd.Parameters["存储过程输出参数变量名"].Value
//如this.textBox3.Text = cmd.Parameters["@ItemCount"].Value.ToString();
                          //如果存储过程带输出和输出参数

   SqlCommand cmd = new SqlCommand("存储过程名", conn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add(new SqlParameter("存储过程输入参数变量名", 数据类型));
cmd.Parameters["存储过程输入参数"].Value =具体的值;
cmd.Parameters.Add(new SqlParameter("存储过程输出参数变量名", 数据类型));
cmd.Parameters["存储过程输出参数变量名"].Direction = ParameterDirection.Output;
cmd.ExecuteNonQuery();
//显示输出参数的值cmd.Parameters["存储过程输出参数变量名"].Value
//如this.textBox3.Text = cmd.Parameters["@ItemCount"].Value.ToString();
调用带输入参数的存储过程

【例2】创建存储过程AddNewCategory实现往Category表中添加新的商品类别,新的商品分类名称CategoryName作为输入参数输入。
CREATE PROCEDURE AddNewCategory
(@categoryName nvarchar(50))
AS
INSERT INTO Category (CategoryName) VALUES (@categoryName)
【例】调用上述存储过程AddNewCategory
try
{
// 数据库连接字符串
string connStr = "server=localhost;uid=sa;pwd=;database=eshop";
// 创建Connection 对象
SqlConnection conn = new SqlConnection(connStr);
// 打开数据库连接
conn.Open(); SqlCommand cmd = new SqlCommand("AddNewCategory", conn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add(new SqlParameter("@categoryName", SqlDbType.NVarChar,50));
cmd.Parameters["@categoryName"].Value = this.textBox1.Text;
cmd.ExecuteNonQuery();
MessageBox.Show("插入成功");
} catch
{
MessageBox.Show("操作不成功");
return;
}
                               调用带输入和输出参数的存储过程

【例1】创建存储过程ShoppingCartItemCount获取某购物车中购物种数并作为输出参数输出,购物车编号CartID为输入参数。
CREATE Procedure [dbo].[ShoppingCartItemCount]
( @CartID nvarchar(50),
@ItemCount int OUTPUT
)
AS
SELECT @ItemCount = COUNT(ProductID) FROM ShoppingCart
WHERE CartID = @CartID
【例】调用上述存储过程ShoppingCartItemCount
try
{
// 数据库连接字符串
string connStr = "server=localhost;uid=sa;pwd=;database=eshop";
// 创建Connection 对象
SqlConnection conn = new SqlConnection(connStr);
// 打开数据库连接
conn.Open(); SqlCommand cmd = new SqlCommand("ShoppingCartItemCount", conn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add(new SqlParameter("@CartID", SqlDbType.NVarChar,50));
cmd.Parameters["@CartID"].Value = this.textBox2.Text;
cmd.Parameters.Add(new SqlParameter("@ItemCount",SqlDbType.Int));
cmd.Parameters["@ItemCount"].Direction = ParameterDirection.Output;
cmd.ExecuteNonQuery();
//显示输出参数的值cmd.Parameters["存储过程输出参数变量名"].Value
this.textBox3.Text = cmd.Parameters["@ItemCount"].Value.ToString(); } catch
{ MessageBox.Show("操作不成功");
return;
}

实际例子:

 string constr = "server=192.168.9.111;database=111;uid=sa;pwd=1111234";
using(SqlConnection conn=new SqlConnection(constr))
{
conn.Open(); using (SqlCommand cmd = new SqlCommand("p_pageSelect", conn))
{
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add(new SqlParameter("@num", SqlDbType.Int));
cmd.Parameters.Add(new SqlParameter("@tableName", SqlDbType.NVarChar, 50));
cmd.Parameters.Add(new SqlParameter("@startNum", SqlDbType.Int)); cmd.Parameters["@num"].Value = this.tbNum.Text;
cmd.Parameters["@tableName"].Value = this.cmbTableName.Text;
cmd.Parameters["@startNum"].Value = this.tbStartNum.Text;
SqlDataAdapter sda = new SqlDataAdapter(cmd);
DataSet ds = new DataSet(); sda.Fill(ds);
dgvData.DataSource= ds.Tables[0]; }
}

最新文章

  1. 【Leetcode-Mysql】Trips and Users
  2. python chinese code
  3. Bootstrap中文参考手册
  4. .NET单例模式-------各种写法&&验证
  5. Spring boot 整合jsp和tiles模板
  6. MySQL中的datetime与timestamp比较
  7. web前端安全相关
  8. javascript函数值的重写
  9. 无法打开登录 'ASPState' 中请求的数据库。登录失败。
  10. Mr.聂 带你成为web开发大牛——入门篇(上)
  11. 一个栗子上手CSS3动画
  12. JavaWeb(四)JDBC操作Oracle
  13. Linux的常用命令(1) - 指定运行级别
  14. angular 遍历foreach
  15. python之路--初识html前端
  16. C# PointToScreen
  17. H5视频推流方案
  18. 不用登陆密码也能进路由器,适用于TP、磊科、腾达
  19. C语言文件实现学生成绩管理
  20. npp基本设置

热门文章

  1. Vulkan Tutorial 01 开发环境搭建之Windows
  2. laravel框架容器管理的一些要点(转)
  3. zookeeper更进一步(数据模型、watcher及shell命令)
  4. solrcloud上传collection配置
  5. id 和 instancetype 方法的区别
  6. SpringBoot22 Ajax跨域、SpringBoot返回JSONP、CSRF、CORS
  7. Python 安装selenium
  8. 8.INSERT INTO 语句 UPDATE 语句
  9. 关于instanceof测试遇到的问题
  10. struct stat中的mode_t