SQL Programmering

De filmklip der er lavet i starten af kurset, er super gode til at komme i gang med.

Der er meget hurtig respons, når man indsender en opgave.

Man kan selv tilpasset tidspunktet for kurset, når det passer ind i den normale hverdag

Johan Hauge, EM Retail Solutions A/S

SQL Programmering

Der har været en rigtig god rødtråd mellem teori og øvelserne hele vejen igennem kursuset. Der har samtidigt været udfordrende, men uden at jeg har siddet og slået mig selv på hovedet. Thor har samtidig været online godt og vel 24/7 til at besvare på spørgsmål og hjælpe mig igennem, hvor jeg har haft det svært.

Alexander Thompson, privat

DreamWeaver CS4

Det bedste af det hele - din ubegrænsede tålmodighed. Jeg vidste intet om hjemmesider, havde aldrig været på IT kurser, plus dansk er ikke min modersmål - jeg misforstod tit, hvad du skrev. Det har sikkert været meget irriterende for dig, men du fortsætte at forklare uden at blive sur. Det er meget vigtigt for en begynder ikke at være "skræmt væk", fordi så tænker man: "mon ikke klarer jeg det alligevel".
Jeg synes, emnerne for kurser var godt valgte.
Det var godt, at man kunne arbejde med kurser, når man havde tid - der var ingen tidsfrister til hvert emne.
Det var godt, at du svarede hurtigt på spørgsmålene.

Tak for kursus! Det var en god oplevelse, det var en stor udfordring for mig, men det var meget interessant at "fægte" igennem det!

Antra Kahr, kahrius.dk

Excel videregående

Det har været rigtig godt at kunne arbejde med kurset når man selv synes at man havde tid til det.

Overskueligt materiale og overkommelige opgaver.

Hurtige svar på opgaveløsninger.

Et rigtig godt kursus :o)

Susanne Jensen, KoncernØkonomi

Word grundlæggende

 Det har været kanon, at underviseren svarer mig lynhurtigt.

 Det har været ok, at det var mig og kun mig, der skulle omsætte kursusmaterialet - hvilket var eminent.

 Jeg havde mulighed for at planlægge, hvornår jeg skulle løse kursusmaterialet - hvilket var glimrende.

Majbrit Larsen, Revisionsdirektoratet

DreamWeaver MX

Hej Thor

Det bedste har været at jeg så hurtigt fik svar, der var aldrig en fornemmelse af at afstanden til hjælp var lang, det føltes som om vi bare genoptog en snak fra sidst...

Og så var der aldrig en følelse af at blive talt ned til, selv om jeg da godt er klar over at du adskillige gange må have revet dig i håret over mine spørgsmål.

Det har også været godt, at der ikke har været en tidsfrist. Jeg kan se at flere af mine kolleger har været igang med et kursus, som de måtte skippe, fordi de ikke var i stand til at overholde tidsfristen.

Vivi Bundgaard, Egvad Bibliotek

DreamWeaver MX

Man lærer, som beskrevet, de grundlæggende ting i DreamWeaver, som man har brug for at vide. Derudover er der altid hurtig respons, og hjælp at hente, hvis det går galt.

Tina Hartmann, Privat

< >
Se flere referencer

Funktioner til håndtering af tekststrenge

Der findes en lang række funktioner til behandling af tekststrenge.

Først en lille oversigt

FunktionBeskrivelse
LEFT(felt, n) Returnerer n tegn fra feltet fra venstre mod højre
RIGHT(felt, n) Returnerer n tegn fra feltet fra højre mod venstre
LTRIM(felt) Fjerner foranstillede mellemrum fra feltet
RTRIM(felt) Fjerner efterstillede mellemrum fra feltet
SUBSTRING(felt, n, m) Returnerer m tegn fra feltet startende ved n
UPPER(felt) Konverterer feltet til store bogstaver
LOWER(felt) Konverterer feltet til små bogstaver
LEN(felt) Returnerer antallet af tegn i feltet
CHARINDEX(tekst, felt, n) Returnerer placeringen af tekst i feltet startende i n
(man behøver ikke angive n)
REVERSE(felt) Returnerer teksten spejlvendt
CONCAT(felt1, felt2, felt3,..) Sammensætter felterne
(svarende til +, som vi har set tidligere)
REPLACE(tekst, tekst1, tekst2) Erstatter alle forekomster af tekst1 i tekst med tekst2

De fleste af funktionerne giver sig selv - vi skal dog nok lige give de sidste 3 et par ord mere med på vejen.

CHARINDEX()

Kast et blik på tabellen Person.Address

Address tabellen

Vil man gerne have husnummeret ud af AddressLine1 kan man bruge CHARINDEX() - det kan se sådan her ud:

SELECT LEFT(AddressLine1, CHARINDEX(' ', AddressLine1)) 
AS HouseNo, AddressLine1 
FROM Person.Address;

Og giver dette output (prøv selv)

Husnummer

CHARINDEX(' ', AddressLine1) giver os positionen af det første mellemrum i teksten og LEFT sørger så for at vi får alle tegnene hen til det mellemrum. Som man ser er det ikke 100% skudsikkert, men der er vilkårene og lærer os, at man skal sørge for at få data i den rigtige opdeling med det samme frem for at skulle dele det efterfølgende.

Har man danske adresser på formen "Nørre Voldgade 12" kan man også godt splitte med CHARINDEX - det kunne se sådan her ud

SELECT AddressLine1, 
RIGHT(AddressLine1, CHARINDEX(' ', REVERSE(AddressLine1))) 
AS HouseNo FROM Person.Address; 

Udfordringen er, at vi skal have fundet det positionen af det sidste mellemrum. Og her kan man så benytte REVERSE funktionen, der spejlvender teksten. Prøv det...

CONCAT()

Vi har tidligere set, at man kan sætte tekstfelter sammen med +, men så også, at hvis ét af felterne har værdien NULL bliver det samlede resultat også NULL.

CONCAT() kan sætte tekstfelter sammen også selvom nogle af felterne har værdien NULL - funktionen konverterer automatisk NULL til en tom tekststreng ''.

 

Når du har betalt for kurset får du adgang til øvelser til hver lektion. Og når du har fået godkendt din besvarelse får du desuden adgang til mine løsningsforslag med ekstra tips og trix.