Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2002.05.27;
Скачать: [xml.tar.bz2];

Вниз

агрегирующая функция для строкового типа   Найти похожие ветки 

 
DPetrovich   (2002-05-02 15:54) [0]

Подскажите, пожалуйста, как можно написать запрос с группировкой так что бы аггрегирующая функция в нём была для строк .
например, для набора
ID stroka
-------------
1 abc
1 def
2 ghi

написать запрос

select ID, sumstr(stroka) as sumstroka from table1 group by ID

и получить результат
ID sumstroka
-----------------
1 abcdef
2 ghi


 
wicked   (2002-05-02 18:36) [1]

имхо никак...


 
dimanchik   (2002-05-03 01:12) [2]

Я не знаю, есть ли в MSSQL User Define Functions?
Если есть, то можно попробовать.


 
sniknik   (2002-05-03 08:53) [3]

в MSSQL 2000 вроде есть. и если определить sumstr(ID) с выходом stroka то должно получится. Хотя не пробовал гарантий дать не могу.


 
DPetrovich   (2002-05-03 11:50) [4]

User Define Functions есть , я создал такую ...

CREATE FUNCTION [dbo].[aggrstr] (@str1 varchar(250), @str2 varchar(250) )
RETURNS varchar(250) AS
BEGIN
declare @str3 varchar(250)
select @str3=ltrim(rtrim(@str1))+ltrim(rtrim(@str2))
RETURN (@str3)
END


Однако ж на запрос

select [ID], [dbo].[aggrstr](stroka) as sumstroka
from Table1 group by ID

выскакивает ошибка

Column "Table1.stroka" is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause.


Значит всё так никак... Печально...


 
Delirium   (2002-05-03 13:44) [5]

В MSSQL нельзя создавать агрегатные функции, однако в вашем случае sniknik прав, достаточно создать функцию с входным параметром ID (хотя для универсальности можно передавать имя таблицы, и названия символьного и цифрового полей), а в самой функции организовать курсор и соответствующим образом его обработать.


 
DPetrovich   (2002-05-03 14:04) [6]

sniknik, Delirium спасибо большое!
Я сразу не понял какую функцию нужно писать. Если передавать ID и делать через курсор, то действительно получится!




Страницы: 1 вся ветка

Форум: "Базы";
Текущий архив: 2002.05.27;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.006 c
1-88455
Бульбаш
2002-05-17 16:45
2002.05.27
Смена клавиши табуляции


14-88627
DRUG
2002-04-19 17:59
2002.05.27
Regedit


7-88654
МИФИст
2002-03-02 21:19
2002.05.27
Определение типа протокола...


3-88360
agrig
2002-04-28 11:11
2002.05.27
Неправильное обновление поля типа N в парадоксе


1-88419
sj
2002-05-17 09:30
2002.05.27
Динамический массив как выходной параметр процедуры





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский