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

Excel grundlæggende 2000

Jeg syntes at det været rigtig godt og læreridt.

Det passede mig rigtig godt at jeg selv kunne bestemme hvornår jeg lavede opgaverne,

Når man havde en til to timer fik man lige sat sig ved pc,en og så bare igang. 

Det passer rigtig godt ind i en børnefamilie istedet for at skulle være væk i et par dage.

Opgaverne syntes jeg var rimlig let at forstå, hvordan man skulle løse dem.

Opgaverne  var udfordrene det længere man kom frem

Jeg har lyst til at prøve mere på et tidspunkt

Jeg vil gerne anbefale det til andre.

Finn Nygaard Jensen, Efterskolen Ådalen

ASP.NET 4.5

Der har altid faldet et hurtigt svar på spørgsmål, ligesom database problemer, der opstod undervejs, blev løst hurtigt og meget smidigt , uanset at det betød, at Thor måtte opgraderer sin SQL server.

Selvom jeg har stor erfaring med traditionel programmering, har Thor alligevel formået, at åbne mine øjne for den nye verden der er i webudvikling og det er helt sikkert, at fremtidens løsninger er her.
Kommer der et udvidet kursus i ASP.NET, så er jeg sikker på, at jeg vil være at finde blandt kursisterne.

Jeg har kun roser til IT-fjernundervisning, specielt til Thor.

Finn Hoelgaard
Datamatiker

Museum Vestsjælland

Finn Hoelgaard

Excel VBA

Jeg har gennemført kurset Excel VBA. Jeg var skeptisk overfor måden at lære på inden jeg gik i gang, men jeg må sige at min skepsis blev gjort til skamme. Lige fra første lektion følte jeg at jeg virkelig lærte noget.

Thors tilgang til materialet er perfekt. Gennem løbende øvelser får man lejlighed til at afprøve teorien i praksis.

Beder man om lidt hjælp, så kommer den lynhurtig – men det er kun et hint og så kan man selv finde ud af resten – det er perfekt for herved tvinges eleven til at tænke sig om – mon det kan bruges i folkeskolen også :).

Kurset er ALLE pengene værd og kan køres når man har tid og er motiveret. Holder man for lange pauser i undervisningen, så komme Thors pegefinger i form af en mail og så er det bare om at komme i gang igen :)

Jacob Madsen, Mettler-Toledo A/S

Excel grundlæggende 2007

Det passer mig perfekt at løse opgaverne i mit eget tempo og at jeg kan bruge den tid der skal til..

Mette Kargaard. Frederiksen, Privat

Excel grundlæggende 2007

Har været fuldt ud tilfreds med kursusforløbet, det har ikke taget nær så lang tid som frygtede, men jeg har også haft en del huller i min hverdag som jeg kunne bruge til kurset.

Skal helt klart videre med det videregående kursus og håber der er lidt mere hjernegynmastik.

Hurtig hjælp via chatten og hurtige svar efter øvelserne.

Kan godt anbefales til andre. 

Helle Majdal, Mejdal Service og Teknik

< >
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.