Missing right parenthesis oracle ошибка
работает, выводит примерно следующее:
(такая выборка нужна для одного хитрого отчета)
1 - это коэффициент, который тоже должен высчитываться одним хитрым подзапросом
Подставляем туда этот хитрющий подзапрос:
И, пипец, - ошибка ORA-00907: отсутствует правая скобра,
указывая на слово ORDER BY подзапроса.
на самом то деле, синтаксически вроде-бы все верно,
если убрать ORDER BY f.DATE_TARIF DESC, то все работает,
но мне эта строка нужна, чтоб первой строкой результата была та строка,
где дата более поздняя
возвращает несколько строк, а мне нужно в формулу
CREDIT * (xxx) * 0.01
подставить значение SUM_TARIF именно той строки, которая имеет наиболее позднее значение даты в DATE_TARIF.
как бы поэтому я
1) пытался сортировать таблицу () , чтоб первой строкой была строка, содержащая более позднюю дату
2) Брал только первую строку ()
а как мне построить тогда этот запрос, чтоб был такой же результат?
Общая идея такая (просто нет времени вникать в специфику - домой хоцца :) ):
Your suggestion will not work. You can not pass correlated values that deep:
You would have to use something like:
I thought pamir explained it:
If you want to use function do something like:
SQL State = 42000 SQL Code = 907 SQL Message = ORA-00907: отсутствует правая скобка
Exception message = java.sql.SQLException: ORA-00907: отсутствует правая скобка
SQL State = 42000 SQL Code = 907 SQL Message = ORA-00907: отсутствует правая скобка
Exception message = java.sql.SQLException: ORA-00907: отсутствует правая скобка
Что делать?
Это он очень правильно выдает. Кому пришла в голову светлая идея создавать пользовательские объекты в схеме SYSTEM?!
SQL State = 42000 SQL Code = 907 SQL Message = ORA-00907: отсутствует правая скобка
Exception message = java.sql.SQLException: ORA-00907: отсутствует правая скобка
Что делать?integer - это подтип, его нельзя уточнять по кол-ву знаков. Напишите NUMBER вместо INTEGER.
Select CAST((CASE WHEN CHARINDEX('ЗП', 1PO)>0
THEN RIGHT(1PO,LEN(1PO)-CHARINDEX('ЗП',1PO)+1) ELSE NULL END) AS varchar(20)) AfterText, 1PO
from Lyb4eg;
Are you sure it is Oracle database? RIGHT, LEN, CHARINDEX are SQL Server functions (at least not Oracle functions). But main reeason for ORA-00907: missing right parenthesis is column name 1PO. Unquoted Oracle names can't start with a digit:
Error ORA-00907 is a syntax error and therefore, is a commonly seen error by users writing code manually. This error indicates that there is a left parenthesis but no corresponding right parenthesis, or that additional information was contained within the parentheses.
To correct this error, you must find the part of code that contains the missing right parenthesis, insert the missing symbol in the correct spot, and run the statement again.
Error ORA-00907 can commonly occur in commands such as CREATE TABLE, CREATE CLUSTER, and INSERT, which all require an itemized list enclosed in parentheses. It can also occur within subqueries such as WHERE clauses, UPDATE table SET column = (SELECT…) statements.
In the following example, the missing right parenthesis after “20” would throw error ORA-00907:
CREATE TABLE employee
employee_name VARCHAR(20 NOT NULL,
employee_phone VARCHAR(10) NOT NULL,
For example, the following lines of code is missing the necessary number of quotation marks:
in_fieldname_list := ‘PROTOTYPE’ ’, ‘ ’ADDR1’ ’, ‘ ’CITY’ ’, ‘ ’STATE’ ’,’ ’ZIP’ ’, ‘ ’OAPPRAISAL’;
in_fieldname_list := ‘ ‘ ‘PROTOTYPE’ ’, ‘ ’ADDR1’ ’, ‘ ’CITY’ ’, ‘ ’STATE’ ’,’ ’ZIP’ ’, ‘ ’OAPPRAISAL’ ‘ ’;
Error ORA-00907 specifically points to a missing right parenthesis while error ORA-00906 indicates that there is a missing left parenthesis.
To avoid seeing error ORA-00907, make sure to practice writing correct syntax. One of the easiest ways to ensure your syntax is correct is to use an integrated development environment that includes a source code editor. A good source code editor should offer features such as syntax highlighting, autocomplete, indentation, and matching brackets to help the coder automate the process of coding and make it easier to catch mistakes. With such features, you should be able to easily spot any line of code, which is causing error ORA-00907. If still facing this error after reviewing the syntax, check that it is not being caused by FULL/LEFT OUTER joins associated with Bug 4433936. While the bug has been fixed for later versions of Oracle, it can still be seen in earlier versions.
Читайте также: