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]   

> Без описания
DlTA
Отправлено: 10 Марта, 2017 - 16:21:12
Post Id



Постоянный участник


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


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




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

ну есть у меня исходный id товара, и куча комплектных id других, но связь должна работать в обе стороны, то есть для вашего товара должны выдаваться конкретные id и для остальных вас нынешний id.
 
 Top
Мелкий Супермодератор
Отправлено: 10 Марта, 2017 - 16:36:58
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


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




Я прочитал трижды:
- что надо получить?
- чем не подходит классика М:М?


-----
PostgreSQL DBA
 
 Top
DlTA
Отправлено: 10 Марта, 2017 - 17:18:58
Post Id



Постоянный участник


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


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




в общем
мой товар ID | с чем оно комплектуется ID
1 | 2
2 | 3
3 | 1
это то что кажется корректно, но получается что нужно табличка по больше
1 | 2
2 | 1

2 | 3
3 | 2

3 | 1
1 | 3
либо писать запрос сравнивающий в двух направлениях

а хочется чет получше, есть?
 
 Top
Мелкий Супермодератор
Отправлено: 10 Марта, 2017 - 17:50:05
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


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




Т.е. если 1 комплектуется 2, это значит, что 2 всегда комплектуется 1?

Какая субд?
Для pg можно попробовать собрать с intarray табличку int[] комплектов и gin индексом поверх. Правда, в пролёте fk будут, но шевелиться должно внятно, довольно удобно и на заголовке строки сэкономить места.


-----
PostgreSQL DBA
 
 Top
DlTA
Отправлено: 10 Марта, 2017 - 18:16:14
Post Id



Постоянный участник


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


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




у меня MyISAM
 
 Top
Мелкий Супермодератор
Отправлено: 11 Марта, 2017 - 09:34:53
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


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




Крепитесь. Жизнь жестока.
Тут скоро всемирный день бекапов - не откладывайте, проверьте свои бекапы прямо сейчас. Проверьте, что помните как делать PitR и что реально можете это сделать, проведите учения. И да пощадит Ктулху ваши данные!

Ну а для mysql сложнее что-то сделать. На периферии сознания болтается мысль приклеить сбоку табличку из одного ai-поля просто ради сиквенса (а то не могу придумать реальный ключ), а основную табличку писать как сиквенс, id товара. Комплектными будут товары записанные под одним сиквенсом. Поиск комплектов для товара получается простой. FK сохра... А, мазохисты, ну да.
Какие ещё типовые запросы к связи ожидаются?


-----
PostgreSQL DBA
 
 Top
DlTA
Отправлено: 30 Марта, 2017 - 00:17:12
Post Id



Постоянный участник


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


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




Мелкий пишет:
...
Какие ещё типовые запросы к связи ожидаются?

ой блин, прочитал и ничего не понял,

а вообще сложил стары методом, смотрел что выбирать в 2х направлениях, вопхнул в функцию, и теперь уже пофигу, id получаю.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB