加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 将sqlce表中的标识设置为自动递增?

发布时间:2020-12-15 21:42:33 所属栏目:百科 来源:网络整理
导读:我是一名初学者程序员(高中生),我的老师给了我一个任务,每当我在我的数据库中插入一个新行时,在sqlce表中创建一个主键就会自动递增(我不认为他知道如何做它:) 这是我目前的代码: using (SqlCeConnection con = new SqlCeConnection(conString)){ con.Open()
我是一名初学者程序员(高中生),我的老师给了我一个任务,每当我在我的数据库中插入一个新行时,在sqlce表中创建一个主键就会自动递增(我不认为他知道如何做它:)

这是我目前的代码:

using (SqlCeConnection con = new SqlCeConnection(conString))
{
    con.Open();

    using (SqlCeCommand com = new SqlCeCommand("INSERT INTO Occupational VALUES(@employedBeforeBool,@nameofEmployer,@Addressemployed,@specificsAtEmployer,@employmentOnDischarge,@yearsExperienceWithEmployer,@desireToReturnToEmployer,@farmingExperienceBool,@tradesorapprentiship,@whattradesorapprentiship,@SoldierID,@Occupational_ID)",con))
    {
        com.CommandText = "SET IDENTITY_INSERT Occupational ON";
        com.Parameters.AddWithValue("@employedBeforeBool",Soldier1.employedBeforeBool);
        com.Parameters.AddWithValue("@nameofEmployer",Soldier1.nameOfEmployer);
        com.Parameters.AddWithValue("@Addressemployed",Soldier1.addressOfEmployer);
        com.Parameters.AddWithValue("@specificsAtEmployer",Soldier1.specificsAtEmployer);
        com.Parameters.AddWithValue("@employmentOnDischarge",Soldier1.employmentOnDischarge);
        com.Parameters.AddWithValue("@yearsExperienceWithEmployer",Soldier1.yearsExperienceWithEmployer);
        com.Parameters.AddWithValue("@desireToReturnToEmployer",Soldier1.desireToReturnToEmployer);
        com.Parameters.AddWithValue("@farmingExperienceBool",Soldier1.farmingExperienceBool);
        com.Parameters.AddWithValue("@tradesorapprentiship",Soldier1.tradeOrApprenticeship);
        com.Parameters.AddWithValue("@whattradesorapprentiship",Soldier1.whattradesorapprentiship);
        com.Parameters.AddWithValue("@SoldierID",SoldierID);
        //com.Parameters.AddWithValue("@Occupational_ID",counter);

        com.ExecuteNonQuery();
    }

当我运行它时我的程序没有崩溃,它看起来像是插入但表中没有任何东西出现.

解决方法

您当前的代码使用SET IDENTITY文本覆盖INSERT INTO查询.只有1个CommandText属性.

在创建表时进行列自动递增,在插入过程中不必执行任何操作.

如果您使用设计器创建表,请返回并将Key列的IDENTITY属性设置为true.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读