Форум программистов, компьютерный форум, киберфорум
Oracle
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/121: Рейтинг темы: голосов - 121, средняя оценка - 4.89
0 / 0 / 0
Регистрация: 31.07.2012
Сообщений: 10

PLS-00103: Encountered the symbol ";" when expecting one of the following

02.08.2012, 20:33. Показов 24079. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В файле function.sql поместила код определения и вызова функции:
Oracle 11 SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
CREATE OR REPLACE FUNCTION word_count (in_w IN NUMBER)
RETURN words NUMBER
AS
words NUMBER := in_w;
BEGIN
words := words + 1;
RETURN words;
END;
/
SHOW ERRORS FUNCTION word_count;
 
BEGIN
DBMS_OUTPUT.PUT_LINE('Count words '|| word_count(TO_NUMBER('25'));
END;
Пробую в sql*plus, пишет ошибку:
ERROR at line 2:
ORA-06550: line 2, column 66:
PLS-00103: Encountered the symbol ";" when expecting one of the following:
. ( ) , * % & | = - + < / > at in is mod remainder not rem =>
.. <an exponent (**)> <> or != or ~= >= <= <> and or like
LIKE2_ LIKE4_ LIKEC_ as between from using || member
SUBMULTISET_
The symbol ")" was substituted for ";" to continue.

У меня во второй строке ; нет, что не так?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
02.08.2012, 20:33
Ответы с готовыми решениями:

Ошибка Error at line 16: PLS-00103: Encountered the symbol ""
При добавление или обновлении таблицы TEAM данные о команде заносятся в таблицу GROUPS_TEAM, если это команда есть в таблице ГрупсТим, то...

Триггер и PLS-00103: Encountered the symbol ""
create or replace trigger Valid_sklad /* Триггер, позволяющий оформить заказ только при наличии товара на складе */ Before Insert...

При запуске мелкой программы появляется ошибка "ORA-06550: line 4, column 5: PLS-00103: Encountered the symbol "" The symbol "" was ignored."
Сегодня первый день изучаю PL/SQL Установил Toad Открыл Editor и пишу первую программу (конечно Hello word) SET SERVEROUTPUT ON ...

5
Эксперт Java
 Аватар для turbanoff
4094 / 3828 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 12
02.08.2012, 21:47
у вас во второй строчке написано:
Oracle 11 SQL
2
RETURN words NUMBER
должно быть
Oracle 11 SQL
2
RETURN NUMBER
Зачем вы там words написали?
1
1 / 1 / 0
Регистрация: 20.06.2012
Сообщений: 51
02.08.2012, 21:48
CREATE OR REPLACE FUNCTION word_count (in_w IN NUMBER)
RETURN NUMBER; точку с запятой попробуйте) и words уберите)

если что то вот синтаксис)

Oracle 11 SQL
1
2
3
4
5
6
7
8
9
CREATE OR REPLACE FUNCTION employer_details_func
   RETURN VARCHAR(20);
IS 
   emp_name VARCHAR(20); 
BEGIN 
  SELECT first_name INTO emp_name
    FROM emp_tbl WHERE empID = '100';
  RETURN emp_name;
END;


ПС люди добрые научите писать код в странице правильно как у вас))
0
0 / 0 / 0
Регистрация: 31.07.2012
Сообщений: 10
02.08.2012, 23:43  [ТС]
words убрала, спасибо, глупая ошибка.
Все равно что-то не то.
Я из sql*plus делаю вызов файла
@function
До этого прописала SET SERVEROUTPUT ON
В файле есть вызов функции и по идее должно мне вывести фразу: Count words 26
Мне пишет

Function created.

No errors.
4

Самой фразы нет. Что я не так делаю?
0
Эксперт Java
 Аватар для turbanoff
4094 / 3828 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 12
03.08.2012, 07:12
Возможно, перед PUT_LINE, необходимо выполнить
Oracle 11 SQL
1
DBMS_OUTPUT.ENABLE;

Не по теме:

Цитата Сообщение от Lutrix Посмотреть сообщение
научите писать код в странице правильно как у вас))
Смотрите внимательней на редактор сообщений, там куча кнопок. Почти каждая - bbcode.
Например для PL/SQL bbcode такой: [PLSQL_][/PLSQL]

0
0 / 0 / 0
Регистрация: 31.07.2012
Сообщений: 10
03.08.2012, 13:47  [ТС]
При вызове функции не хватало третьей скобки, в этом и ошибка.
Oracle 11 SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
CREATE OR REPLACE FUNCTION word_count (in_w IN NUMBER)
RETURN NUMBER
AS
words NUMBER := in_w;
BEGIN
words := words + 1;
RETURN words;
END;
 
/
SHOW ERRORS FUNCTION word_count;
 
 
BEGIN
DBMS_OUTPUT.ENABLE;
DBMS_OUTPUT.PUT_LINE('Count words '|| word_count(TO_NUMBER('25')));
END;
/
Работает и без DBMS_OUTPUT.ENABLE;
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
03.08.2012, 13:47
Помогаю со студенческими работами здесь

Ошибка "Encountered the symbol 'end-of-file' when expecting one of the following"
CREATE OR REPLACE PROCEDURE PROCEDURE_01 IS DECLARE TYPE GENERIC_CURSOR IS REF CURSOR; cur1 GENERIC_CURSOR; TYPE AGEN_AID IS...

Ошибка PLS-00103
Доброго времени суток. Пытаюсь скомпилировать функцию, но выдается ошибка: create or replace function policy (state integer default...

Ошибка PLS-00103
Здравствуйте. Делаю по примеру данному в университете, и почему то получаю ошибку. БД - Oracle 18 Среда - SQL Developer 19.2 ...

Создание функций и процедур в PL/SQL ошибка PLS-00103
Стоит задача вывести из таблицы с заказами номер заказа и сумму в формате &quot;N рублей, M копеек&quot; Здесь я по сути просто для рублей...

ОШИБКА в строке 38: PLS-00103: обнаружен символ «конец файла» при ожидании одного из следующих событий:
Oracle Database 10g Express Edition CREATE OR REPLACE PACKAGE BODY swim IS PROCEDURE add_rows is BEGIN SAVEPOINT p1; ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru