amixen
Новичок
MySql сложный запрос с JOIN с сортировкой по предыдущему SELECT'у
Приветствую люди!
Разрабатывая свой проект столкнулся с траблой и пока не нашел решения...
Есть:
таблица subdomains (домены),
таблица languages (языки и сообщения),
таблица settings (тут хранятся свойства).
CREATE TABLE `light_subdomains` (
`id` int(11) NOT NULL auto_increment,
`subdomain` varchar(25) NOT NULL default '',
`posted` timestamp NOT NULL default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=cp1251;
CREATE TABLE `light_settings` (
`id` int(11) NOT NULL auto_increment,
`field_id` int(11) NOT NULL default '0',
`phones` varchar(20) NOT NULL default '',
`fax` varchar(20) NOT NULL default '',
`email` varchar(50) NOT NULL default '',
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=cp1251;
Обязательно надо обращаться к таблице languages во всех запросах, так-как там лежат слова и предложения и много чего другого... Поэтому я делаю сложный запрос с использованием JOIN.
Задача:
взять из базы данные по доменам (таблица subdomains), потом в таком же порядке (по ID-шникам) взять данные из таблица settings.
Я сначала вытаскиваю данные из таблицы subdomains:
[sql]SELECT * FROM light_subdomains AS t ORDER BY t.subdomain[/sql]
id subdomain
3 `bbb`
4 `ddd`
2 `zzz`
Потом из таблицы settings (мне нужно было возвращать строки с данными в том же порядке, с сортировкой по field_id):
[sql]
SELECT t.*, light_languages.*
FROM light_settings AS t
LEFT JOIN light_languages ON light_languages.field_id=t.id
WHERE t.id IS NOT NULL AND t.field_id IN (3,4,2)
[/sql]
Но ессесно второй запрос возвращает данные не в том порядке в котором должен!
Можно не трогая первый запрос во втором какимто образом указать принудительную сортировку (где field_id=3, потом=4, потом=2) ???
Приветствую люди!
Разрабатывая свой проект столкнулся с траблой и пока не нашел решения...
Есть:
таблица subdomains (домены),
таблица languages (языки и сообщения),
таблица settings (тут хранятся свойства).
CREATE TABLE `light_subdomains` (
`id` int(11) NOT NULL auto_increment,
`subdomain` varchar(25) NOT NULL default '',
`posted` timestamp NOT NULL default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=cp1251;
CREATE TABLE `light_settings` (
`id` int(11) NOT NULL auto_increment,
`field_id` int(11) NOT NULL default '0',
`phones` varchar(20) NOT NULL default '',
`fax` varchar(20) NOT NULL default '',
`email` varchar(50) NOT NULL default '',
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=cp1251;
Обязательно надо обращаться к таблице languages во всех запросах, так-как там лежат слова и предложения и много чего другого... Поэтому я делаю сложный запрос с использованием JOIN.
Задача:
взять из базы данные по доменам (таблица subdomains), потом в таком же порядке (по ID-шникам) взять данные из таблица settings.
Я сначала вытаскиваю данные из таблицы subdomains:
[sql]SELECT * FROM light_subdomains AS t ORDER BY t.subdomain[/sql]
id subdomain
3 `bbb`
4 `ddd`
2 `zzz`
Потом из таблицы settings (мне нужно было возвращать строки с данными в том же порядке, с сортировкой по field_id):
[sql]
SELECT t.*, light_languages.*
FROM light_settings AS t
LEFT JOIN light_languages ON light_languages.field_id=t.id
WHERE t.id IS NOT NULL AND t.field_id IN (3,4,2)
[/sql]
Но ессесно второй запрос возвращает данные не в том порядке в котором должен!
Можно не трогая первый запрос во втором какимто образом указать принудительную сортировку (где field_id=3, потом=4, потом=2) ???