栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

创建存储过程以将自动增量作为其主要字段添加?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

创建存储过程以将自动增量作为其主要字段添加?

理想情况下,您只需通过更改表定义将TagID用作身份字段。如果您不能这样做,那么下一个最佳选择是:

CREATE PROCEDURE [dbo].[InsertTagProcdure]       @Value nvarchar(200),        @TagCount nvarchar(200) ASBEGIN    BEGIN TRANSACTION        DECLARE @TagID int;        SELECt @TagID = coalesce((select max(TagID) + 1 from Tag), 1)    COMMIT          INSERT INTO         Tag         (TagID,Value,TagCount)         VALUES         (@TagID,@Value,@TagCount)END

事务确保您不会以唯一的TagID结尾,并且合并处理特殊情况,即表为空并给出初始值1。

编辑:

根据对原始问题的更改,该表已经具有一个标识列,因此您的存储过程应为:

CREATE PROCEDURE [dbo].[InsertTagProcdure]       @Value nvarchar(200),        @TagCount nvarchar(200) ASBEGIN    INSERT INTO Tag (Value,TagCount) VALUES (@Value,@TagCount)END

并且您的C#代码应为

int TagID = int.Parse(txtTagID.Text); //这应该会消失,以便自动递增。字符串值= txtValue.Text; int
TagCount = int.Parse(txtCount.Text);

        using (var conn = new SqlConnection(Properties.Settings.Default.DBConnectionString))        using (var cmd = conn.CreateCommand())        {     conn.Open();     cmd.CommandText = "InsertTagProcdure";     cmd.CommandType = CommandType.StoredProcedure;     cmd.Parameters.AddWithValue("@Value", Value);     cmd.Parameters.AddWithValue("@TagCount", TagCount);     cmd.ExecuteNonQuery(); }


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/376551.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号