Kar*_*san 7 c# asp.net odp.net
我使用的Oracle.DataAccess.Client一起工作甲骨文在我的数据库ASP.Net应用程序.有没有在帮助文档MSDN的ODP.Net和甲骨文的文档真的很糟糕.我无法找到这个简单问题的答案.
是否无法在不构建dataset对象和更新对象的情况下执行简单的更新语句dataset?
如何在C#中使用Oracle ODP.Net执行更新语句?
Chr*_*lor 17
我需要检查确切的语法,但这里有一些快速的代码
using (OracleConnection con = new OracleConnection(...))
{
con.Open();
OracleCommand cmd = con.CreateCommand();
cmd.CommandType = CommandType.Text;
cmd.CommandText = "update table set col1 = :param1, col2 = :param2 where key = :keyValue";
cmd.Parameters.AddWithValue("param1", 1);
cmd.Parameters.AddWithValue("param2", "Text data");
cmd.Parameters.AddWithValue("keyValue", "1");
cmd.ExecuteNonQuery();
}
Run Code Online (Sandbox Code Playgroud)
上面创建一个命令对象设置命令以执行SQL Update语句,在这个例子中我展示了一种设置参数化查询的方法,你应该总是使用参数化查询.设置命令后,您只需调用ExecuteNonQuery实际执行命令即可.
因此,经过一番侦查并解决了一段时间后,我发现我用来向连接命令添加新参数的方法如下。我没有找到上一篇文章中所述的方法。请注意,我正在使用我正在传递值的查询对象。
public Boolean InsertMethod(Query _query)
{
var success = false;
var queryString = string.Format(@"INSERT INTO TABLE(ID, OWNER, TEXT) VALUES (TABLE_SEQ.NEXTVAL,:OWNER, :TEXT)");
try
{
using (OracleConnection con = new OracleConnection(ConString))
{
con.Open();
OracleCommand cmd = con.CreateCommand();
cmd.CommandText = queryString;
cmd.Parameters.Add("OWNER", _query.Owner);
cmd.Parameters.Add("TEXT", _query.Text);
int rowsUpdated = cmd.ExecuteNonQuery();
if (rowsUpdated > 0) success = true;
}
return success;
}
catch (Exception ex)
{
log.Error(ex);
throw;
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
41916 次 |
| 最近记录: |