BCB通过ADO向oracle中插入时间的问题,谢谢

bxjgood66 2006-10-20 02:57:14
用bcb通过ADO向oracle库插入当前的时间,代码如下:

AnsiString sqlstring= "INSERT INTO SEND (TIME) VALUES values('"+Now()+"') ";
DB->ManagerADOQuery->Close();
DB->ManagerADOQuery->SQL->Clear();
DB->ManagerADOQuery->SQL->Add(sqlstring);
DB->ManagerADOQuery->ExecSQL();
像这样执行总是错误,请大家帮忙构造一个正确的。
我知道在oracle中正确应是:
INSERT INTO SEND (TIME,SENDTIME ) VALUES values(sysdate)
或者:
INSERT INTO SEND (TIME,SENDTIME ) VALUES values(TO_Date( '10/19/2006 12:00:23 下午', 'MM/DD/YYYY HH:MI:SS AM'))

但是如何在BCB中通过 ADO构造这样的呢 ? 谢谢
...全文
249 10 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
bxjgood66 2006-10-23
  • 打赏
  • 举报
回复
问题找到:原来的我的sql语句写错了:INSERT INTO SEND (ID, TIME ) VALUES values()多了一个values真是晕呀,呵呵 。

总结:
"INSERT INTO SEND (TIME) VALUES values('"+Now()+"') ";
INSERT INTO SEND (ID, TIME ) VALUES values('123', :dataParm ) ";
这两种方式都是可以的。
感谢:keiy()  提的思路也是很好的是经验之谈,任何数据库的date型都不兼容,所以我们在实际应用中几乎不用它,用varchar 一样可以,应用程序是一般都有将字串转成date型的函数。
bxjgood66 2006-10-21
  • 打赏
  • 举报
回复
我还没有搞定呀 ,郁闷!!!
柯本 2006-10-21
  • 打赏
  • 举报
回复
oracle的日期/时间格式要由注册表的:
HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOME0
中的NLS_DATE_FORMAT来确定
如果,没有NLS_DATE_FORMAT,那就由NLS_LANG所代表的语言集来定
所以,要解决你的问题有两个方法
1.在注册表中上述位置设
NLS_DATE_FORMAT=YYYY-MM-DD hh24:mi:ss
然后用
FormatDateTime( "YYYY-MM-DD HH:mm:ss", Now())
2.用sql的to_date
如:
insert into t1 values(to_date('2006-01-02 10:02:05','YYYY-MM-DD hh24:mi:ss'))
--------------------------------------------------------------------------------
任何数据库的date型都不兼容,所以我们在实际应用中几乎不用它,用varchar 一样可以
,因为无论sql或delphi都有将字串转成date型的函数
bxjgood66 2006-10-20
  • 打赏
  • 举报
回复
我已设定好了:
DB->ManagerADOQuery->Parameters->ParamByName("dataParm")->Value = Now();
为什么打印出来的参数没有换呢:

INSERT INTO SEND (ID, TIME ) VALUES values('123', :dataParm )

是不是 DB->ManagerADOQuery->Parameters 还需要设置 ? ?
lurel 2006-10-20
  • 打赏
  • 举报
回复
手头没有BCB工具,没法帮你调试,不过,你可以对DB->ManagerADOQuery->Parameters进行一下设定。搜一下以前的帖子。
bxjgood66 2006-10-20
  • 打赏
  • 举报
回复
我像这样还是不行 :
AnsiString sqlstring= "INSERT INTO SEND (ID, TIME ) VALUES values('123', :dataParm ) ";
DB->ManagerADOQuery->Close();
DB->ManagerADOQuery->SQL->Clear();
DB->ManagerADOQuery->SQL->Add(sqlstring);
DB->ManagerADOQuery->Parameters->ParamByName("dataParm")->Value = Now();
this->MemoLog->Lines->Append(FormatDateTime( "YYYY-MM-DD HH:mm:ss", Now()) + " sqlstring : " + sqlstring);
DB->ManagerADOQuery->ExecSQL();

上面仍出错,打印如下:
sqlstring : INSERT INTO SEND (ID, TIME ) VALUES values('123', :dataParm )
2006-10-20 15:35:13 出错了 : ORA-00936: 缺失表达式
bxjgood66 2006-10-20
  • 打赏
  • 举报
回复
我来试一下 ,谢谢
lurel 2006-10-20
  • 打赏
  • 举报
回复
利用参数传进去,这样看看行不?我手头没BCB

AnsiString sqlstring= "INSERT INTO SEND (TIME) VALUES values(:dataParm)";
DB->ManagerADOQuery->Close();
DB->ManagerADOQuery->SQL->Clear();
DB->ManagerADOQuery->SQL->Add(sqlstring);
DB->ManagerADOQuery->Params->ParamByName("dataParm")->Value = Now();
DB->ManagerADOQuery->ExecSQL();
bxjgood66 2006-10-20
  • 打赏
  • 举报
回复
在线等 。。。。
bxjgood66 2006-10-20
  • 打赏
  • 举报
回复
呵呵 上面写错了:

INSERT INTO SEND (TIME) VALUES values(sysdate)
或者:
INSERT INTO SEND (TIME) VALUES values(TO_Date( '10/19/2006 12:00:23 下午', 'MM/DD/YYYY HH:MI:SS AM'))

1,178

社区成员

发帖
与我相关
我的任务
社区描述
C++ Builder 数据库及相关技术
社区管理员
  • 数据库及相关技术社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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