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

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

  Все выпуски  

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


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

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

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

BahuL
Статус: 3-й класс
Рейтинг: 67
∙ повысить рейтинг >>
Бородин Константин Игоревич
Статус: 8-й класс
Рейтинг: 51
∙ повысить рейтинг >>
Анатолий Ясень
Статус: 7-й класс
Рейтинг: 39
∙ повысить рейтинг >>

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

Выпуск № 413
от 12.03.2009, 01:35

Администратор:Калашников О.А.
В рассылке:Подписчиков: 480, Экспертов: 29
В номере:Вопросов: 3, Ответов: 8

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

Вопрос № 161976: Добрый день вопрос пока больше теоретический но ... Есть база данных MSSQL 2005 в которой есть таблица KONEKT. В эту таблицу приложение записывает всех на данный момент подключенных пользователей и периодически для каждого пользователя запи...


Вопрос № 161997: Здравствуйте! Прошу вашей помощи в решении на первый взгляд простой задачи: у меня есть например таблица из 5 столбцов, все данные типа char(2) (см. приложение). Помогите мне составить запрос, что бы при указании первых трех значений...
Вопрос № 162192: Здравствуйте, господа эксперты. У меня есть к вам вопрос, надеюсь вы мне поможете! У меня дома локальная сеть из 2-х компьютеров....На одном я установил MySQL, а с другого компа я немогу к базе подключиться. В чем может быть проблема? ...

Вопрос № 161.976
Добрый день

вопрос пока больше теоретический но ...
Есть база данных MSSQL 2005 в которой есть таблица KONEKT. В эту таблицу приложение записывает всех на данный момент подключенных пользователей и периодически для каждого пользователя записывает его текущий статус. При запуске приложения, оно запрашивает количество подключенных пользователей запросом
SELECT COUNT(*) FROM KONEKT
Доступ к базе данных полный, к приложению нет

Есть ли возможность заставить базу отвечать на этот и только этот запрос конкретной цифрой, например 1.
Отправлен: 04.03.2009, 10:07
Вопрос задал: Jurijs Mahinovs (статус: Посетитель)
Всего ответов: 3
Мини-форум вопроса >>> (сообщений: 1)

Отвечает: Челноков Виктор Альбертович
Здравствуйте, Jurijs Mahinovs!
Конечно непонятно для чего запрашивать кол. строк, а в ответ конкретную цифру.

Создайте хранимую процедуру и возвращаемое значение return 4. цифра может быть любой.
CREATE PROCEDURE proba

AS
BEGIN

SELECT COUNT(*) FROM KONEKT

return 4
END
Ответ отправил: Челноков Виктор Альбертович (статус: Студент)
Ответ отправлен: 04.03.2009, 10:26

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

    Оценка за ответ: 3
    Комментарий оценки:
    ключевая фраза была
    Доступ к базе данных полный, к приложению нет
    ваше предложение не сработает потому что имей я возможность изменить запрос в приложении, вопрос бы и не возник


    Отвечает: Hubbitus
    Здравствуйте, Jurijs Mahinovs!

    Нет, COUNT это стандартная аггрегирующая функция, переопределить ее Вам не удастся.
    Ответ отправил: Hubbitus (статус: 3-й класс)
    Ответ отправлен: 04.03.2009, 12:51

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

    Оценка за ответ: 5
    Комментарий оценки:
    Спасибо, в сторону count копать не буду :)


    Отвечает: Digitall
    Здравствуйте, Jurijs Mahinovs!
    подобный финт можно провернуть если таблицу KONEKT удалить, и создать "вьюшку" KONEKT возвращающую только одну строку.
    И создать для нее ничего не делающие триггера на запись, обновление , удаление.
    Ответ отправил: Digitall (статус: 1-й класс)
    Ответ отправлен: 04.03.2009, 14:29

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

    Оценка за ответ: 5
    Комментарий оценки:
    Спасибо, этот вариант вполне может и сработать, надо будет проверить


    Вопрос № 161.997
    Здравствуйте!

    Прошу вашей помощи в решении на первый взгляд простой задачи: у меня есть например таблица из 5 столбцов, все данные типа char(2) (см. приложение).
    Помогите мне составить запрос, что бы при указании первых трех значений, я получал элемент, который максимальное количество раз встречается во всех строчках таблицы при данных трех значениях. Например, из нижней таблицы, я задал первые три значения 1 2 2, в итоге должно получиться 4, т.к. оно максимальное количество раз встречается при заданном наборе первых трех значений.

    Заранее спасибо!

    Приложение:

    Отправлен: 04.03.2009, 12:52
    Вопрос задал: Ole (статус: 3-й класс)
    Всего ответов: 4
    Мини-форум вопроса >>> (сообщений: 0)

    Отвечает: Hubbitus
    Здравствуйте, Ole!
    >Помогите мне составить запрос, что бы при указании первых трех значений, я получал элемент, который максимальное количество раз встречается во всех строчках таблицы при данных трех значениях.
    На сколько я понял нужно посчитать количество строк, значения в первых 3х столбцах совпадают с данными, так?

    SELECT COUNT(*) FROM tablename WHERE field1 = 1 AND field2 = 2 AND field3 = 3
    Ответ отправил: Hubbitus (статус: 3-й класс)
    Ответ отправлен: 04.03.2009, 13:42

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


    Отвечает: Челноков Виктор Альбертович
    Здравствуйте, Ole!
    Попробуйте запрос

    select top (1) t4
    from (
    SELECT t1, t2, t3, t4,count(t4)as t5
    FROM Table_2
    where t1='1' and t2='2' and t3='3'
    GROUP BY t1, t2, t3, t4) as tem
    order by t5 desc

    Table_2 - название табл.
    t1, t2, t3, t4 - названия столбцов.
    sql 2005
    Ответ отправил: Челноков Виктор Альбертович (статус: Студент)
    Ответ отправлен: 04.03.2009, 13:58

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


    Отвечает: PVS@Lviv
    Здравствуйте, Ole!
    Pre Scriptum: нужно, наверное, вводить правило "В вопросах по базам данных обязательно указывать СУБД" . От этого ответ может оказатся значительно проще.


    Вот примерный синтаксис (должен работать в firebird, с небольшими изменениями в Sybase AS* и DB2 и, возможно, MSSQL):

    WITH
    subq_a (f1, f2, f3 ,f4, f4c) AS ( SELECT f1,f2,f3,f4,count(all *) from tab group by f1,f2,f3,f4),
    subq_b (f1, f2, f3 ,f4, f4c) AS ( SELECT f1,f2,f3,f4,count(all *) from tab group by f1,f2,f3,f4)
    SELECT a.f1,a.f2,a.f3,a.f4
    FROM subq_a a, subq_b b
    where
    a.f1=b.f1 and
    a.f2=b.f2 and
    a.f3=b.f3
    group by a.f1,a.f2,a.f3,a.f4
    having
    a.f4c=max(b.f4c)
    Ответ отправил: PVS@Lviv (статус: Профессионал)
    Украина, Львов
    ----
    Ответ отправлен: 04.03.2009, 14:02

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


    Отвечает: Digitall
    Здравствуйте, Ole!
    плохо что в вопросе не указана база данных.
    привожу пример для оракла:

    Приложение:

    Ответ отправил: Digitall (статус: 1-й класс)
    Ответ отправлен: 04.03.2009, 14:47

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


    Вопрос № 162.192
    Здравствуйте, господа эксперты. У меня есть к вам вопрос, надеюсь вы мне поможете!
    У меня дома локальная сеть из 2-х компьютеров....На одном я установил MySQL, а с другого компа я немогу к базе подключиться. В чем может быть проблема?
    Отправлен: 06.03.2009, 13:29
    Вопрос задал: Qepka15
    Всего ответов: 1
    Мини-форум вопроса >>> (сообщений: 1)

    Отвечает: Hubbitus
    Здравствуйте, Qepka15!
    По данному описанию могу сказать что проблема может быть в чем угодно!
    Проверьте следующее для начала:

    1) С локального компьтера можете получить доступ?
    2) MySQL сконфигурирован для доступа из сети? Посмотрите на какой IP-адресе и на каком порту.
    3) Вы именно на этот IP и порт коннектитесь удаленно? Не мешает ли фаерволл ни на той, ни на другой машине?
    Ответ отправил: Hubbitus (статус: 3-й класс)
    Ответ отправлен: 06.03.2009, 14:58

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


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

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

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

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

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

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


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

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

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

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

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

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


    © 2001-2009, Портал 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

    В избранное