In TSQL I could use something like Select [table] from tablename
to select a column named "table".
How do I do this for reserved words in oracle?
Edit: I've tried square braces, double quotes, single quotes, and backquotes, they don't work...
As a further clarification, I have a column which someone named comment. As this is a reserved word oracle is chucking a wobbly trying to select with it, its failing when parsing the query. I've tried Select "comment" from tablename but it didn't work. I'll check case and come back.
Oracle normally requires double-quotes to delimit the name of identifiers in SQL statements, e.g.
However, it graciously allows omitting the double-quotes, in which case it quietly converts the identifier to uppercase:
gets internally converted to something like:
Oracle does use double-quotes, but you most likely need to place the object name in upper case, e.g. "TABLE". By default, if you create an object without double quotes, e.g.
Oracle would create the object as upper case. However, the referencing is not case sensitive unless you use double-quotes!
From a quick search, Oracle appears to use double quotes (
"
, eg"table"
) and apparently requires the correct case—whereas, for anyone interested, MySQL defaults to using backticks (`) except when set to use double quotes for compatibility.double quotes worked in oracle when I had the keyword as one of the column name.
eg:
you have to rename the column to an other name because
TABLE
is reserved by Oracle.You can see all reserved words of Oracle in the oracle view
V$RESERVED_WORDS
.