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


"Skicka in" DataSet till databasen

Postades av 2006-07-10 15:43:05 - Emil Karlsson, i forum c# (c-sharp), Tråden har 7 Kommentarer och lästs av 677 personer

Håller på att försöka uppdatera en databas och är helt ny med .NET och databaser, det är ju inte riktigt likt gamla ASP eller PHP, inte heller Java för den delen.

Jag har ett dataset som jag har hämtat, ändrat i men nu vill jag uppdatera det, och försöker med detta

public int Update(DataSet ds)
        {
            int a=-1;
            try
            {
                conn.Open();

                a= adapter.Update(ds);

                conn.Close();

                return a;
            }
            catch (Exception e)
            {
                MessageBox.Show("ERROR:\n"+e.Message);
                return -1;
            } 

        }

adapter och conn finns redan i klassen och är "igång"


Svara

Sv: "Skicka in" DataSet till databasen

Postades av 2006-07-10 16:58:49 - Per Hultqvist

Den kod du visar är det nog inga större fel på, men frågan är hur du "ställer in" din DataAdapter? Använder du CommandBuilder eller skapar du egna SqlCommands? Koden där du skapar adaptern behövs för att se vad som är fel. Ett felmeddelande skulle också vara användbart, eller får du inget fel alls men inget sparas?


Svara

Sv:"Skicka in" DataSet till databasen

Postades av 2006-07-10 17:35:03 - Emil Karlsson

använder odbcConnectionStringBuilder

        public void Connect(string dataUrl, string usrName, string pswd)
        {
            builder.Driver = "Microsoft Access Driver (*.mdb)"; // Load driver
            builder.Add("Dbq", dataUrl); // Load dataUrl
            builder.Add("Uid", usrName); // Load username
            builder.Add("Pwd", pswd); // Load password

            // Create connection
            conn = new OdbcConnection(builder.ConnectionString);
        }

        public void Query(string qString, string tableName)
        {
            // Try to open connection and fill DataSet
            try
            {
                conn.Open();
                adapter.SelectCommand = new OdbcCommand(qString, conn);

                adapter.Fill(ds, tableName);

                // Close connection
                conn.Close();
            }
            catch (Exception e)
            {
                MessageBox.Show("ERROR: \n" + e.Message);
            }   
        }


vet inte riktigt om jag har gjort rätt eller om det är rätt att använda ODBC?


Svara

Sv: "Skicka in" DataSet till databasen

Postades av 2006-07-12 12:44:54 - Per Hultqvist

Emil,

Om du skall fylla ett dataset så räcker det med att sätta SelectCommand och sedan anropa adapter.Fill(). Om du däremot skall skriva ned förändringarna i ett dataset till databasen så måste du dessutom ha satt DeleteCommand, UpdateCommand och InsertCommand för att det skall fungera.

Det går att använda en CommandBuilder (SqlCommandBuilder?) för att slippa skapa dessa manuellt, se följande länk :

http://msdn2.microsoft.com/en-us/library/system.data.odbc.odbccommandbuilder.aspx

Lycka till...


Svara

Sv:"Skicka in" DataSet till databasen

Postades av 2006-07-12 21:05:57 - Emil Karlsson

jag läser förbrilt i dokumentationen men får inte bukt på mitt problem...


Men hur skapar jag Delete, Update och Insert Commands? Måste jag veta exakt vilka kolumner och vilkor som ska köras, kan man inte bara ta det ändrade DataSetet och "spara över" databasen?


Svara

Sv: "Skicka in" DataSet till databasen

Postades av 2006-07-13 07:47:30 - Johan Djupmarker

Innan du kör Update borde det räcka att köra:

OdbcCommandBuilder cb = new OdbcCommandBuilder(adapter);

/Johan


Svara

Sv:"Skicka in" DataSet till databasen

Postades av 2006-07-13 16:45:28 - Emil Karlsson

hjälper inte ... :(


Svara

Sv: "Skicka in" DataSet till databasen

Postades av 2006-08-01 13:09:52 - Emil Karlsson

Jag har löst problemet genom att göra såhär

[code]
try
{
conn.Open();
OdbcCommandBuilder com = new OdbcCommandBuilder(adapter);
if (ds.HasChanges() == true)
{
try
{
adapter.Update(ds, tName);
ds.AcceptChanges();
MessageBox.Show("Save complete!");
}
catch (Exception e)
{
MessageBox.Show("SAVE ERROR:\n" + e.Message);
}
}
conn.Close();
return 1;
}
catch (Exception e)
{
MessageBox.Show("SAVE ERROR:\n" + e.Message);
return -1;
}
[/code]

men nu kommer ett nytt problem. När jag har lagt till flera tabeller i samma DataSet får den problem när den börjar spara över varandra. Den ska spara Tabellen events men den vill spara hela datasetet till den tabellen och då kan den inte hitta kolumner som inte finns.

Hur ska jag göra för att hämta och lagra all data från en databas med flera tabeller till ett DataSet sedan få sparningen att fungera??


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 169
27 953
271 705
709
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