AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi String bei Sql Abfrage zu lang
Thema durchsuchen
Ansicht
Themen-Optionen

String bei Sql Abfrage zu lang

Ein Thema von Fridolin · begonnen am 18. Apr 2007 · letzter Beitrag vom 18. Apr 2007
Antwort Antwort
Fridolin

Registriert seit: 8. Jan 2007
71 Beiträge
 
Delphi 2006 Architect
 
#1

String bei Sql Abfrage zu lang

  Alt 18. Apr 2007, 14:11
Datenbank: mysql • Version: 5.2 • Zugriff über: mydac
Ich schon wieder ,

String zu lang, sagt er mir...

Hat jemand ne Idee, wie ich es anders machen kann?

myquery1.sql.text := ('select distinct fabrikat,modell,fahrerhaus,radstand,gesamtgewicht,trommel,luftansaugung,achsformel,volumen,ausfuehrung from fabrikate,modelle,fahrerhaeuser,radstaende,gg,trommeln,luftansaugungen,achsformeln,volumina,ausfuehrungen,bezeichnungen where fabrikate.f_id = '''+a+''') and (modelle.m_id = bezeichnungen.m_id and bezeichnungen.f_id = '''+a+''') and (fahrerhaeuser.fa_id = bezeichnungen.fa_id and bezeichnungen.f_id = '''+a+''') and (radstaende.r_id = bezeichnungen.r_id and bezeichnungen.f_id = '''+a+''') and (gg.g_id = bezeichnungen.g_id and bezeichnungen.f_id = '''+a+''') and (trommeln.t_id = bezeichnungen.t_id and bezeichnungen.f_id = '''+a+''') and (luftansaugungen.l_id = bezeichnungen.l_id and bezeichnungen.f_id = '''+a+''') and (achsformeln.ac_id = bezeichnungen.ac_id and bezeichnungen.f_id = '''+a+''') and (volumina.v_id = bezeichnungen.v_id and bezeichnungen.f_id = '''+a+''') and (ausfuehrungen.a_id = bezeichnungen.a_id and bezeichnungen.f_id = '''+a+''') ');
  Mit Zitat antworten Zitat
Benutzerbild von Schaedel
Schaedel

Registriert seit: 5. Jan 2006
Ort: Saarland
174 Beiträge
 
Delphi 2007 Professional
 
#2

Re: Sting bei Sql Abfrage zu lang

  Alt 18. Apr 2007, 14:13
benutz doch myquery1.sql.add('');
Und trenn ein paar mal den SQLstring damit

Sanfte Grüße!
Michael S.
  Mit Zitat antworten Zitat
Fridolin

Registriert seit: 8. Jan 2007
71 Beiträge
 
Delphi 2006 Architect
 
#3

Re: String bei Sql Abfrage zu lang

  Alt 18. Apr 2007, 14:22
Danke geht....

  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.033 Beiträge
 
Delphi 12 Athens
 
#4

Re: String bei Sql Abfrage zu lang

  Alt 18. Apr 2007, 14:26
Das hilft auch nicht unbedingt was, ich vermute mal der Compiler meckert schon rum?

Delphi speichert die Strinkonstanten als ShortString ab und die dürfen maximal 255 Zeichen lang sein.

Du kannst aber die Strings auch aufteilen ... einfach mit +

Die erste Stringkonstante war über 260 Byte lang:
Code:
myquery1.sql.text := ('select distinct fabrikat,modell,fahrerhaus,radstand,gesamtgewicht,trommel,luftansaugung,achsformel,volumen,ausfuehrung from fabrikate,modelle,fahrerhaeuser,[color=#ff0000][b]'+'[/b][/color]radstaende,gg,trommeln,luftansaugungen,achsformeln,volumina,ausfuehrungen,bezeichnungen where fabrikate.f_id = '''+a+''') and (modelle.m_id = bezeichnungen.m_id and bezeichnungen.f_id = '''+a+''') and (fahrerhaeuser.fa_id = bezeichnungen.fa_id and bezeichnungen.f_id = '''+a+''') and (radstaende.r_id = bezeichnungen.r_id and bezeichnungen.f_id = '''+a+''') and (gg.g_id = bezeichnungen.g_id and bezeichnungen.f_id = '''+a+''') and (trommeln.t_id = bezeichnungen.t_id and bezeichnungen.f_id = '''+a+''') and (luftansaugungen.l_id = bezeichnungen.l_id and bezeichnungen.f_id = '''+a+''') and (achsformeln.ac_id = bezeichnungen.ac_id and bezeichnungen.f_id = '''+a+''') and (volumina.v_id = bezeichnungen.v_id and bezeichnungen.f_id = '''+a+''') and (ausfuehrungen.a_id = bezeichnungen.a_id and bezeichnungen.f_id = '''+a+''') ');
PS SQL kommt doch auch mit " als Stringgegrenzung klar?
Eventuell könntest du damit auch noch etwas lesbarer arbeiten ... weniger '.

myquery1.sql.text := ('select distinct fabrikat,modell,fahrerhaus,radstand,gesamtgewicht,trommel,luftansaugung,achsformel,volumen,ausfuehrung from fabrikate,modelle,fahrerhaeuser,'+'radstaende,gg,trommeln,luftansaugungen,achsformeln,volumina,ausfuehrungen,bezeichnungen where fabrikate.f_id = "'+a+'") and (modelle.m_id = bezeichnungen.m_id and bezeichnungen.f_id = "'+a+'") and (fahrerhaeuser.fa_id = bezeichnungen.fa_id and bezeichnungen.f_id = "'+a+'") and (radstaende.r_id = bezeichnungen.r_id and bezeichnungen.f_id = "'+a+'") and (gg.g_id = bezeichnungen.g_id and bezeichnungen.f_id = "'+a+'") and (trommeln.t_id = bezeichnungen.t_id and bezeichnungen.f_id = "'+a+'") and (luftansaugungen.l_id = bezeichnungen.l_id and bezeichnungen.f_id = "'+a+'") and (achsformeln.ac_id = bezeichnungen.ac_id and bezeichnungen.f_id = "'+a+'") and (volumina.v_id = bezeichnungen.v_id and bezeichnungen.f_id = "'+a+'") and (ausfuehrungen.a_id = bezeichnungen.a_id and bezeichnungen.f_id = "'+a+'")'); Und alles in einer Zeile ist auch nicht sonderlich übersichtlich.
Wenn du dir angewönst alles spätestens an 'ner bestimmten Stelle umzubrechen, dann würdest du auch nicht mehr an diese Grenze gelangen.

Delphi-Quellcode:
myquery1.sql.text := ('select distinct fabrikat,modell,fahrerhaus,radstand,gesamtgewicht,trommel,'
  +'luftansaugung,achsformel,volumen,ausfuehrung from fabrikate,modelle,fahrerhaeuser,radstaende,'
  +'gg,trommeln,luftansaugungen,achsformeln,volumina,ausfuehrungen,bezeichnungen where fabrikate.'
  +'f_id = "'+a+'") and (modelle.m_id = bezeichnungen.m_id and bezeichnungen.f_id = "'+a+'") and '
  +'(fahrerhaeuser.fa_id = bezeichnungen.fa_id and bezeichnungen.f_id = "'+a+'") and (radstaende.'
  +'r_id = bezeichnungen.r_id and bezeichnungen.f_id = "'+a+'") and (gg.g_id = bezeichnungen.g_id '
  +'and bezeichnungen.f_id = "'+a+'") and (trommeln.t_id = bezeichnungen.t_id and bezeichnungen.'
  +'f_id = "'+a+'") and (luftansaugungen.l_id = bezeichnungen.l_id and bezeichnungen.f_id = "'+a
  +'") and (achsformeln.ac_id = bezeichnungen.ac_id and bezeichnungen.f_id = "'+a+'") and ('
  +'volumina.v_id = bezeichnungen.v_id and bezeichnungen.f_id = "'+a+'") and (ausfuehrungen.a_id '
  +'= bezeichnungen.a_id and bezeichnungen.f_id = "'+a+'")');
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: String bei Sql Abfrage zu lang

  Alt 18. Apr 2007, 14:28
Außerdem würde die Verwendung von Parametern sehr der Übersichtlichkeit dienen.
Markus Kinzler
  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 06:00 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