Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> SQL , создание базы данных, написание хранимых sp(вроде паписал но.. 
:(
    Опции темы
Berliner
Дата 27.3.2006, 15:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 803
Регистрация: 18.5.2005

Репутация: нет
Всего: 2



Вот подкинули задание
есть база маленькая собирает погоду для регионов(стран).
Вот хранимые процедуры которые надо реализовать.
sp_fetch_within_day(процедура которую нужно сделать) data_within_day(таблица с данными) -Returns data for a specified data item (temperature, sunlight etc), falling between the start date/time and end/time and at the specified resolution.

sp_fetch_daily_summary (процедура нужно сделать) data_daily_summary(таблица с данными) Returns data for a specified data item (temperature, sunlight etc), falling between the start date/time and end/time and at the specified resolution.

sp_create_daily_summary(процедура которую нужно сделать) data_within_day(таблица в данными) Reads a list of the available regions from table regions, and then processes each of the tables containing data collected during the day, calculates summaries, and stores the summarised data in the respective data_daily_summary_* table.

Одна из сложностей в том, для каждого региона (страны)данные храняться в ствоей талице

дело в том что для каждой старны есть своя таблица data_within_day_usa(для USA) или data_withing_day-russia
data_daily_summary_USA data_daily_summary_russia (любые другие страны)
есть таблица regions_def где храняться все дрегионы
и вот что написано в таске The stored procedure sp_create_daily_summary will read the list of regions available in the database, (from table regions_def) and then process all of the data collected during the day, for each of these regions.

эт тпипа такие запрсы будут

Fetch all data available on atmospheric pressure recorded during the day in the region of Russia, starting from 10-Sep-1984 to 25-Sept-2000, and return the data aggregated in 15-day intervals.

This query is of the generic form:

Select all data on <data item type> that is available as daily summary data for region <region> during [start date] and [end date] and aggregate the data using a resolution period of <N> days
я написал такую процедуру


Код

if object_id ('dbo.sp_fetch_within_day') is NOT NULL drop procedure dbo.sp_fetch_within_day
GO
create procedure dbo.sp_fetch_within_day
@temperature varchar
--.................
--................
--................ 
AS

SELECT C(temperature parameters or humidity, from where I can fetch them?) 
as T parameter
from tablewithparameters, data_item_def where (name=@temperature) 
and resolution(вот сюда не знаю что тулить).










а мне прислали такой шаблон:


Код

-- NOTE: generate_series() function requires postgres ver 8.X.X. 




  created a test table like this :

CREATE TABLE test (
 data_ts timestamp,
 epoch integer
)

I tried a sample resolution of 6 minutes = 360 seconds

-- I slightly redesigned the schema, converting timestamps in the data_ts to epoch (number of seconds), to reduce the type conversion time. I will redesign the schema later to use integers (ssm - seconds since midnight) insted of the timestamp.

Here is the query I run:

create temporary table sr as select * from generate_series(360,1800*24,360) as a;
update sr set a = a + (select min(epoch) from test);
create index ss on sr(a); 
select S.a,count(T.epoch) as cnt from sr S left join test T
on T.epoch >= S.a - 360 AND T.epoch <= S.a group by S.a order by S.a asc;

All I had to do to complete the query was to add the following aggregate functions:

first(), max(), min(), last(), sum()



Более подродно в приложении
непонимаю как надо эту задачу решать подскажите плиз.





Это сообщение отредактировал(а) Berliner - 27.3.2006, 16:12

Присоединённый файл ( Кол-во скачиваний: 1 )
Присоединённый файл  task.doc 100,00 Kb
PM   Вверх
Berliner
Дата 27.3.2006, 16:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 803
Регистрация: 18.5.2005

Репутация: нет
Всего: 2



подскажи плиз что нужно писать почему такая разница в моей схеме и этой sp которую другой человек написал, чтобы я от нее отталкивался

Код

if object_id ('dbo.sp_fetch_within_day') is NOT NULL drop procedure dbo.sp_fetch_within_day
GO
create procedure dbo.sp_fetch_within_day
@temperature varchar
--.................
--................
--................ 
AS

SELECT C(temperature parameters or humidity, from where I can fetch them?) 
as T parameter
from tablewithparameters, data_item_def where (name=@temperature) 
and resolution(вот сюда не знаю что тулить).



заказчик

Код


-- NOTE: generate_series() function requires postgres ver 8.X.X. 




  created a test table like this :

CREATE TABLE test (
 data_ts timestamp,
 epoch integer
)

I tried a sample resolution of 6 minutes = 360 seconds

-- I slightly redesigned the schema, converting timestamps in the data_ts to epoch (number of seconds), to reduce the type conversion time. I will redesign the schema later to use integers (ssm - seconds since midnight) insted of the timestamp.

Here is the query I run:

create temporary table sr as select * from generate_series(360,1800*24,360) as a;
update sr set a = a + (select min(epoch) from test);
create index ss on sr(a); 
select S.a,count(T.epoch) as cnt from sr S left join test T
on T.epoch >= S.a - 360 AND T.epoch <= S.a group by S.a order by S.a asc;

All I had to do to complete the query was to add the following aggregate functions:

first(), max(), min(), last(), sum()


PM   Вверх
Berliner
Дата 27.3.2006, 17:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 803
Регистрация: 18.5.2005

Репутация: нет
Всего: 2



может кто нибудь знает?
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1046 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.