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

  • 08:28 Butiksskyltar: Hur upplever utbude
  • 22:31 Slappna av
  • 19:55 kick-off med fokus på hälsa?
  • 19:53 kick-off med fokus på hälsa?
  • 16:24 Föreslå en skönhetsklinik online
  • 16:23 Föreslå en skönhetsklinik online
  • 18:42 Hvor finder man håndlavede lamper
  • 18:41 Hvor finder man håndlavede lamper

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 570 812
27 960
271 761
575
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