AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Count-Fehler

Ein Thema von Tsunami · begonnen am 11. Apr 2005 · letzter Beitrag vom 13. Apr 2005
Antwort Antwort
Tsunami

Registriert seit: 28. Feb 2005
3 Beiträge
 
#1

Count-Fehler

  Alt 11. Apr 2005, 16:21
Datenbank: Firebird • Version: 1.5.2.4731 • Zugriff über: Zeos 6.1.5 Patch 2
Ich versuche die Anzahl der Einträge einer Tabelle anzeigen zu lassen und benutze folgenden Code :

dmEasyQuery.qryCustomer.SQL.Add('SELECT count(*) as anzahl FROM CUSTOMER');
dmEasyQuery.qryCustomer.Open;

Es erscheint eine Fehlermeldung, das das Feld 'Cust_No' nicht gefunden wurde.
'Cust_No' ist aber sehr wohl in der Tabelle enthalten.
Wieso will diese Abfrage überhaupt etwas von 'Cust_No'?
Liegt es daran, das der Primäre Index auf dieses Feld zeigt?

Da ich ein Anfänger bin, benutze ich erstmal die Beispieldatenbank employee.fdb, die bei Zweos dabei war.

Wie kann ich mit der IBO-Console den Primären Index auf ein anderes Feld anlegen oder anders gefragt, wie kann ich überhaupt Felder für eine schnelle Suche indizieren?
  Mit Zitat antworten Zitat
Benutzerbild von glunzl
glunzl

Registriert seit: 21. Mär 2004
Ort: Reinbek
119 Beiträge
 
Delphi 7 Professional
 
#2

Re: Count-Fehler

  Alt 13. Apr 2005, 05:54
Moin! Ist noch etwas früh, aber läuft es ohne "as anzahl"

Gruss
glunzl
Michael
  Mit Zitat antworten Zitat
Benutzerbild von Airblader
Airblader

Registriert seit: 29. Okt 2004
Ort: Geislingen an der Steige
742 Beiträge
 
#3

Re: Count-Fehler

  Alt 13. Apr 2005, 06:08
Zitat von glunzl:
Moin! Ist noch etwas früh, aber läuft es ohne "as anzahl"

Gruss
glunzl
as anzahl ist hier aber nötig (wie sollte es denn sonst heißen)

@eröffner
ja, daran liegt es wohl. du machst aber nen großen, perfomancemäßig riesigen fehler.
du selektierst total unnötig die gesamte tabelle.
an deiner stelle würde ich etwas wie SELECT COUNT(`id`) schreiben. Ich hoffe du hast ne ID, denn sowas gehört
normal in ne tabelle rein =)

air
Ingo Bürk
Es nimmt der Augenblick, was Jahre geben.

Johann Wolfgang von Goethe
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.252 Beiträge
 
Delphi 2006 Professional
 
#4

Re: Count-Fehler

  Alt 13. Apr 2005, 07:30
Zitat von Airblader:
as anzahl ist hier aber nötig (wie sollte es denn sonst heißen)
Es ist nicht nötig das ein Feld einen bestimmten Namen hat
Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
var
  anzahl : Integer;
begin
  qryCustomer.Close;
  qryCustomer.SQL.Text := 'SELECT COUNT(id) FROM customer';
  qryCustomer.Open;
  anzahl := qryCustomer.Fields[0].AsInteger;
end;
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
bate

Registriert seit: 28. Jul 2004
Ort: Kahla
32 Beiträge
 
Delphi 7 Professional
 
#5

Re: Count-Fehler

  Alt 13. Apr 2005, 07:55
wenn qryCustomer irgend was mit TDataSet zu tun hat würd ich einfach

qryCustomer.RecordCount mal beanspruchen.

auserdem count(*) naja nimm den Primary Key und schau dann nocheinmal.
  Mit Zitat antworten Zitat
Benutzerbild von MagicAndre1981
MagicAndre1981

Registriert seit: 4. Jun 2004
Ort: Nordhausen
2.214 Beiträge
 
Delphi 7 Enterprise
 
#6

Re: Count-Fehler

  Alt 13. Apr 2005, 11:07
Zitat von bate:
wenn qryCustomer irgend was mit TDataSet zu tun hat würd ich einfach

qryCustomer.RecordCount mal beanspruchen.

auserdem count(*) naja nimm den Primary Key und schau dann nocheinmal.
RecordCount liefert doch bei einem SQL-Server nur die Ergebnisse zurück, die schon gefetch (also vom Server abgerufen) wurden. Damit erhält man nicht alle Datensätze.

Die Lösung von Sharky hab ich auch immer genutzt und das funktionuckelt.

André
André
  Mit Zitat antworten Zitat
bate

Registriert seit: 28. Jul 2004
Ort: Kahla
32 Beiträge
 
Delphi 7 Professional
 
#7

Re: Count-Fehler

  Alt 13. Apr 2005, 11:18
Zitat von MagicAndre1981:
RecordCount liefert doch bei einem SQL-Server nur die Ergebnisse zurück, die schon gefetch (also vom Server abgerufen) wurden. Damit erhält man nicht alle Datensätze.

Die Lösung von Sharky hab ich auch immer genutzt und das funktionuckelt.

André

Zitat von Delphi OnlineHilfer:
Description

Examine RecordCount to determine the total number of records in the recordset of the dataset component. Applications might use this property with RecNo to iterate through all the records in a dataset, though typically record iteration is handled with calls to First, Last, MoveBy, and Prior using Eof and Bof to set the limits of row traversing.
Also ich muss dir mal wiedersprechen. Wenn du das Property abfragst weis der Client wieviele Datensätze er erwarten muss. Selbst wenn du Async das ganze machst, und das Property abfragst weist du es. (Bei Async skipt er das Asyncron und fetcht sofort alles).

Wenn du mir das nicht glauben solltest schlag selber in der OH nach.
  Mit Zitat antworten Zitat
Benutzerbild von MagicAndre1981
MagicAndre1981

Registriert seit: 4. Jun 2004
Ort: Nordhausen
2.214 Beiträge
 
Delphi 7 Enterprise
 
#8

Re: Count-Fehler

  Alt 13. Apr 2005, 11:32
Mit den IBX-Komponenten hat das ebenfalls nie hingehauen. Du benutzt die BDE und dort ist das auch so wie du es schreibst.

André
André
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:32 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz