随笔 - 149  文章 - 8  评论 - 248  阅读 - 21万

带返回值的存储过程

当用户注册表单的时候,需要返回用户注册后的ID,这时候用存储过程的Output很方便。
后台代码:

复制代码
public partial class _Default : System.Web.UI.Page
{
    
string SqlConnectionString = "Server=(local);Initial Catalog=dbtest;Integrated Security=True";

    
protected void Page_Load(object sender, EventArgs e)
    {

    }
    
protected void btnSubmit_Click(object sender, EventArgs e)
    {
        SqlConnection con 
= new SqlConnection(SqlConnectionString);
        
using (SqlCommand com = new SqlCommand())
        {
            
try
            {
                con.Open();
                com.Connection 
= con;
                com.CommandType 
= CommandType.StoredProcedure;
                com.CommandText 
= "add_users";
                com.Parameters.Add(
"@User_Name", SqlDbType.VarChar, 20);
                com.Parameters[
"@User_Name"].Value = this.txtUser.Text;
                com.Parameters.Add(
"@Pass_word", SqlDbType.VarChar, 20).Value = this.txtPwd.Text;
                com.Parameters.Add(
"@Id", SqlDbType.Int, 4).Direction = ParameterDirection.Output;
                com.ExecuteNonQuery();

                
this.lblTip.Text = com.Parameters[2].Value.ToString();
                con.Close();
            }
            
catch { }
        }
    }
}

复制代码


存储过程代码:(数据库就三个字段UID、UserName、Password)

CREATE proc [dbo].[add_Users]
(@User_Name varchar(
20),@Pass_word varchar(50),@Id int output)
as
insert into info(UserName,Password) values(@User_name,@Pass_word)
select @Id
=max(UID) from info


完整程序下载:下载

posted on   几度夕阳红了  阅读(2734)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述
< 2008年12月 >
30 1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30 31 1 2 3
4 5 6 7 8 9 10

点击右上角即可分享
微信分享提示