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

Access videregående 2007

Det har været godt at du hele tiden har været enten på mail eller chat, så du kan hjælpe en hurtigt videre. Samtidig vil jeg også sig at jeg ikke forventede så hurtige svar. Hvis der var noget man skulle bruge hjælp til kunne man jo bare gå videre med næste øvelse, for så at vendte tilbage til den ufærdige.

"Nu har jeg bestået prøven og skal nu lære at køre"

Det glæder jeg mig til at blive god til

Sarah Kristoffersen, VELUX Skærbæk

Excel VBA

Øvelserne kan tages i det tempo, der passer en, hvilket gør det muligt at gå i dybden med udvalgt teori og øvelser og inddrage arbejdsrelaterede udfordringer/problemstillinger direkte i kurset.

Der er hurtig respons fra underviser, man bliver udfordret på opgaverne og får ikke lov til og gå videre før en opgave er løst tilfredsstillende.

Kan anbefale kurset til andre.

Brian Lind Olsen, OUH Odense Universitetshospital

DreamWeaver CS55

En rigtig god undervisningsform hvor man kan arbejde når man er inspireret og opmærksom. Det gælder både ang. planlægning af tid og hvor i øvelserne man har brug for hjælp og svar på spørgsmål. Alt skete i mit tempo, og svar på spørgsmål var tilpasset mit niveau, så jeg kunne forstå det.

Jeg kom igennem alle de vigtige og nødvendige dele af programmet i et på forhånd planlagt forløb.

Samtidig var du ved din klippekortsordning med på mine private hjemmesider, således at jeg, efterhånden som jeg arbejdede med kurset, i praksis kunne bruge hvad jeg havde lært og fik opøvet rutine. Dermed er det for alvor lært og mine forventninger er mere end fuldt ud indfriet.

Alis Christiansen, privat

ASP.NET MVC 5

Jeg var ret glad for, at der var god vekselvirkning mellem teori og praksis. Nogle opgaver var lige til højrebenet, men der var gode muligheder for at anvende teorien på egen hånd, da visse opgaver klart krævede at du havde forstået teorien. Det var super, at man ikke fik alting forærende, men også skulle tænke selv. Jeg kom på kurset uden forudgående viden om MCV, og gik fra kurset med langt større forståelse og god praktisk erfaring med MCV. Jeg vil klart anbefale it-fjernundervisning.

Søren Bondrup Rasmussen, Alm. Brand Forsikring

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