2011-11-24 126 views
2

代碼如下。 在我的代碼我更新現有的行(從現有的表),程序從文本框中獲取所有更新的值。 在表autoNumber字段的結尾(最後一列)被命名爲「codonsAutoNum」從數據庫中獲取autoNumber值

我不知道如何從數據庫獲取值(自動編號值)。 我需要位置(在代碼中)有'?'的位置的值。

謝謝大家的幫助!

代碼:

 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(); 

編輯:它得到了真正confused.How沒有我的碼suppoused被似乎? 我需要把「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); 

名=全名的保存價值,每個點擊的價值chages

多了一個疑問句。我試圖做同樣的e.Row(這是我在表保存在每個點擊),我得到一個錯誤「System.Data.OleDb.OleDbException(0x80004005):可以在索引或主鍵上或關係中找出重複的值」

+4

使用帶有參數vs內聯SQL的存儲過程。INLINE SQL允許SQL注入。程序然後可以返回位置/ ID。 – xQbert

+0

+1 xQbert!爲了使這個更安全的代碼見:http://msdn.microsoft.com/en-us/library/ff648339.aspx - 另一種選擇是參數化SQL。 –

回答

1

我建議將查詢從內聯sql移動到存儲過程。並不是要阻止SQL注入,而是因爲您可以設置存儲過程以返回其剛剛創建的標識(自動編號)字段的值。只需在運行sql之後返回SCOPE_IDENTITY即可。

所有這一切都假設你使用SQL服務器(我不熟悉其他分貝的,但會假定他們有相似的功能)

見鏈接獲取更多信息

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

編輯:哇,這個答案很快!道歉重複的答案

EDIT2:看起來像訪問暴露變量@@ IDENTITY包含上次使用/創建的自動編號。所以你應該能夠運行和內聯查詢,並沿着'SELECT @@ IDENTITY AS prevID'的行跟隨另一個'

+0

我們在我們的一些代碼的內聯查詢中使用了Scope_Identity,它工作正常。我們只是將語句一行,用分號分隔成一行中的兩個語句。例如:「插入到MyTable(myValues);選擇@@ Identity」我不確定這是否適用於所有RDBMS,但它適用於我們較早的SQL Server。它也可以在Access中工作。 – David

+0

它看起來很多工作!有沒有簡單的解決方案? – user1017315

+0

tbh David Stratton已經重新開始......只需運行原始查詢,然後選擇'; SELECT @@ IDENTITY'並將其與.executequery而不是.executenonquery一起使用。不是很多額外的工作 –