/ Forside / Teknologi / Udvikling / Delphi/Pascal / Nyhedsindlæg
Login
Glemt dit kodeord?
Brugernavn

Kodeord


Reklame
Top 10 brugere
Delphi/Pascal
#NavnPoint
oldwiking 603
jrossing 525
rpje 520
EXTERMINA.. 500
gandalf 460
gubi 270
DJ_Puden 250
PARKENSS 230
technet 210
10  jdjespers.. 200
SQL-Parser
Fra : Viktoria Runge


Dato : 05-12-02 22:05

Hej

Jeg skal, som hovedopgave, udvikle en SQL-Parser i Delphi men kender
intet til parserer. Er der en der kan anbefale en god bog hvori
teknikken er godt forklaret???


 
 
JM (08-12-2002)
Kommentar
Fra : JM


Dato : 08-12-02 22:14

05 Dec 2002 21:04:58 GMT, Viktoria Runge <viktoria@ofir.dk> skrev:
> Hej
>
> Jeg skal, som hovedopgave, udvikle en SQL-Parser i Delphi men kender
> intet til parserer. Er der en der kan anbefale en god bog hvori
> teknikken er godt forklaret???
>

En parser, er normalt noget, som omsætter tekst til symboler, og så smider
teksten væk, så man kun har symbolerne som memoteknik.

Men det er jo nok næppe det som det drejer sig om, ved en SQL-Parser?




Konrad (09-12-2002)
Kommentar
Fra : Konrad


Dato : 09-12-02 11:21

JM <ccc41290@vip.cybercity.dk> wrote in message news:<1108_1039382031@news.tele.dk>...
> 05 Dec 2002 21:04:58 GMT, Viktoria Runge <viktoria@ofir.dk> skrev:
> > Hej
> >
> > Jeg skal, som hovedopgave, udvikle en SQL-Parser i Delphi men kender
> > intet til parserer. Er der en der kan anbefale en god bog hvori
> > teknikken er godt forklaret???
> >
>
> En parser, er normalt noget, som omsætter tekst til symboler, og så smider
> teksten væk, så man kun har symbolerne som memoteknik.

Æhh...?

> Men det er jo nok næppe det som det drejer sig om, ved en SQL-Parser?

Bogen "Compilers - principles, techniques and tools" [populært
"Dragebogen"]
<http://www.amazon.com/exec/obidos/tg/detail/-/0201100886/103-3553698-1639001?vi=glance>
kan på det varmeste anbefales. Den omhandler alt det du søger.

mvh
dadk

Jens Dyekjær Madsen (11-12-2002)
Kommentar
Fra : Jens Dyekjær Madsen


Dato : 11-12-02 23:42

Gennerelt forstår jeg ved en parser, at den typisk omsætter teksten til symboler,
således at hvert ord, får et nummer. Dertil, så vil det via en tilstandsmaskine
være nogen tekster, såsom kommentarer som udelukkes, og ikke tages med i den
parsede tekst. Også store og små bogstaver, kan den evt. lade være at skilde
imellem. Samt anførselstegn, vil for flere sprog, medføre at deres indhold gemmes
seperat, og at den så også omsættes til et symbol. Dermed, så bliver hele teksten
komprimeret, til en hel masse symboler, som reelt kun er tal som er fortløbende
fra 0 til n. Og derved, så kan man forholdsvis enkelt holde styr på, og tilknytte
data, til hver enkelt ord, fordi at de kan gemmes i en variebel. Hvis at man
skulle bruge ordende som index, så vil der være milliarder af muligheder, og man
kunne ikke gemme data til dem på en pæn måde i en tabel. F.eks. så kan alle
addresserne gemmes til hvert ord, og f.eks. procedurenavnet får en unik symbol,
og dermed henvisning til et tabelentry, hvori at der står f.eks. en addresse,
eller far addresse, på omtalte "symbol". Også ved sætninger, kan man bruge
symbolværdien, til at holde styr på, hvor at data gemmes i lageret, for det
pågældende symbol. Ialt, så kan man til sidst smide alle ordende væk, og nøjes
med at bruge symbolerne. De oprindelige ord er glemt, og man har kun værdierne
fra 0 - n, hvor at n er antal forskellige ord. De indbyggede ord, dem kan man
hæfte på i starten af ordende i teksten, således at de får de indbyggede navne 0
- k, hvor at k er antal ord, man ønsker at genkende. Også ord, som er deffineret
i andre biblioteker kan hæftes ind forest. Dermed, kan f.eks. "writeln" få en
bestemt nummer, og således får man en nummersekvens, som fortæller præcis hvordan
at ordende hænger sammen. De ting, som skal overføres til compileren, og som ikke
er symboler, altså ordendes reelle indhold - disse kan gemmes. Oftest, så vil man
desuden overføre navne på nogen symboler, i en tabel - hvis at det er et krav,
som styres af tilstandsmaskinen. Altså, f.eks. ord i anførselstegn - her vil hele
sætningen kunne betragtes som et stort symbol, og således opfattes som et samlet
ord, og så også blive gemt så den kan bruges af compileren. Parserens opgave er
altså løst sagt, at omsætte source til symboler. Og så i mange tilfælde, at smide
alt væk - med mindre, det står i anførselstegn. Og til gengæld, så kan den så
genkende indbyggede ord, fordi at disse er inkluderet i toppen, og samtidig også
genkende andre ord, som inkluderes i toppen. De kan komme fra andre filer som
skal kædes sammen med denne. Princippet er altså enkelt i mange tilfælde: at
sætte nogen ord som skal genkendes øverst, og så læse ordende fra teksten, og at
undersøge om disse er i tabellen. Ellers, så tilføjes de, og får et nyt nummer.
TIl sidst får man en nummerrækkefølge af ordende, hvor at de oprindelige ord, har
de mindste numre. Og dertil, så sørger man for, at videregive informationer som
står i anførselstegn, eller andet som man har brug for at overlevere for det
pågældende sprog, til compileren. Når compileren modtager det, så er det symboler
- og det vil i praksis være numre, som går fra 0 til n, og som således er
begrænset til at anvende en begrænset mængde plads. Også teksten vil ofte blive
meget mere kompakt når den omsættes til symboler, og man kan betragte det som en
form for komprimering. I basic, og comal, gemmer man direkte ord internt som
symboler, f.eks. så gemmes en symbolværdi direkte på ZX81 når at man taster
print. Dette svarer måske en smule til parsing, selvom det måske ikke er helt det
samme - f.eks. så er det her kun de indbyggede ord, og der håndteres ikke
selvdefinerede navne, såsom det gør som til sprog som pascal. Umiddelbart, så kan
parsing måske også være andre ting, og det betyder oftest ikke nødvendigvis
ovenstående, selvom det er meget rart at kende.




Søg
Reklame
Statistik
Spørgsmål : 177583
Tips : 31968
Nyheder : 719565
Indlæg : 6409100
Brugere : 218888

Månedens bedste
Årets bedste
Sidste års bedste