SQL Server 存储过程



(1) 如何查找数据库中的存储过程:select * from sysobjects where xtype='P'。

(2) ASP.NET如何执行存储过程:【转载于贝壳专栏http://blog.csdn.net/dxnn520/article/details/8023458

  1. ASP.NET执行存储过程  
  2. 一. 执行一个没有参数的存储过程的代码如下:  
  3. connectionString为连接字符串  
  4. SqlConnection conn=new SqlConnection(connectionString);   
  5. SqlDataAdapter da = new SqlDataAdapter();  
  6. da.SelectCommand = new SqlCommand();  
  7. da.SelectCommand.Connection = conn;  
  8. //myProc存储过程的名字  
  9. da.SelectCommand.CommandText = "myProc";  
  10. da.SelectCommand.CommandType = CommandType.StoredProcedure;   
  11.   
  12. 二. 执行一个有参数的存储过程的代码如下  
  13. SqlConnection conn=new SqlConnection(connectionString);   
  14. SqlDataAdapter da = new SqlDataAdapter();   
  15. da.selectCommand = new SqlCommand();   
  16. da.selectCommand.Connection = conn;   
  17. da.selectCommand.CommandText = "NameOfProcedure";   
  18. da.selectCommand.CommandType = CommandType.StoredProcedure;   
  19. param = new SqlParameter("@ParameterName", SqlDbType.DateTime);   
  20. param.Direction = ParameterDirection.Input;   
  21. param.Value = Convert.ToDateTime(inputdate);   
  22. da.selectCommand.Parameters.Add(param);   
  23. 若需要添加输出参数:   
  24.   
  25. param = new SqlParameter("@ParameterName", SqlDbType.DateTime);   
  26. param.Direction = ParameterDirection.Output;   
  27. param.Value = Convert.ToDateTime(inputdate);   
  28. da.selectCommand.Parameters.Add(param);   
  29. 若要获得参储过程的返回值:   
  30.   
  31. param = new SqlParameter("@ParameterName", SqlDbType.DateTime);   
  32. param.Direction = ParameterDirection.ReturnValue;   
  33. param.Value = Convert.ToDateTime(inputdate);   
  34. da.selectCommand.Parameters.Add(param);  
  35.   
  36.    
  37.   
  38. try  
  39.     {  
  40.      //****进行数据连接****//  
  41.      string conString="server=localhost;database=stuDB;uid=sa";//连接串  
  42.      SqlConnection sqlConnection=new SqlConnection(conString);//创建连接对象  
  43.      sqlConnection.Open();//打开连接  
  44.      SqlCommand sqlCommand=new SqlCommand();//创建SqlCommand命令对象  
  45.      sqlCommand.Connection=sqlConnection;//SqlCommand命令对象的连接属性赋值  
  46.      sqlCommand.CommandType=CommandType.StoredProcedure;//**************命令对象的类型为执行数据库的存储过程***********  
  47.      string sql = string.Format("proc_insert_stuClass");//Sql语句为数据库的存储过程  
  48.      sqlCommand.CommandText=sql;//命令文本  
  49.       
  50.      //****设置存储过程的参数****//  
  51.      SqlParameter sp1=new SqlParameter("@outcome",SqlDbType.Bit);//创建参数对象,并设置@outcome参数的类型为Bit类型  
  52.      sp1.Direction=System.Data.ParameterDirection.Output;//设置此项参数的类型为输出参数  
  53.      sqlCommand.Parameters.Add(sp1);//将此项参数添加到命令参数集  
  54.   
  55.        SqlParameter sp=new SqlParameter("@classNo",SqlDbType.VarChar);  
  56.      sp.Direction=System.Data.ParameterDirection.Input;//设置此项参数的类型为输入参数  
  57.      sp.Value=this.textBox1.Text;//给输入参数赋值  
  58.      sqlCommand.Parameters.Add(sp);  
  59.   
  60.      sp=new SqlParameter("@classCount",SqlDbType.Int);  
  61.      sp.Direction=System.Data.ParameterDirection.Input;//设置此项参数的类型为输入参数  
  62.      sp.Value=this.textBox2.Text;//给输入参数赋值  
  63.      sqlCommand.Parameters.Add(sp);  
  64.   
  65.      sp=new SqlParameter("@classTeacher",SqlDbType.VarChar);  
  66.      sp.Direction=System.Data.ParameterDirection.Input;//设置此项参数的类型为输入参数  
  67.      sp.Value=this.textBox3.Text;//给输入参数赋值  
  68.      sqlCommand.Parameters.Add(sp);  
  69.   
  70.      sp=new SqlParameter("@classNote",SqlDbType.VarChar);  
  71.      sp.Direction=System.Data.ParameterDirection.Input;//设置此项参数的类型为输入参数  
  72.      sp.Value=this.textBox4.Text;//给输入参数赋值  
  73.      sqlCommand.Parameters.Add(sp);  
  74.   
  75.      //****执行存储过程****//  
  76.      sqlCommand.ExecuteNonQuery();//执行存储过程  
  77.      string outcome=sp1.Value.ToString();//将输出参数的值取出  
  78.                 Console.WriteLine(outcome);  
  79.     }  
  80.     catch(Exception ex)  
  81.     {  
  82.       MessageBox.Show(ex.Message);  
  83.     }  

(3) 知道存储过程应该是保存在某个表里,如何可以从那个表一次性取到全部存储过程的详细内容????

SELECT sysobjects.name,text FROM syscomments ,sysobjects
WHERE syscomments.id =sysobjects.id
结果中,name栏为存储过程名,text栏为存储过程内容。

(4) 如何进行查看存储过程的所有:【如图所示】:在对应数据库下,》可编程性》存储过程。。。。。。

(5) 如何查看存储过程的具体代码内容:

【如图所示】:在对应数据库下,》可编程性》存储过程》,找到对应的存储过程,单击鼠标右键,选择“编写存储过程脚本为(s)”》选择“CREAT到(c)”》“新查询编辑器窗口”即可。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值