从数据库中获取autoNumber值
代码如下。 在我的代码我更新现有的行(从现有的表),程序从文本框中获取所有更新的值。 在表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):可以在索引或主键上或关系中找出重复的值”
看到这一点:
http://msdn.microsoft.com/en-us/library/ks9f57t0(v=VS.80).aspx
看到标有节 “检索的Microsoft Access自动编号值”
排序版本
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'的行跟随另一个'
我们在我们的一些代码的内联查询中使用了Scope_Identity,它工作正常。我们只是将语句一行,用分号分隔成一行中的两个语句。例如:“插入到MyTable(myValues);选择@@ Identity”我不确定这是否适用于所有RDBMS,但它适用于我们较早的SQL Server。它也可以在Access中工作。 – David
它看起来很多工作!有没有简单的解决方案? – user1017315
tbh David Stratton已经重新开始......只需运行原始查询,然后选择'; SELECT @@ IDENTITY'并将其与.executequery而不是.executenonquery一起使用。不是很多额外的工作 –
使用带有参数vs内联SQL的存储过程。INLINE SQL允许SQL注入。程序然后可以返回位置/ ID。 – xQbert
+1 xQbert!为了使这个更安全的代码见:http://msdn.microsoft.com/en-us/library/ff648339.aspx - 另一种选择是参数化SQL。 –