.netADO调用存储过程

1、vb调用存储过程

Try
      sqlcon.Open()
	Dim cmd As New SqlCommand()
	cmd.Connection = con
	cmd.CommandType = CommandType.StoredProcedure
	cmd.CommandText = "addUser"

	Dim param As New SqlParameter()
	param.ParameterName = "@ID"
	param.Value = txtID.Text.Trim()
	cmd.Parameters.Add(param)

	param = New SqlParameter("@Name", txtName.Text.Trim())
	cmd.Parameters.Add(param)

	param = New SqlParameter()
	param.ParameterName = "@Sex"
	param.Value = txtSex.Text.Trim()
	cmd.Parameters.Add(param)

	'da.InsertCommand = cmd;

	If cmd.ExecuteNonQuery() = 1 Then
		MessageBox.Show("添加成功")
	Else
		MessageBox.Show("失败")
	End If
Catch ex As SqlException
	MessageBox.Show(ex.Message)
  Finally 
      If sqlcon.State = ConnectionState.Open Then 
          sqlcon.Close()          
      End If
End Try

 

 以下是C#关于存储过程的执行:

 一: 执行不带返回参数(Input)的存储过程
           1: 首先在数据库写个存储过程, 如创建个 addUser存储过程。
                  Create Proc addUser
                  @ID int,
                  @Name varchar(20),
                  @Sex varchar(20)
                  As
                  Insert Into Users Values( @ID, @Name,@Sex )


           2:创建SqlCommand对象,并初始SqlCommand对象 如:
              SqlCommand cmd = new SqlCommand( );
              cmd.CommandText = "addUser";     // 制定调用哪个存储过程
              cmd.CommandType = CommandType.StoredProcedure;     // 制定Sql命令类型是存储过程, 默认的为Sql语句。
              cmd.Connection = con;    // 设定连接

           3:向SqlCommand对象添加存储过程参数
             SqlParameter param = new SqlParameter( );   // 定义一个参数对象
             param.ParameterName = "@ID";                    // 存储过程参数名称
             param.Value = txtID.Text.Trim();                   // 该参数的值
             cmd.Parameters.Add( param );                        // SqlCommand对象添加该参数对象

             param = new SqlParameter( "@Name", txtName.Text.Trim() );  // 简写方式
             cmd.Parameters.Add( param );

            4:SqlCommand对象调用执行Sql的函数。 如:
                  cmd.ExecuteNonQuery();
         

二:执行带返回参数(Output)的存储过程
            1: 首先在数据库写个存储过程, 如创建个 queryUser存储过程。
                alter Proc queryUser
               @ID int,
               @Suc varchar(10) output
               As
               select @Suc = 'false'
               if exists( Select * From users where u_id = @ID )
                       select @Suc = 'success'

            2:创建SqlCommand对象,并初始SqlCommand对象 如:
              SqlCommand cmd = new SqlCommand( );
              cmd.CommandText = "queryUser";     // 制定调用哪个存储过程
              cmd.CommandType = CommandType.StoredProcedure;     // 制定Sql命令类型是存储过程, 默认的为Sql语句。
              cmd.Connection = con;    // 设定连接

            3:向SqlCommand对象添加存储过程参数
               SqlParameter param1 = new SqlParameter( "@ID", txtID.Text );   // 添加输入参数
               cmd.Parameters.Add( param1 );

               SqlParameter param2 = new SqlParameter();         // 添加输出参数
               param2.ParameterName = "@Suc";                       // 名称
               param2.SqlDbType = SqlDbType.VarChar;         // 输出参数的Sql类型
               param2.Size = 10;                                                   // 输出参数的Sql类型大小
               param2.Direction = ParameterDirection.Output;  // 指定该参数对象为输出参数类型
               cmd.Parameters.Add( param2 );

            4:SqlCommand对象调用执行Sql的函数。 如:
                  cmd.ExecuteNonQuery();
                  MessageBox.Show( param2.Value.ToString() );  // 输出输出参数的值

posted @ 2013-12-29 21:03  ps十一郎  阅读(193)  评论(0编辑  收藏  举报