-
Не пойму в чем причина, написал запрос 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 = <>
а глючит, когда они есть
-
> а глючит, когда они есть
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
Connected = True
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 = :CC'
Parameters = <
item
Name = 'CC'
DataType = ftString
Size = -1
Value = Null
end>
Left = 128
Top = 24
end
end procedure TForm1.Button1Click(Sender: TObject);
begin
db.Connected := true;
ds.Parameters.ParamByName('CC').Value := 'RU';
ds.Open;
try
ShowMessageFmt('count = %s', [ds.Fields[0].AsString]);
finally
ds.Close;
end;
end; И с параметрами не глючит. Это у тебя ADO кривое (или еще что)
-
теперь ты их в дизайне определил, а глючит, когда не до определишь в рантайме да и не глючит, а аккуратнее надо быть просто. У нас изначально какой вопрос был? Как автор такого добился. Я нашел как - именно если параметры в where не до определены.
-
> У нас изначально какой вопрос был?
У автора параметров изначально не было вообще. Ву компрене ? > Как автор такого добился.
автору давно пофиг, на вопрос в [5] ответа нет и не будет. Но, включив телепатор, могу предположить, что у автора кривой/не тот провайдер, кривое ADO или кривое то, что у программистов обычно из задницы растет. Более того, изменив пример на ADOQuery (вдруг местные последователи ислама правы в своих нападках на TADOQuery? ) я получил точно такой же результат, как с ADODataSet 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 = 340
Top = 224
Width = 75
Height = 25
Caption = 'Button1'
TabOrder = 0
OnClick = Button1Click
end
object Button2: TButton
Left = 340
Top = 260
Width = 75
Height = 25
Caption = 'Button2'
TabOrder = 1
OnClick = Button2Click
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
Parameters = <
item
Name = 'CC'
DataType = ftString
Size = -1
Value = Null
end>
Left = 128
Top = 24
end
object q: TADOQuery
Connection = db
Parameters = <>
SQL.Strings = (
'SELECT COUNT(*) FROM arg_city WHERE country_code = '#39'RU'#39)
Left = 204
Top = 24
end
end unit main;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, DB, ADODB, StdCtrls;
type
TForm1 = class(TForm)
db: TADOConnection;
ds: TADODataSet;
Button1: TButton;
q: TADOQuery;
Button2: TButton;
procedure Button1Click(Sender: TObject);
procedure Button2Click(Sender: TObject);
end;
var
Form1: TForm1;
implementation
procedure TForm1.Button1Click(Sender: TObject);
begin
db.Connected := true;
ds.Parameters.ParamByName('CC').Value := 'RU';
ds.Open;
try
ShowMessageFmt('count = %s', [ds.Fields[0].AsString]);
finally
ds.Close;
end;
end;
procedure TForm1.Button2Click(Sender: TObject);
begin
db.Connected := true;
q.Open;
try
ShowMessageFmt('count = %s', [q.Fields[0].AsString]);
finally
q.Close;
end;
end;
end. число записей одинаковое.
|