Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/34: Рейтинг темы: голосов - 34, средняя оценка - 4.56
0 / 0 / 1
Регистрация: 27.06.2008
Сообщений: 47
1

Обратиться к таблице по её ID

22.10.2018, 12:00. Показов 6709. Ответов 9

Author24 — интернет-сервис помощи студентам
есть ID таблицы (таблица с таким ID есть в представлении ALL_OBJECTS

есть ли возможность обратиться к таблице для выборки... ну чтобы было что-то типа

select * from ("функция, возвращающая набор записей таблицы по её ID")

иными словами есть запись и ID таблицы, откуда взяты значение для полей.
нужно обратиться к таблице по ID (есть и другие ID для других записей) чтобы изменить значения полей записи
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
22.10.2018, 12:00
Ответы с готовыми решениями:

Обратиться к таблице, не зная её имени
Есть БД SQLite3. В ней одна таблица, имя этой таблицы заранее не известно. Имя таблицы получаем...

Как обратиться к временной таблице видимой во время выполнения?
Имеется 2 процедуры В главной создана временная таблица - в подчиненной нужно читать из нее...

Как в oracle обратиться к таблице и где и как в delphi 5 обратиться к бд?
как в oracle обратиться к таблице и где и как в delphi 5 обратиться к бд?

Обратиться к массиву, как к таблице
есть пример работающего кода, приведен ниже, там вроде вопросов нет, массив, к нему потом...

9
3499 / 2083 / 742
Регистрация: 02.06.2013
Сообщений: 5,078
22.10.2018, 12:12 2
https://docs.microsoft.com/ru-... erver-2017
0
0 / 0 / 1
Регистрация: 27.06.2008
Сообщений: 47
22.10.2018, 12:38  [ТС] 3
ну то есть найти ИМЯ таблицы по ID и прицепить его к инструкции SQL а потом её Exec?
0
3499 / 2083 / 742
Регистрация: 02.06.2013
Сообщений: 5,078
22.10.2018, 12:49 4
po_saa`, да.
0
0 / 0 / 1
Регистрация: 27.06.2008
Сообщений: 47
22.10.2018, 13:02  [ТС] 5
я думал об этом... это самый простой и очевидный способ

однако должен быть цивильный метод по которому сам SQL сервер ищет таблицы.
ведь для чего-то же сделан object_id


при поиске таблицы (из запроса например) сервер очевидно ищет ID по имени, типа OBJECT_ID(имя_таблицы, имя_бд)
а потом использует наверное ID таблицы для ссылки на объект
0
3499 / 2083 / 742
Регистрация: 02.06.2013
Сообщений: 5,078
22.10.2018, 13:20 6
po_saa`, в DDL и DML инструкциях используются имена объектов, а не их ID'ы. Никаких других более "цивильных" вариантов нет.
0
0 / 0 / 1
Регистрация: 27.06.2008
Сообщений: 47
22.10.2018, 14:54  [ТС] 7
триггеры это те же самые запросы и с точки зрения системы они отличаются только событием, на которые они реагируют. А запрос отрабатывает обычным порядком.
А вот ID - он для системы, потому что система не работает с текстом.
Именно поэтому и прикручен OBJECT_ID.
Потому что ID это смещение в адресном пространстве на номер записи.
Список таблиц - это тоже таблица.
0
3499 / 2083 / 742
Регистрация: 02.06.2013
Сообщений: 5,078
22.10.2018, 15:52 8
Цитата Сообщение от po_saa` Посмотреть сообщение
триггеры это те же самые запросы и с точки зрения системы они отличаются только событием, на которые они реагируют. А запрос отрабатывает обычным порядком.
А вот ID - он для системы, потому что система не работает с текстом.
Именно поэтому и прикручен OBJECT_ID.
Потому что ID это смещение в адресном пространстве на номер записи.
Список таблиц - это тоже таблица.
Это все к чему? Обоснование необходимости указывать вместо имен объекетов их ID?
Или вас удручает необходимость пользоваться динамикой? Ну так таков удел всех, кто выбирает архитектуру с множеством таблиц одинаковой структуры вместо единой.
Хотя облегчить страдания и уйти от динамики можно, но писанины будет много. Вот пример:
T-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
34
35
36
37
38
39
40
41
42
use tempdb;
go
 
create table dbo.Table1 (id int identity, v int, table_id int default (1), check (table_id = 1), primary key (id, table_id));
create table dbo.Table2 (id int identity, v int, table_id int default (2), check (table_id = 2), primary key (id, table_id));
go
 
create view dbo.vAggregatedTable
as
select table_id, id, v from dbo.Table1
union all
select table_id, id, v from dbo.Table2
go
 
insert into dbo.Table1 (v) values (1);
insert into dbo.Table2 (v) values (2);
 
select * from dbo.vAggregatedTable;
select * from dbo.Table1;
select * from dbo.Table2;
go
 
declare @t table (table_id int, id int, new_v int);
insert into @t
values
 (1, 1, 10), (2, 1, 20);
 
update vagt
 set
  v = t.new_v
from
 @t t join
 dbo.vAggregatedTable vagt on vagt.table_id = t.table_id and vagt.id = t.id;
 
select * from dbo.vAggregatedTable;
select * from dbo.Table1;
select * from dbo.Table2;
go
 
drop view dbo.vAggregatedTable;
drop table dbo.Table1, dbo.Table2;
go
Подробнее читайте в документации о секционированных представлениях.
0
0 / 0 / 1
Регистрация: 27.06.2008
Сообщений: 47
22.10.2018, 17:01  [ТС] 9
>>Это все к чему? Обоснование необходимости указывать вместо имен объекетов их ID?

нет, не "обоснование" просто попытка найти системную процедуру, которая интуитивно должна быть , поскольку, с точки зрения программера БД, именно так строятся массивы в памяти, а следовательно и структура БД в целом.
0
3499 / 2083 / 742
Регистрация: 02.06.2013
Сообщений: 5,078
22.10.2018, 17:58 10
Цитата Сообщение от po_saa` Посмотреть сообщение
просто попытка найти системную процедуру, которая интуитивно должна быть
Остается только пожелать успехов в поисках.
Но лучше потратьте время на изучение показанного примера. Думается пользы и знаний от этого получите гораздо больше.
0
22.10.2018, 17:58
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
22.10.2018, 17:58
Помогаю со студенческими работами здесь

Как обратиться к таблице в скрипте js
Добрый день. Нужно перекрасить первую ячейку первой строки с помощью js. Чего я только не делал, а...

Как обратиться к таблице БД .sdf?
Вчера кое-как разобрался с бд .mdf, а сегодня торможу с этой проблемой. Создал новую локальную бд...

Как обратиться к конкретной строке в таблице бд?
Здравствуйте. Создал небольшую программу, которая подключается к БД и выводит всю информацию из...

Как обратиться к первой записи в таблице?
Добрый день! Есть таблица c полями ID. date. name. Как обратиться к наименьшей дате в данной...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru