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

Как сделать селект с временной таблицы обьявленной внутри процедуры

25.03.2014, 16:32. Показов 3456. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
CREATE OR REPLACE PROCEDURE history
(id NUMBER DEFAULT NULL,
e_date DATE DEFAULT NULL)
IS
TYPE temptable IS TABLE OF hist_all%rowtype
INDEX BY binary_integer;
ttable temptable;
BEGIN
.......
......
SELECT * BULK COLLECT 
    INTO ttable
    FROM hist a
    WHERE a.id=history.id AND a.date_f<=history.e_date;
Как вывести данные с таблицы ttable?

Добавлено через 16 минут
ребята, прошу помочь...горит
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.03.2014, 16:32
Ответы с готовыми решениями:

Сделать, чтобы в зависимости от выбранного значения внутри Radiogroup менялась функция внутри процедуры rasposn
Мне нужно чтоб в зависимости от выбранного значения внутри радио группа (rgTypeCis) менялась функция внутри процедуры rasposn. Внутри...

Селект из 2-х таблиц, как сделать?
А как сделать такое? Есть таб1. с полем Name (1000 уникальных записей), и есть таб2. тоже с полем Name (несколько записей) Нужно...

Как сделать через селект изменения?
Подскажите, как можно сделать селект так, чтобы при смене, менялись значения в инпутах jdoodle.com/a/QDO

7
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
25.03.2014, 16:37
Пробежаться в цикле?

PS
Это не называется "временная таблица", это называется коллекция. Временная таблица в Oracle - это та, которая создается с пом. CREATE GLOBAL TEMPORARY TABLE
0
0 / 0 / 0
Регистрация: 26.01.2013
Сообщений: 26
25.03.2014, 16:41  [ТС]
Grossmeister, можете примерчик показать как извлечь данные с коллекции?
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
25.03.2014, 17:02
SQL
1
2
3
4
5
FOR i IN 1..tab1.Count loop
    
  dbms_output.put_line(tab1(i).fld1);
 
END loop;
Если не знаем, с какого по какой индекс у коллекции, можно использовать методы First, Last, Next.
Все это описано в любой книжке или доке по PL/SQL
0
0 / 0 / 0
Регистрация: 26.01.2013
Сообщений: 26
25.03.2014, 17:10  [ТС]
SQL
1
2
3
4
FOR i IN 1..ttable.count loop
  dbms_output.put_line(ttable(i));
 
  END loop;
Написал для моего случая, но выдает ошибку
wrong number of types of arguments in call to put_line
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
25.03.2014, 17:24
Если бы у тебя коллекция состояла из простых типов (number, varchar2), то твой текст прокатил бы. Но у тебя коллекция состоит из record-ов, которую целиком вывести нельзя, только по полям. Поэтому я в своем примере и указал одно поле record-а
0
0 / 0 / 0
Регистрация: 26.01.2013
Сообщений: 26
26.03.2014, 09:57  [ТС]
т.е. вывести многомерную таблицу нельзя с таким обьявлением переменных?

Добавлено через 3 минуты
Запрос типа select * from TABLE(CAST(my_table AS my_table_type)) не подойдет здесь?

Добавлено через 6 минут
Мне нужно вернуть данные с коллекции в полной обьеме, не по 1 строке.

Добавлено через 40 минут
подскажите пожалуйста где я неправ?

Добавлено через 6 часов 4 минуты
Может кто-нибудь показать как на моем примере можно извлечт данные с коллекции?

Добавлено через 9 часов 28 минут
Grossmeister, help
сегодня здаваться(
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
26.03.2014, 10:20
Цитата Сообщение от Portlend
Запрос типа select * from TABLE(CAST(my_table AS my_table_type)) не подойдет здесь?
В Oracle исторически сложилось так, что есть 2 движка: SQL и PL/SQL. SELECT - это движок SQL. Движок SQL понимает только типы данных SQL. В SQL есть только 2 типа коллекций: nested table и varray. PL/SQL кроме того умеет работать и с третьим типом - index-by table. Так вот, у тебя определена именно index-by table, про которую SQL ничего не знает и, следовательно, ее нельзя использовать в SELECT.
Кроме того, чтобы ту же nested table можно было использовать в SELECT, такой тип д.б. определен на уровне БД, а не в процедуре/пакете (оттуда SQL тоже не может доставать типы). Ну и RECORD здесь не подходит (это тоже PL/SQL тип), нужно создавать OBJECT опять же на уровне БД.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.03.2014, 10:20
Помогаю со студенческими работами здесь

Как сделать селект пустым при загрузке?
Знаю, вопрос тупой, но что-то не могу найти, как сделать, чтоб при выводе из базы, выбранное значение в списке было пустым? Помогите...

Как сделать селект, отбрасывающий строки с круглой датой?
например у меня есть строки , в которых Date : 2019-03-01 14:08:42.053 2018-07-13 19:02:33.677 2018-12-12 00:00:00.000 2018-07-10...

Как можно удалить запись из временной таблицы?
подскажите как можно удалить запись из временной таблицы? я сначала создал таблицу потом при ее заполнении получаю список данных, удаляю...

Создание временной таблицы,где ее название-переменная,названия столбцов-поля другой таблицы ..
Помогите,пож-ста,справиться со следующей проблемой. Есть главная таблица с полями:дата,игрок,время начала,время конца,номер корта. ...

Как через pattern сделать форматирование временной зоны?
Формат типа -3, -2, -1, 0, +1, +2, +3 и.т.д


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
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