试用了一下 OracleDataAdapter 功能,但是upadate时遇到问题。数据不能更新。如下代码有什么问题?

kuailexq2000 2010-03-05 09:49:48
using System;
using System.Data;
using Oracle.DataAccess.Client;
using System.Web.Configuration;

namespace oraModify
{
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
try
{
String connectionString = WebConfigurationManager.ConnectionStrings["ConnectionString1"].ConnectionString;
OracleConnection con = new OracleConnection(connectionString);
con.Open();

//// Create the command
OracleCommand cmdSelect = new OracleCommand("", con);

// sql文
OracleCommand cmdUpdate = new OracleCommand("", con);

// sql文
OracleCommand cmdDelete = new OracleCommand("", con);

// sql文
OracleCommand cmdInsert = new OracleCommand("", con);

//select statement
string strSelectSql = "SELECT * FROM TBUSER WHERE LOGINID = :I_LOGINID ";
string strUpdateSql = "UPDATE TBUSER SET EFFECTSTRT = :I_EFFECTSTRT WHERE LOGINID = :I_LOGINID ";
//string strDeleteSql = "DELETE FROM TBUSER WHERE LOGINID = :I_LOGINID";
//string strInsertSql = "INSERT TB_USER(LOGINID,EFFECTSTRT,EFFECTEND) VALUES (:I_LOGINID, :I_EFFECTSTRT,:I_EFFECTEND )";

//command和检索sql文 关联
cmdSelect.CommandText = strSelectSql;
cmdUpdate.CommandText = strUpdateSql;
//cmdDelete.CommandText = strDeleteSql;
//cmdInsert.CommandText = strInsertSql;

//sql文中变量通过oracle参数传递
OracleParameter oraParameter;

//当设置参数的时候
//oracle参数值可通过SourceColumn属性与更新数据行的字段绑定
//取得数据值的版本可通过SourceVersion来设定。
//DataRowVersion.Current 取得数据行中修改后的数据值
//DataRowVersion.Original 取得数据行中原始的数据值
//Where条件里面的参数值往往设置为取DataRowVersion.Original版本
//更新或者插入的参数值往往设置为取DataRowVersion.Current版本

//--------------------------------------------------
//取得用的oracle command
oraParameter = new OracleParameter("I_LOGINID", OracleDbType.Varchar2);
oraParameter.SourceColumn = "LOGINID";//检索字段值
oraParameter.SourceVersion = DataRowVersion.Current;
oraParameter.Value = "60";
cmdSelect.Parameters.Add(oraParameter);//字符型
//--------------------------------------------------
//更新用的oracle command
oraParameter = new OracleParameter("I_EFFECTSTRT", OracleDbType.Date);
oraParameter.SourceColumn = "EFFECTSTRT";//更新字段值
oraParameter.SourceVersion = DataRowVersion.Current;
oraParameter.Value = Convert.ToDateTime("2010/02/14").Date;
cmdUpdate.Parameters.Add(oraParameter);

oraParameter = new OracleParameter("I_LOGINID", OracleDbType.Varchar2);
oraParameter.SourceColumn = "LOGINID";//检索字段值
oraParameter.SourceVersion = DataRowVersion.Original;
oraParameter.Value = "60";
cmdUpdate.Parameters.Add(oraParameter);
////--------------------------------------------------
////删除用的oracle command
//oraParameter = new OracleParameter("I_LOGINID", OracleDbType.Varchar2);
//oraParameter.SourceColumn = "LOGINID";//检索字段值
//oraParameter.SourceVersion = DataRowVersion.Original;
//oraParameter.Value = "50";
//cmdDelete.Parameters.Add(oraParameter);

////--------------------------------------------------
////追加用的oracle command
//oraParameter = new OracleParameter("I_LOGINID", OracleDbType.Varchar2);
//oraParameter.SourceColumn = "LOGINID";//追加字段值
//oraParameter.SourceVersion = DataRowVersion.Current;
//oraParameter.Value = "70";
//cmdInsert.Parameters.Add(oraParameter);

//oraParameter = new OracleParameter("I_EFFECTSTRT", OracleDbType.Varchar2);
//oraParameter.SourceColumn = "EFFECTSTRT";//追加字段值
//oraParameter.Value = "2010/02/14";
//oraParameter.SourceVersion = DataRowVersion.Current;
//cmdInsert.Parameters.Add(oraParameter);

//oraParameter = new OracleParameter("I_EFFECTEND", OracleDbType.Varchar2);
//oraParameter.SourceColumn = "EFFECTEND";//追加字段值
//oraParameter.Value = "2010/02/14";
//oraParameter.SourceVersion = DataRowVersion.Current;
//cmdInsert.Parameters.Add(oraParameter);

using (OracleDataAdapter dataAdapter = new OracleDataAdapter())
{
int nRecCount = 0;
DataSet i_Data = new DataSet();

dataAdapter.SelectCommand = cmdSelect;
dataAdapter.Fill(i_Data, "TB_USER");
//dataAdapter.InsertCommand = cmdInsert;//追加command设置
dataAdapter.UpdateCommand = cmdUpdate;//更新command设置
//dataAdapter.DeleteCommand = cmdDelete;//删除command设置
nRecCount = dataAdapter.Update(i_Data, "TB_USER");//数据更新
//this.GridView1.DataSource = i_Data;
//GridView1.DataBind();//将控件及其所有子控件绑定到指定的数据源
}
// Close and Dispose OracleConnection object
con.Close();
con.Dispose();

}
catch (Exception ex)
{

throw ex;
}


}
}
}
...全文
421 33 打赏 收藏 转发到动态 举报
写回复
用AI写文章
33 条回复
切换为时间正序
请发表友善的回复…
发表回复
kuailexq2000 2010-03-08
  • 打赏
  • 举报
