Avatar billede loopstudio Nybegynder
27. marts 2007 - 18:01 Der er 3 kommentarer og
1 løsning

Er det muligt at benytte en selvkreeret function i en SQL SELECT?

Kan man og hvordan gør man flg.:

Laver en Nz() function i c# som kan anvendes i et SQL udtryk opimod en MS Access db?

I MS Access findes en function Nz() som fjerner en evt. NULL værdi fra et felt i en SQL-sætning. Men det virker ikke i c#.
Derfor ville jeg lave min egen, som flg:

    public string Nz(string vaerdi)
    {
        if (vaerdi == null)
        {
            return "";
        }
        else
        {
            return vaerdi;
        }
    }

Og så anvende den i mit sql-udtryk.. f.eks.

SELECT field1, Nz(field2) FROM tabel1;

Men den siger flg. fejl:

Undefined function 'Nz' in expression.
Avatar billede arne_v Ekspert
27. marts 2007 - 18:50 #1
proev:

IIF(ISNULL(field2), '', field2)
Avatar billede kalp Novice
27. marts 2007 - 20:03 #2
det du har lavet i c# burde også fungere, men det kommer jo så også an på hvordan du anvender metoden.

Hvis du laver noget lignede dette..

string tekst = null;

string sqlQuery = "select * from TABEL where Kolonne = '"+ tekst +"'";

sqlQuery = Nz(sqlQuery);

så virker det selvfølgelig ikke:)

dette burde tilgengæld virke..

string tekst = null;
tekst = Nz(tekst);
string sqlQuery = "select * from TABEL where Kolonne = '"+ tekst +"'";

Nu er det bare princippet i det selvfølgelig.
Og ud fra at du siger den funktion ikke virker i c#.
Avatar billede loopstudio Nybegynder
28. marts 2007 - 16:09 #3
arne_v tak dte virkede!
Bare opret et svar, så får du point :)
Avatar billede arne_v Ekspert
28. marts 2007 - 17:01 #4
svar
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
IT-kurser om Microsoft 365, sikkerhed, personlig vækst, udvikling, digital markedsføring, grafisk design, SAP og forretningsanalyse.

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester