?
Solved

INSERT with to_date in values clause

Posted on 2010-11-18
2
Medium Priority
?
770 Views
Last Modified: 2013-12-18
I'm tyring to insert a date value into a date field using to_date in the values clause, but continually get the following error.  I've tried a large variety of date formats and masks, but my preferred is MM/DD/YYYY hh:mm PM TZR.


Error starting at line 1 in command:
INSERT INTO pa_cpnt_user (col_num, cpnt_typ_id, cpnt_id, rev_dte, user_value, lst_upd_usr, lst_upd_tstmp) VALUES (1124,TRNG,test-item, to_date('20070901 02:00','yyyymmdd hh:mm'),08,SS_UPDATE,SYSDATE)
Error at Command Line:1 Column:183
Error report:
SQL Error: ORA-00984: column not allowed here
00984. 00000 -  "column not allowed here"
*Cause:    
*Action:


Here is the sql:

INSERT INTO pa_cpnt_user (col_num, cpnt_typ_id, cpnt_id, rev_dte, user_value, lst_upd_usr, lst_upd_tstmp) VALUES (1124,TRNG,test-item, to_date('20070901 02:00','yyyymmdd hh:mm'),08,SS_UPDATE,SYSDATE);

My table is as follows:

desc pa_cpnt_user
Name                           Null                             Type                                                                                                                                                                                                                                                                                      
------------------------------ -------------------------------- ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
COL_NUM                        NOT NULL                         NUMBER(38)                                                                                                                                                                                                                                                                                
CPNT_TYP_ID                    NOT NULL                         VARCHAR2(90)                                                                                                                                                                                                                                                                              
CPNT_ID                        NOT NULL                         VARCHAR2(90)                                                                                                                                                                                                                                                                              
REV_DTE                        NOT NULL                         DATE                                                                                                                                                                                                                                                                                      
USER_VALUE                                                      VARCHAR2(120)                                                                                                                                                                                                                                                                              
LST_UPD_USR                                                     VARCHAR2(90)                                                                                                                                                                                                                                                                              
LST_UPD_TSTMP                                                   DATE                                                                                                                                                                                                                                                                                      
0
Comment
Question by:mattturley
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
2 Comments
 
LVL 3

Accepted Solution

by:
mpaladugu earned 2000 total points
ID: 34169690
all the charecter values shoudl be enclosed in sngle quotes,

IINSERT INTO pa_cpnt_user (col_num,
                          cpnt_typ_id,
                          cpnt_id,
                          rev_dte,
                          user_value,
                          lst_upd_usr,
                          lst_upd_tstmp)
    VALUES (1124,
            'TRNG',
            'test-item',
            TO_DATE ('20070901 02:00', 'yyyymmdd hh:mm'),
            08,
            'SS_UPDATE',
            sysdate)
0
 
LVL 3

Expert Comment

by:mpaladugu
ID: 34169723
In the above comment, use MI instead of MM in place for minutes.

INSERT INTO pa_cpnt_user (col_num,
                          cpnt_typ_id,
                          cpnt_id,
                          rev_dte,
                          user_value,
                          lst_upd_usr,
                          lst_upd_tstmp)
    VALUES (1124,
            'TRNG',
            'test-item',
            TO_DATE ('20070901 02:00', 'yyyymmdd hh:mm'),
            08,
            'SS_UPDATE',
            sysdate)


and to try various date formats, just to test which format returns what. and if particular format is correct use for example.
Select TO_DATE ('20070901 02:00', 'yyyymmdd hh:mi PM') from dual
0

Featured Post

Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Truncate is a DDL Command where as Delete is a DML Command. Both will delete data from table, but what is the difference between these below statements truncate table <table_name> ?? delete from <table_name> ?? The first command cannot be …
Configuring and using Oracle Database Gateway for ODBC Introduction First, a brief summary of what a Database Gateway is.  A Gateway is a set of driver agents and configurations that allow an Oracle database to communicate with other platforms…
This video shows information on the Oracle Data Dictionary, starting with the Oracle documentation, explaining the different types of Data Dictionary views available by group and permissions as well as giving examples on how to retrieve data from th…
This video shows how to recover a database from a user managed backup
Suggested Courses

770 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question