回复
引用 31 楼 kuailexq2000 的回复:
引用 28 楼 qldsrx 的回复:DataRow dr = i_Data.Tables[0].Rows[0]; dr["EFFECTSTRT"] = Convert.ToDateTime("2010/02/14").Date;//这里改动了下第一行数据。
这个没试过,试一下。


ok
阿非 2010-03-05
  • 打赏
  • 举报
回复
oraParameter = new OracleParameter("I_LOGINID", OracleDbType.Varchar2);
oraParameter.SourceColumn = "LOGINID";//检索字段值
oraParameter.SourceVersion = DataRowVersion.Original;
oraParameter.Value = "60";
cmdUpdate.Parameters.Add(oraParameter);
--------------------------------------------------------

oraParameter.Value = "60";


区别是没有设置value
kuailexq2000 2010-03-05
  • 打赏
  • 举报
回复

using System;
using System.Data;
using Oracle.DataAccess.Client;
using System.Web.Configuration;

namespace oraModify
{
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
try
{
String connectionString = WebConfigurationManager.ConnectionStrings["ConnectionString1"].ConnectionString;
OracleConnection con = new OracleConnection(connectionString);
con.Open();

//// Create the command
OracleCommand cmdSelect = new OracleCommand("", con);
// sql文
OracleCommand cmdUpdate = new OracleCommand("", con);

//select statement
string strSelectSql = "SELECT * FROM TBUSER WHERE LOGINID = :I_LOGINID ";
string strUpdateSql = "UPDATE TBUSER SET EFFECTSTRT = :I_EFFECTSTRT WHERE LOGINID = :I_LOGINID ";

//command和检索sql文 关联
cmdSelect.CommandText = strSelectSql;
cmdUpdate.CommandText = strUpdateSql;

//sql文中变量通过oracle参数传递
OracleParameter oraParameter;

//--------------------------------------------------
//取得用的oracle command
oraParameter = new OracleParameter("I_LOGINID", OracleDbType.Varchar2);
oraParameter.SourceColumn = "LOGINID";//检索字段值
oraParameter.SourceVersion = DataRowVersion.Current;
oraParameter.Value = "60";
cmdSelect.Parameters.Add(oraParameter);//字符型
//--------------------------------------------------
//更新用的oracle command
oraParameter = new OracleParameter("I_EFFECTSTRT", OracleDbType.Date);
oraParameter.SourceColumn = "EFFECTSTRT";//更新字段值
oraParameter.SourceVersion = DataRowVersion.Current;
oraParameter.Value = Convert.ToDateTime("2010/02/14").Date;
cmdUpdate.Parameters.Add(oraParameter);

oraParameter = new OracleParameter("I_LOGINID", OracleDbType.Varchar2);
oraParameter.SourceColumn = "LOGINID";//检索字段值
oraParameter.SourceVersion = DataRowVersion.Original;
oraParameter.Value = "60";
cmdUpdate.Parameters.Add(oraParameter);

using (OracleDataAdapter dataAdapter = new OracleDataAdapter())
{
int nRecCount = 0;
DataSet i_Data = new DataSet();

dataAdapter.SelectCommand = cmdSelect;
dataAdapter.Fill(i_Data, "TB_USER");
//dataAdapter.InsertCommand = cmdInsert;//追加command设置
dataAdapter.UpdateCommand = cmdUpdate;//更新command设置
nRecCount = dataAdapter.Update(i_Data, "TB_USER");//数据更新
}
// Close and Dispose OracleConnection object
con.Close();
con.Dispose();
}
catch (Exception ex)
{
throw ex;
}
}
}
}

整理了一下,方便看。:)
kuailexq2000 2010-03-05
  • 打赏
  • 举报
回复
引用 9 楼 sandy945 的回复:
我没装 oracle ,没办法帮你测。

多谢啊,
能提示一下有什么不同吗
阿非 2010-03-05
  • 打赏
  • 举报
回复
我没装 oracle ,没办法帮你测。
阿非 2010-03-05
  • 打赏
  • 举报
回复

OracleDataAdapter da = new OracleDataAdapter();
OracleCommand cmd;
OracleParameter parm;

// Create the SelectCommand.

cmd = new OracleCommand("SELECT * FROM Dept " +
"WHERE DName = pDName AND Loc = pLoc", conn);

cmd.Parameters.Add("pDName", OracleType.NVarChar, 14);
cmd.Parameters.Add("pLoc", OracleType.NVarChar, 13);

da.SelectCommand = cmd;

// Create the UpdateCommand.

cmd = new OracleCommand("UPDATE Dept SET DeptNo = pDeptNo, DName = pDName " +
"WHERE DeptNo = poldDeptNo", conn);

cmd.Parameters.Add("pDeptNo", OracleType.Number, 2, "DeptNo");
cmd.Parameters.Add("pDName", OracleType.NVarChar, 14, "DName");

parm = cmd.Parameters.Add("poldDeptNo", OracleType.Number, 2, "DeptNo");
parm.SourceVersion = DataRowVersion.Original;

da.UpdateCommand = cmd;



abaochen 2010-03-05
  • 打赏
  • 举报
回复
command = new SqlCommand(
"UPDATE Customers SET CustomerID = @CustomerID, CompanyName = @CompanyName " +
"WHERE CustomerID = @oldCustomerID", connection);

// Add the parameters for the UpdateCommand.
command.Parameters.Add("@CustomerID", SqlDbType.NChar, 5, "CustomerID");
command.Parameters.Add("@CompanyName", SqlDbType.NVarChar, 40, "CompanyName");
SqlParameter parameter = command.Parameters.Add(
"@oldCustomerID", SqlDbType.NChar, 5, "CustomerID");
parameter.SourceVersion = DataRowVersion.Original;

adapter.UpdateCommand = command;
kuailexq2000 2010-03-05
  • 打赏
  • 举报
回复
引用 5 楼 sandy945 的回复:
MSDN:

C# code
command=new SqlCommand("UPDATE Customers SET CustomerID = @CustomerID, CompanyName = @CompanyName"+"WHERE CustomerID = @oldCustomerID", connection);// Add the parameters for the UpdateCommand. command.Parameters.Add("@CustomerID", SqlDbType.NChar,5,"CustomerID");
command.Parameters.Add("@CompanyName", SqlDbType.NVarChar,40,"CompanyName");
SqlParameter parameter= command.Parameters.Add("@oldCustomerID", SqlDbType.NChar,5,"CustomerID");
parameter.SourceVersion= DataRowVersion.Original;

adapter.UpdateCommand= command;


看过了,没看到有什么区别。

单用dataAdapter.selectcommand 是可以通过的。
有两个注意的事情:),我不了解的。
1.这个是oracle的,并且是oracle provider。是不是与sqlclient/oracleclient有不同
2.单独写 .updatecommand会因为
dataAdapter.Update(i_Data, "TB_USER");//数据更新

中没有表名出错。
3.没用到的代码很多,简单建个user表就看到现象了。

多谢!
阿非 2010-03-05
  • 打赏
  • 举报
回复
MSDN:


command = new SqlCommand(
"UPDATE Customers SET CustomerID = @CustomerID, CompanyName = @CompanyName " +
"WHERE CustomerID = @oldCustomerID", connection);

// Add the parameters for the UpdateCommand.
command.Parameters.Add("@CustomerID", SqlDbType.NChar, 5, "CustomerID");
command.Parameters.Add("@CompanyName", SqlDbType.NVarChar, 40, "CompanyName");
SqlParameter parameter = command.Parameters.Add(
"@oldCustomerID", SqlDbType.NChar, 5, "CustomerID");
parameter.SourceVersion = DataRowVersion.Original;

adapter.UpdateCommand = command;
lovelan1748 2010-03-05
  • 打赏
  • 举报
回复
贴代码好好贴嘛,报错吗?
kuailexq2000 2010-03-05
  • 打赏
  • 举报
回复
没错
就是数据不更新。
zetee 2010-03-05
  • 打赏
  • 举报
回复
小菜鸟,问问题都不会。怎么搞
阿非 2010-03-05
  • 打赏
  • 举报
回复
报错么?
阿非 2010-03-05
  • 打赏
  • 举报
回复
还是写一下吧
引用 21 楼 sandy945 的回复:
//关键
DataSet dataSet = new DataSet();
dataAdpater.Fill(dataSet, "TBUSER");

//这里只是更新了第一行,如果你想更新LOGINID 为60的所有记录,遍历DataSet 分别赋值即可
DataRow row = dataSet.Tables["TBUSER"].Rows[0];
row["EFFECTSTRT"] = Convert.ToDateTime("2010/02/14").Date;

//关键
DataSet dataSet = new DataSet();
dataAdpater.Fill(dataSet, "TBUSER");

//这里只是更新了第一行,如果你想更新LOGINID 为60的所有记录,遍历DataSet 分别赋值即可
//DataRow row = dataSet.Tables["TBUSER"].Rows[0];
//row["EFFECTSTRT"] = Convert.ToDateTime("2010/02/14").Date;

if(dataSet.Tables.Contains("TBUSER"))
{
for(int i=0;i<dataSet.Tables["TBUSER"].Rows.Count;i++)
{
object obj = dataSet.Tables["TBUSER"].Rows[i]["LOGINID"]??"0";
int id;
int.TryParse(obj.ToString(),out id);
if(id==60)
{
dataSet.Tables["TBUSER"].Rows[i]["EFFECTSTRT"] = DateTime.Now;
}
}
}


更新 LOGINID 字段 值为 60 的所有记录 的 EFFECTSTRT 字段 为更新时的时间
kuailexq2000 2010-03-05
  • 打赏
  • 举报
回复
引用 28 楼 qldsrx 的回复:
DataRow dr = i_Data.Tables[0].Rows[0];
dr["EFFECTSTRT"] = Convert.ToDateTime("2010/02/14").Date;//这里改动了下第一行数据。

这个没试过,试一下。

引用 29 楼 qldsrx 的回复:
另外Sandy945的代码一直犯了一个相同的错误,Oracle的参数前缀你没有添加。

他没装oracle,不是可运行的代码,是在sqlserver代码基础上意会一下,我理解的:)
阿非 2010-03-05
  • 打赏
  • 举报
回复
Oracle的参数前缀你没有添加
-------------------------

?
qldsrx 2010-03-05
  • 打赏
  • 举报
回复
多删除了一个参数,这里补上:
oraParameter = new OracleParameter("I_LOGINID",OracleDbType.Varchar2); 
oraParameter.SourceColumn = "LOGINID";//检索字段值
oraParameter.SourceVersion = DataRowVersion.Original;
cmdUpdate.Parameters.Add(oraParameter);


另外Sandy945的代码一直犯了一个相同的错误,Oracle的参数前缀你没有添加。
qldsrx 2010-03-05
  • 打赏
  • 举报
回复
只要这样调整下就可以了:
//更新用的oracle command 
oraParameter = new OracleParameter("I_EFFECTSTRT", OracleDbType.Date);
oraParameter.SourceColumn = "EFFECTSTRT";//更新字段值
oraParameter.SourceVersion = DataRowVersion.Current;
cmdUpdate.Parameters.Add(oraParameter);

using (OracleDataAdapter dataAdapter = new OracleDataAdapter())
{
int nRecCount = 0;
DataSet i_Data = new DataSet();

DataRow dr = i_Data.Tables[0].Rows[0];
dr["EFFECTSTRT"] = Convert.ToDateTime("2010/02/14").Date;//这里改动了下第一行数据。

dataAdapter.SelectCommand = cmdSelect;
dataAdapter.Fill(i_Data, "TB_USER");
//dataAdapter.InsertCommand = cmdInsert;//追加command设置
dataAdapter.UpdateCommand = cmdUpdate;//更新command设置
nRecCount = dataAdapter.Update(i_Data, "TB_USER");//数据更新
}


因为是通过表映射来改动数据库,所以必须要DataSet本身有所改变才行。
同时也因为这样,更新命令UpdateCommand的参数不要给任何值,为空即可,它会自动到DataTable中取相应的值,通过你设置的oraParameter.SourceColumn来关联。
阿非 2010-03-05
  • 打赏
  • 举报
回复
虽然今天有些发昏,但 21楼的代码 是可以运行并达到效果的

有偏差可看注释
kuailexq2000 2010-03-05
  • 打赏
  • 举报
回复
引用 24 楼 qldsrx 的回复1:
楼主你的错误是,请看这段源码:
C# codeusing (OracleDataAdapter dataAdapter=new OracleDataAdapter())
{int nRecCount=0;
DataSet i_Data=new DataSet();

dataAdapter.SelectCommand= cmdSelect;
dataAdapter.Fill(i_Data,"TB_USER");//dataAdapter.InsertCommand = cmdInsert;//追加command设置 dataAdapter.UpdateCommand= cmdUpdate;//更新command设置 nRecCount= dataAdapter.Update(i_Data,"TB_USER");//数据更新 }
显然你的i_Data 未做过任何改动,更新自然不会有效。dataAdapter.Update是针对DataTable中有改动的数据行,有一行被改动了,就更新那一行数据到数据库一次。

谢谢回答,“显然你的i_Data 未做过任何改动,更新自然不会有效。”
需要如何改动i_Data,这个dataset;请详细些。
引用 24 楼 qldsrx 的回复2:
再看这里:
C# code
oraParameter=new OracleParameter("I_LOGINID", OracleDbType.Varchar2);
oraParameter.SourceColumn="LOGINID";//检索字段值 oraParameter.SourceVersion= DataRowVersion.Original;
oraParameter.Value="60";
你既然指定了参数的具体值,也就是并非从DataTable里传递改动映射来更新,那么你根本不需要那个OracleDataAdapter,直接使用OracleCommand 调用它的ExecuteNonQuery()方法即可实现更新效果了。

ExecuteNonQuery是可以的。
加载更多回复(13)

110,534

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