从数据库中获取自动编号值



代码如下:在我的代码中,我更新现有的行(从现有的表),该程序从textBoxes中获得所有更新的值。在表的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= fullname的保存值,在每次点击中值都会改变

多一个问题。我试图做同样的e.o row(这是我保存在每次点击表),我得到一个错误"System.Data.OleDb。OleDbException (0x80004005):可能导致索引上的重复值,或在mainKey上或在关系"@ @ @ @

"中

见:

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

请参阅"检索Microsoft Access自动编号值"一节

sort version

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

我不相信SCOPE_IDENTITY()在访问

我建议将查询从内联sql移动到存储过程。不是为了阻止SQL注入,而是因为您可以将存储过程设置为返回刚刚创建的标识(自动编号)字段的值。只需让它在运行sql后返回SCOPE_IDENTITY。

所有这些都是假设你正在使用SQL服务器(我不熟悉其他数据库,但会假设他们有类似的功能)

查看链接获取更多信息

http://msdn.microsoft.com/en-us/library/ks9f57t0.aspx

编辑:哇,这个回复很快!为重复的回答道歉

EDIT2:看起来访问公开了一个变量@@IDENTITY,其中包含最后使用/创建的自动号码。所以你应该能够运行一个内联查询,然后在它后面跟着另一个'SELECT @@IDENTITY AS prevID'

相关内容

  • 没有找到相关文章

最新更新