Avatar billede george Nybegynder
29. januar 2005 - 18:38 Der er 9 kommentarer og
1 løsning

Hvor mange kolonner er der i min db

Hvordan finder jeg ud af hvor mange kolonner der er i min DB med en enkelt SQL statement ?
Avatar billede arne_v Ekspert
29. januar 2005 - 18:41 #1
Mener du hvor mange rækker der er i en tabel ?

SELECT COUNT(*) FROM tabelnavn
Avatar billede george Nybegynder
29. januar 2005 - 18:42 #2
Nej kolonner
Avatar billede arne_v Ekspert
29. januar 2005 - 18:48 #3
En tabel eller alle tabeller ?

Og tør man spørge om hvorfor du vil vide det ?
Avatar billede george Nybegynder
29. januar 2005 - 18:59 #4
En tabel. Jeg skal bruge antallet så jeg kan lave en løkke.
Avatar billede arne_v Ekspert
29. januar 2005 - 19:02 #5
Normalt så laver man en
  SELECT * FROM ...
og så spørger man om hvormange kolonner der er i recordset/resultset/datareader/rowset
(afhængig af sprog).
Avatar billede arne_v Ekspert
29. januar 2005 - 19:02 #6
Men SQLServer har en stored procedure som kan hente oplysninger om alle kolonner:

sp_tables 'foobar'

henter alle kolonner for tabellen foobar.
Avatar billede george Nybegynder
29. januar 2005 - 19:04 #7
Øhh...ok, ved du hvordan man gør det i ASP/SQL
Avatar billede arne_v Ekspert
29. januar 2005 - 19:07 #8
Set rs = Server.CreateObject("ADODB.Recordset")
rs.Open "SELECT * FROM ...",con

og rs.Fields.Count indeholder antal kolonner og rs.Fields.Item(i) indholder
værdien for kolonne i (starter i 0 !)
Avatar billede george Nybegynder
29. januar 2005 - 19:37 #9
Yes, perfekt. Det var lige den jeg havde brug for rs.Fields.Count.

Takker! Svar = Points
Avatar billede arne_v Ekspert
29. januar 2005 - 19:40 #10
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
Computerworld tilbyder specialiserede kurser i database-management

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