c# - 从数据库获取自动编号值

标签 c# ms-access oledb autonumber

代码如下。 在我的代码中,我更新现有行(从现有表),程序从文本框中获取所有更新的值。 表的末尾(最后一列)有一个名为“codonsAutoNum”的自动编号字段

我不知道如何从数据库中获取值(自动编号值)。 我需要(代码中)有“??”的位置的值。

感谢大家的帮助!

代码:

        private void update_Click(object sender, EventArgs e)
    {
        string connectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\\Projects_2012\\Project_Noam\\Access\\myProject.accdb";
        OleDbConnection myConnection = new OleDbConnection(connectionString);
        string myInsertQuery =(String.Format("UPDATE tblCodons SET codonsCodon1='{0}', codonsCodon3='{1}', " + 
        "codonsTriplet1='{2}', codonsTriplet2='{3}', codonsTriplet3='{4}', codonsTriplet4='{5}', " + 
        "codonsTriplet5='{6}', codonsTriplet6='{7}', codonsFullName='{8}'" + 
        " WHERE codonsAutoNum='{9}'",codon1.Text, codon3.Text ,triplet1.Text, triplet2.Text,
         triplet3.Text, triplet4.Text, triplet5.Text, triplet6.Text,
        fullName.Text,??));
        OleDbCommand myCommand = new OleDbCommand(myInsertQuery);
        myCommand.Connection = myConnection;
        myConnection.Open();
        myCommand.ExecuteNonQuery();
        myCommand.Connection.Close();

编辑:它真的很困惑。我的代码应该如何显示? 我需要将“SELECT @@identity”放在哪里?我不明白为什么我不能只获取该值? (我需要它作为所选行的索引来确定更新的位置。当我识别此内容(如下)时它运行良好,但它不允许我更改全名字段..有一个比自动编号列更好的解决方案?

        private void update_Click(object sender, EventArgs e)
    {


        string connectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\\Projects_2012\\Project_Noam\\Access\\myProject.accdb";

        OleDbConnection myConnection = new OleDbConnection(connectionString);
        string myInsertQuery =(String.Format("UPDATE tblCodons SET codonsCodon1='{0}', codonsCodon3='{1}', " + 
        "codonsTriplet1='{2}', codonsTriplet2='{3}', codonsTriplet3='{4}', codonsTriplet4='{5}', " + 
        "codonsTriplet5='{6}', codonsTriplet6='{7}', codonsFullName='{8}'" + 
        " WHERE codonsFullName = {9}",codon1.Text, codon3.Text ,triplet1.Text, triplet2.Text,
         triplet3.Text, triplet4.Text, triplet5.Text, triplet6.Text,
        fullName.Text,this.name));
        OleDbCommand myCommand = new OleDbCommand(myInsertQuery);
        myCommand.Connection = myConnection;
        myConnection.Open();
        myCommand.ExecuteNonQuery();
        myCommand.Connection.Close();
        this.tblCodonsTableAdapter.Fill(this.myProjectDataSet.tblCodons);

name=全名保存的值,每次点击值变化

还有一个问题。我尝试对 e.Row 执行相同的操作(我在每次单击表中时保存它),但出现错误“System.Data.OleDb.OleDbException (0x80004005):可能导致索引或索引上出现重复的值” mainKey 或关系中"‏‏

最佳答案

看这个:

http://msdn.microsoft.com/en-us/library/ks9f57t0(v=VS.80).aspx

请参阅标记为“检索 Microsoft Access 自动编号值”的部分

版本排序

OleDbCommand cmdNewID = new OleDbCommand("SELECT @@IDENTITY",
            connection)

我不相信 Access 权限中存在 SCOPE_IDENTITY()

关于c# - 从数据库获取自动编号值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8258102/

相关文章:

c# - 使用 jet.oledb.4.0 导入 Excel 工作表,将第一行设置为列名

c# - OleDB 选择语句

c# - 从散列值中取回值?

mysql - 在 MS Access 查询中计算数字的幂

asp.net - 如何选择多个类别的产品

mysql - 同步 Access DB 和 MySQL

c# - 用 OLEDB 读取 Excel 文件?

c# - 服务器响应为 : 5. 7.1 无法中继/邮件守护程序

c# - 从文件夹 RelativeID 获取文件夹 - Windows Phone

c# - 将转换器应用于 Json 数组中的所有元素