Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: как объединить несколько таблиц

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
muspel
Отправлено: 30 Марта, 2012 - 14:47:27
Post Id


Новичок


Покинул форум
Сообщений всего: 8
Дата рег-ции: Дек. 2011  


Помог: 0 раз(а)




Добрый день! Имеется несколько таблиц: t1, t2, t3... Допустим, в каждой только один столбец id.
Как слить все эти таблицы в одну res одним запросом?
сам нашел только такое решение:

foreach($tables as $table)
INSERT INTO res SELECT id FROM $table

но мне это представляется корявым...

Спасибо!
 
 Top
ПТО
Отправлено: 30 Марта, 2012 - 14:57:34
Post Id



Посетитель


Покинул форум
Сообщений всего: 395
Дата рег-ции: Янв. 2012  


Помог: 3 раз(а)




muspel пишет:
Добрый день! Имеется несколько таблиц: t1, t2, t3... Допустим, в каждой только один столбец id.
Как слить все эти таблицы в одну res одним запросом?
сам нашел только такое решение:

foreach($tables as $table)
INSERT INTO res SELECT id FROM $table

но мне это представляется корявым...

Спасибо!

Какие столбцы у двух других ?
 
 Top
muspel
Отправлено: 30 Марта, 2012 - 15:03:55
Post Id


Новичок


Покинул форум
Сообщений всего: 8
Дата рег-ции: Дек. 2011  


Помог: 0 раз(а)




таблицы с одинаковой структурой, то есть в каждой только столбец id
 
 Top
ПТО
Отправлено: 30 Марта, 2012 - 15:22:42
Post Id



Посетитель


Покинул форум
Сообщений всего: 395
Дата рег-ции: Янв. 2012  


Помог: 3 раз(а)




muspel пишет:
таблицы с одинаковой структурой, то есть в каждой только столбец id

НУ смотри, средствами скуэл это делается. Так как ты не понимаешь и жмешься, чтобы назвать столбики , а так же не говоришь, КАК их тебе надо объединить, по какому принципу, то и ответить тебе точно не получится.
SELECT * FROM (t1 LEFT JOIN t2 USING(id)) LEFT JOIN t3 USING (id)
 
 Top
muspel
Отправлено: 30 Марта, 2012 - 15:30:52
Post Id


Новичок


Покинул форум
Сообщений всего: 8
Дата рег-ции: Дек. 2011  


Помог: 0 раз(а)




нет, я, видимо, неправильно выразился, извиняюсь. И я не жмусь, просто пример такой)
в общем, таблицы:
t1.id | t2.id | t3.id
1 | 2 | 3
4 | 5 | 6
нужно получить:
res.id
1
2
3
4
5
6

(Отредактировано автором: 30 Марта, 2012 - 15:31:47)

 
 Top
ПТО
Отправлено: 30 Марта, 2012 - 15:36:22
Post Id



Посетитель


Покинул форум
Сообщений всего: 395
Дата рег-ции: Янв. 2012  


Помог: 3 раз(а)




muspel пишет:
нет, я, видимо, неправильно выразился, извиняюсь. И я не жмусь, просто пример такой)
в общем, таблицы:
t1.id | t2.id | t3.id
1 | 2 | 3
4 | 5 | 6
нужно получить:
res.id
1
2
3
4
5
6

Ну тогда
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT * FROM t1 UNION ALL SELECT * FROM t2 UNION ALL SELECT * FROM t3;
 
 Top
muspel
Отправлено: 30 Марта, 2012 - 15:38:45
Post Id


Новичок


Покинул форум
Сообщений всего: 8
Дата рег-ции: Дек. 2011  


Помог: 0 раз(а)




Спасибо! еще раз извиняюсь за нечеткость формулировки
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB