Отправляет email-рассылки с помощью сервиса Sendsay

RFpro.ru: Базы данных MySQL

  Все выпуски  

RusFAQ.ru: Базы данных SQL


Хостинг Портала RusFAQ.ru:
MosHoster.ru - Профессиональный хостинг на Windows 2008

РАССЫЛКИ ПОРТАЛА RUSFAQ.RU

Чемпионы рейтинга экспертов в этой рассылке

Шевченко Дмитрий
Статус: 9-й класс
Рейтинг: 50
∙ повысить рейтинг >>
Рыбин Павел
Статус: Студент
Рейтинг: 27
∙ повысить рейтинг >>
Анатолий Бурнашев
Статус: 3-й класс
Рейтинг: 24
∙ повысить рейтинг >>

/ КОМПЬЮТЕРЫ И ПО / Языки программирования / Базы данных SQL

Выпуск № 401
от 07.01.2009, 04:35

Администратор:Калашников О.А.
В рассылке:Подписчиков: 449, Экспертов: 31
В номере:Вопросов: 1, Ответов: 2

Нам важно Ваше мнение об этой рассылке.
Оценить этот выпуск рассылки >>

Вопрос № 156432: Уважаемые эксперты, помогите решить следующую задачу: Есть 2 таблицы, names(id,name) и values(id,pid,user_id,value). В names хранятся названия параметров, в values их значения. Мне нужно одним запросом получить название параметра и его значение...


Вопрос № 156.432
Уважаемые эксперты, помогите решить следующую задачу:
Есть 2 таблицы, names(id,name) и values(id,pid,user_id,value).
В names хранятся названия параметров, в values их значения. Мне нужно одним запросом получить название параметра и его значение, у меня получился следующий запрос:
Код:
SELECT
nm.*,vl.value FROM `names` nm,`values` vl WHERE vl.pid=nm.id AND vl.user_id={вставляется ID} LIMIT 1


Данный запрос прекрасно работает, но только при условии, что в values существует подходящая запись, если таковой нет то ничего не возвращает, а мне нужно, чтобы если нет удовлетворяющих записей возвращалось пустое значение value.
Отправлен: 02.01.2009, 04:21
Вопрос задал: Миленин Александр (статус: Студент)
Всего ответов: 2
Мини-форум вопроса >>> (сообщений: 2)

Отвечает: Виктор Пырлик
Здравствуйте, Миленин Александр!

Вы не указали СУБД, но по синтаксису могу предположить что это MySQL.

Во первых – не используйте служебные слова в личных целях (именование объектов, как то – «values” “value” “names” и т.д.) – это не просто дурной тон, что и чисто практически связано с множеством проблем и ошибок.

Во вторых – Ваше требование не логично.
«показать все записи родительской таблицы удовлетворяющие условию для подчиненной таблицы». И при этом, если нет записей в дочерней таблице – показать в родительской.. простите что?? Показать всё???

Ну и вот примеры запросов:
Возвращает только записи пересечения
Код:
SELECT 
names.id,
names.name,
`values`.value
FROM `values`
JOIN names ON (`values `.pid = names.id and `values`.user_id = 1)


Правое объединение

Код:
SELECT 
names.id,
names.name,
`values`.value
FROM `values`
RIGHT OUTER JOIN names ON (`values`.pid = names.id and `values`.user_id = 1)


Аналогичные с WHERE

Код:
SELECT 
names.id,
names.name,
`values`.value
FROM `values`
JOIN names ON (`values`.pid = names.id )
Where `values`.user_id = 1



---------
Жизнь игрушка – пока играешь сам..
Ответ отправил: Виктор Пырлик (статус: Профессионал)
Россия, Екатеринбург
Тел.: 89043822027
ICQ: 490191733
----
Ответ отправлен: 02.01.2009, 10:22

Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 240145 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!

    Оценка за ответ: 5
    Комментарий оценки:
    Большое спасибо за ответ, вы мне очень помогли.


    Отвечает: Цепковский Антон Сергеевич
    Здравствуйте, Миленин Александр!

    Если используется MySQL, то используйте внутреннюю условную функцию IF:

    IF(x,y,z) — если x = true (вернее, если x не равен 0 и не NULL), выдаёт y, если нет — z.

    К примеру, в форуме хранится информация о пользователях и есть возможность не показывать другим пользователям свой Email. Делается поле show_email, в котором лежит 0, если пользователь не хочет показывать адрес, и 1, если разрешает.

    SELECT ..., IF (show_email,CONCAT('<a href=mailto:',email,'>написать письмо</a>'),'адрес не указан') AS email, ...

    С уважением,
    Антон Цепковский
    ---------
    Вся наша жизнь - RPG
    Ответ отправил: Цепковский Антон Сергеевич (статус: Студент)
    Ответ отправлен: 05.01.2009, 17:31

    Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 240343 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!


    Вы имеете возможность оценить этот выпуск рассылки.
    Нам очень важно Ваше мнение!
    Оценить этот выпуск рассылки >>

    Отправить вопрос экспертам этой рассылки

    Приложение (если необходимо):

    * Код программы, выдержки из закона и т.п. дополнение к вопросу.
    Эта информация будет отображена в аналогичном окне как есть.

    Обратите внимание!
    Вопрос будет отправлен всем экспертам данной рассылки!

    Для того, чтобы отправить вопрос выбранным экспертам этой рассылки или
    экспертам другой рассылки портала RusFAQ.ru, зайдите непосредственно на RusFAQ.ru.


    Форма НЕ работает в почтовых программах The BAT! и MS Outlook (кроме версии 2003+)!
    Чтобы отправить вопрос, откройте это письмо в браузере или зайдите на сайт RusFAQ.ru.

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров >>

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2008, Портал RusFAQ.ru, Россия, Москва.
    Авторское право: ООО "Мастер-Эксперт Про"
    Техподдержка портала, тел.: +7 (926) 535-23-31
    Хостинг: "Московский хостер"
    Поддержка: "Московский дизайнер"
    Авторские права | Реклама на портале

    ∙ Версия системы: 5.13 от 01.12.2008

    Яндекс Rambler's Top100
    RusFAQ.ru | MosHoster.ru | MosDesigner.ru
    RusIRC.ru | Kalashnikoff.ru | RadioLeader.ru

    В избранное