Форум программистов, компьютерный форум, киберфорум
Oracle
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
2 / 2 / 3
Регистрация: 20.03.2015
Сообщений: 112

Sql oracle Ввод нескольких товаров в один заказ

11.12.2016, 19:59. Показов 1134. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
У меня есть таблица Товар(код, название,...) и Продажа(код_продажа, код_товар, ...). Мне надо написать процедуру, добавления товара в продажу, но в одной продаже может участвовать несколько позиций товара, т.е. заполнение таблицы может быть примерно таким (111,1123,..)
(111,1156,..) и т.д.
У меня получается это реализовать только с помощью двух разных процедур. Можно ли это совместить в одной?

SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
/*Добавляем товар и создаем продажу*/
CREATE OR REPLACE PROCEDURE prodaji_INSERT_WITHOUT
    (NAME_TOV VARCHAR2,CENA_PRODAJI INTEGER, KOLICHESTVO_TOV INTEGER)
    IS
    TOVAR INTEGER;
    USLUGA INTEGER;
    BEGIN
    SELECT KOD INTO TOVAR FROM TOVAR1
    WHERE NAZVANIE = NAME_TOV AND CENA_PRODAJ=CENA_PRODAJI;
    INSERT INTO PRODAJA1 (KOD_PRODAJA,KOD_TOVAR,KOLICHESTVO) VALUES (ID_PRODAJA.NextVal,TOVAR,KOLICHESTVO_TOV);
    DBMS_OUTPUT.PUT_LINE('Товар добавлен');
END;
 
 
/*дополняем существующую продажу*/
CREATE OR REPLACE PROCEDURE prodaji_INSERT_DOPOLNIT_W
    (NAME_TOV VARCHAR2,CENA_PRODAJI INTEGER,KOLICHESTVO_TOV INTEGER)
    IS
    TOVAR INTEGER;
    PROVERKA INTEGER;
    prodaja INTEGER;
    BEGIN
    SELECT KOD INTO TOVAR FROM TOVAR1
    WHERE NAZVANIE = NAME_TOV AND CENA_PRODAJ=CENA_PRODAJI;
    SELECT MAX(KOD_PRODAJA) INTO prodaja FROM PRODAJA1;
    SELECT COUNT(*) INTO PROVERKA FROM PRODAJA1
    WHERE KOD_TOVAR=TOVAR AND KOLICHESTVO=KOLICHESTVO_TOV AND KOD_PRODAJA = prodaja;
    IF PROVERKA>0 THEN BEGIN
    DBMS_OUTPUT.PUT_LINE('Этот товар уже есть'||PROVERKA);RETURN;
    END;END IF;
    INSERT INTO PRODAJA1 (KOD_PRODAJA,KOD_TOVAR,KOLICHESTVO) VALUES (ID_PRODAJA.CURRVal,TOVAR,KOLICHESTVO_TOV);
    DBMS_OUTPUT.PUT_LINE('Товар добавлен');
END;
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.12.2016, 19:59
Ответы с готовыми решениями:

Возможен ли ввод нескольких данных в один textbox
Возможен ли ввод нескольких данных в один textbox??? Если да, то подскажите код пожалуйста, очень нужно. Спасибо заранее!!!

Заказ товаров: У всех разные характеристики
Делаю базу данных заказ товаров. Главная таблица заказ. В ней поле idZakaza является главным. Предприятие производит три вида...

Альтернатива Oracle (условие: использование языка SQL и процедурного PL/SQL)
Здравствуйте! Проблема такая: мне надо написать курсовой проект в котором управление БД, созданной в Oracle, производится через приложение...

3
0 / 0 / 0
Регистрация: 08.12.2016
Сообщений: 6
16.12.2016, 13:41
проверку на наличие записи можно сделать триггером ну или рыть в сторону конструкции MERGE, вставка - обновление (INSERT OR UPDATE)
0
22 / 20 / 3
Регистрация: 21.05.2013
Сообщений: 408
16.12.2016, 14:26
немного сумбурна описана задача попробуйте внести больше информации и начните с того что вам нужно получить в итоге. Как только сформулируете что вам необходимо так сразу же и ответ найдётся.
0
0 / 0 / 0
Регистрация: 08.12.2016
Сообщений: 6
16.12.2016, 16:37
если в одной продаже может быть неск. товаров , то это видится мне как две таблицы - мастер/детайл : в мастере вносится заголовок, типа, номер, дата , название точки , продавец и пр .. В детайл - номенклатура продаваемого товара, кколичество, цена пр ...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.12.2016, 16:37
Помогаю со студенческими работами здесь

Замена нескольких символов в строке, необязательно один на один
Здравствуйте. Помогите пожалуйста написать код для замены нескольких символов в заданной строке. К примеру, пользователь вводит в textbox...

Oracle, SQL, PL/SQL. В каком порядке изучать?
привет. скачал книжки для новичков по Oracle, SQL, PL/SQL. в какой последовательности надо изучать эти 3 штуковины? (вдруг кому...

Изменение запроса в зависимости от выбранных строк в нескольких DbGrid (в SQL получить значения из нескольких DataSet)
Здравствуйте. Есть таблицы и компоненты: Tbl_authors – Таблица авторов. С ней связаны компоненты: - ADOTable_authors, -...

Добавить несколько позиций в один заказ
Есть задача сделать базу данных в Access, для фирмы, которая продает сертификаты. Есть таблица "клиенты" и...

Joomla 1.5 + Virtuemart 1.1.9 (Заказ в один клик)
Здравствуйте, уважаемые форумчане. Возможно ли в корзине virtuemart 1.1.9 организовать оформление заказа в один клик. То есть перейдя в...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru