-
Не пойму в чем причина, написал запрос
select count(*) from mytable where article='100' and propid='40'
при открытии ADOQuery, выходит сообщение, что "групповая функция не является одногруппной", хотя в SQL Plus'e всё проходит на "ура". Что-то непонятно? Может кто сталкивался?
-
select article, propid, count(*)
from mytable
where article='100' and propid='40'
group by article, propid
-
Никто не сталкивался.
Кстати а что за субд?
-
Понял,спасибо
-
А в этом случае ошибка, что выражение не является выражением GROUP BY
-
> при открытии ADOQuery, выходит сообщение, что "групповая
> функция не является одногруппной",
так прямо и выходит ?
подробности для вопроизведения будут ?
> хотя в SQL Plus'e всё проходит на "ура".
везде должно проходить на ура
-
> Кстати а что за субд?
+1
такие простые агрегатные штуки должны работать
в oracle, работает
select
count(*)
from t_users U
where U.NAME like 'МЕЛ%' and U.STREET_ID = 0
в MSSQL, работает
SELECT count(*)
FROM [InterStart].[dbo].[vCTVConstSVCDeactivate]
where [INFO] = 'NotActive' and ID_SVC = 55
в Access, работает
SELECT
count(*)
FROM Answert
where Answert.[IdQuest] = 10 and Answert.[Value] = 0
-
про это и речь, поэтому и интересные вещи а какие подробности?
-
может свойства query какие-то на это влияют?
-
параметры есть? parse их?
-
Есть подозрение что в этой СУБД (клиенте ?) нет такой функции 'count' или не допускается выражение 'count(*)'
-
Все параметры по дефолту
-
Вот тольуо адо тут совершенно сбоку
-
А так ?
select count(A.*) from
(select article,propid from mytable where article='100' and propid='40') A
-
Это как-так в оракле нет count?
-
> Это как-так в оракле нет count?
ну вот нет
-
Ну а парсишь их?
Query.Parameters.ParseSQL ?
-
да, не работает, так и пишет
не сингл группа функция, к Ораклу
select count(*) from debtor
where REG_ID = :RI
с параметрами надо играть.
Cheked, Prepare, PARse
у меня заработало, короче
А к MSSQL это не обязательно, и так работает :)
-
У вас ADO кривое (или что-то еще)
object Form1: TForm1
Left = 0
Top = 0
Caption = 'Form1'
ClientHeight = 293
ClientWidth = 426
Color = clBtnFace
Font.Charset = DEFAULT_CHARSET
Font.Color = clWindowText
Font.Height = -11
Font.Name = 'Tahoma'
Font.Style = []
OldCreateOrder = False
PixelsPerInch = 96
TextHeight = 13
object Button1: TButton
Left = 332
Top = 252
Width = 75
Height = 25
Caption = 'Button1'
TabOrder = 0
OnClick = Button1Click
end
object db: TADOConnection
ConnectionString =
'Provider=OraOLEDB.Oracle.1;Password=bar;Persist Security I' +
'nfo=True;User ID=foo;Data Source=sles10'
Provider = 'OraOLEDB.Oracle.1'
Left = 32
Top = 24
end
object ds: TADODataSet
Connection = db
CommandText = 'SELECT COUNT(*) FROM arg_city WHERE country_code = '#39'RU'#39
Parameters = <>
Left = 128
Top = 24
end
end
procedure TForm1.Button1Click(Sender: TObject);
begin
db.Connected := true;
ds.Open;
try
ShowMessageFmt('count = %s', [ds.Fields[0].AsString]);
finally
ds.Close;
end;
end;
результат вполне адекватен
-
> Parameters = <>
а глючит, когда они есть