Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


ExecuteScalar

Postades av 2004-01-11 14:55:21 - Jörgen Lindroos, i forum c# (c-sharp), Tråden har 6 Kommentarer och lästs av 1199 personer

Jag ska skapa nytt id i en tabell. Jag använder inte auto_increment vilket innebär att jag måste räkna upp själv. Jag gjorde så här
<code>
OdbcCommand cmd=conn.CreateCommand();
cmd.CommandText="Select Max(ID) From TABELL";
int nID=(int)cmd.ExecuteScalar();
nID++;
</code>

Men det fungerade inte (fick en InvalidCastException). Jag antog att det var för att det inte fanns några rader i tabellen. Men vad returnerar ExecuteScalar då för nåt. Tänkte det kanske var en null-referens men det var det inte heller. Jag gjorde så här
<code>
OdbcCommand cmd=conn.CreateCommand();
cmd.CommandText="Select Max(ID) From TABELL";
int nID;
object obj=cmd.ExecuteScalar();
if(obj==null)
nID=1;
else
nID=((int)obj)+1;
</code>

Men det fungerade inte heller. Jag fick InvalidCastException iallafall. Alltså kan inte obj varit null.

Någon som vet vad ExecuteScalar returnerar om det inte är några rader i tabellen?
/Jörgen


Svara

Sv: ExecuteScalar

Postades av 2004-01-11 15:54:41 - Oskar Johansson

ExecuteScalar retunerar antalet rader som påverkades vid en insert/update... :)


Svara

Sv: ExecuteScalar

Postades av 2004-01-11 16:29:56 - Jörgen Lindroos

Utdrag från .NET-referens System.Data.Odbc.OdbcCommand.ExecuteScalar
http://msdn.microsoft.com/library/default.asp?url=/library/en-us/cpref/html/frlrfsystemdataodbcodbccommandclassexecutescalartopic.asp

"Use the ExecuteScalar method to retrieve a single value (for example, an aggregate value) from a data source. This requires less code than using the ExecuteReader method, and then performing the operations necessary to generate the single value from the data returned by an OdbcDataReader.

A typical ExecuteScalar query can be formatted as in the following C# example:

CommandText = "select count(*) from region";
Int32 count = (int32) ExecuteScalar();"

Någon som vet svar på min fråga?
/Jörgen


Svara

Sv: ExecuteScalar

Postades av 2004-01-11 16:38:07 - Johan Bovin

vet inte svaret på din fråga, men antingen kan du ju steppa dig igenom koden med hjälp av nån debugging och se vad den returnerar. Annars skulle jag chansat på att den returnerar DBNull...
testa att kolla if(obj==null || obj==DBNull.Value)


Svara

Sv: ExecuteScalar

Postades av 2004-01-11 17:27:23 - Oskar Johansson

Oops, läste visst fel i min egna db-kod... :/ Som du sa, bland resultaten den hittar i databasen, det absolut första värdet (första kolumnen, första raden)


Svara

Sv: ExecuteScalar

Postades av 2004-01-11 17:31:07 - Patrik Löwendahl

Objektet som returneras är inte en Int32,

gör så här istället:

<code>
// If the object is empty, this is the value ID gets
int maxId = -1;

try {
object ret = cmd.ExecuteScalar();

if(ret!=null && ret!=DBNull.Value)
{
maxId = int.Parse(ret.ToString());
}
}
catch ( OleDbException ) {
// Indicate that something blew
maxId = -2;
}
</code>



Svara

Sv: ExecuteScalar

Postades av 2004-01-11 22:33:29 - Jörgen Lindroos

>vet inte svaret på din fråga, men antingen kan du ju steppa dig igenom koden med
>hjälp av nån debugging och se vad den returnerar. Annars skulle jag chansat på att
>den returnerar DBNull...
>testa att kolla if(obj==null || obj==DBNull.Value)

Min kod fungerar när jag använde DBNull. Tack ska du ha Johan.
Om ExecuteScalar returnerar en int eller inte vid det här tillfället vet jag inte, men det var inga problem att konvertera till int med en vanlig cast.

/Jörgen


Svara

Nyligen

  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo
  • 14:25 Tips på verktyg för att skapa QR-k
  • 14:23 Tips på verktyg för att skapa QR-k
  • 20:52 Fungerer innskuddsbonuser egentlig

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 155
27 952
271 704
7 119
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies