Domanda

Ho salvato un oggetto di tipo DataTable nel database SQL 2005 in un campo di tipo varbinary. Voglio recuperare indietro, ma non ero in grado di digitare lanciarla. Questo è il modo ho salvato.

MemoryStream memStream = new MemoryStream();
    StreamWriter sw = new StreamWriter(memStream);

sw.Write(dt);
con.Open();
using (SqlCommand cmd = new SqlCommand("INSERT INTO Tables(TableName, TableData, QuestionID) VALUES (@TableName, @TableData, @QuestionID)", con))
{
    cmd.Parameters.Add("@TableName", SqlDbType.VarChar).Value = "a new table";
    cmd.Parameters.Add("@TableData", SqlDbType.VarBinary,Int32.MaxValue).Value = memStream.GetBuffer();
    cmd.Parameters.Add("@QuestionID", SqlDbType.VarChar).Value = "2";
    cmd.ExecuteNonQuery();

}

Il 'dt' è l'istanza di oggetto DataTable.

È stato utile?

Soluzione

Che cosa il vostro parlando è la serializzazione binaria e deserializzazione. Forse questo sarà di aiuto.

using System;
using System.IO;
using System.Runtime.Serialization;
using System.Runtime.Serialization.Formatters.Binary;
using System.Data;
using System.Text;

namespace Serial
{
    public class Ser
    {
        public static byte[] StrToByteArray(string str)
        {
            UTF8Encoding  encoding = new UTF8Encoding ();
            return encoding.GetBytes(str);
        }

        public static string ByteArrayToStr(byte[] barr)
        {
            UTF8Encoding  encoding = new UTF8Encoding ();
            return encoding.GetString(barr, 0, barr.Length);
        }

        public static void Main(String[] args)
        {
            DataTable dt = new DataTable();
            DataRow dr;

            dt.Columns.Add(new DataColumn("IntegerValue", typeof(Int32)));
            dt.Columns.Add(new DataColumn("StringValue", typeof(string)));
            dt.Columns.Add(new DataColumn("DateTimeValue", typeof(DateTime)));
            dt.Columns.Add(new DataColumn("BooleanValue", typeof(bool)));

            for (int i = 1; i <= 1; i++) 
            {

                dr = dt.NewRow();

                dr[0] = i;
                dr[1] = "Item " + i.ToString();
                dr[2] = DateTime.Now;
                dr[3] = (i % 2 != 0) ? true : false;

                dt.Rows.Add(dr);
            }

            //Serialize
            BinaryFormatter bformatter = new BinaryFormatter();
            MemoryStream  stream = new MemoryStream();

            string s;
            bformatter.Serialize(stream, dt);
            byte[] b = stream.ToArray();
            s = ByteArrayToStr(b);
            stream.Close();
            dt = null;

            //Now deserialise
            bformatter = new BinaryFormatter();
            byte[] d;
            d = StrToByteArray(s);
            stream = new MemoryStream(d);
            dt = (DataTable)bformatter.Deserialize(stream);
            stream.Close();
        }
    }
}

Altri suggerimenti

Ho paura che dovrò deludervi, almeno fino a quando ci dite che hai creato un metodo di estensione per la classe StreamWriter che gestisce le tabelle di dati.

L'unico overload del metodo Write che accetta un'istanza DataTable è quello che prende un oggetto, e per il MSDN documentazione , si salva solo la "rappresentazione di testo" dell'oggetto.

Quindi, speriamo che il metodo .ToString di DataTable genera una stringa in un formato che contiene tutti i contenuti dell'istanza DataTable, ma ahimè. Il metodo .ToString solo restituisce il contenuto della proprietà TableName , e un'espressione visualizzazione, se presente.

Quindi quello che hai salvato non è il contenuto dell'istanza DataTable tutti, solo il nome della tabella.

Si dovrebbe guardare in serializzazione , dovrebbe essere in grado di produrre un binario o XML-rappresentazione di tutti i contenuti dell'oggetto DataTable.

I assumere il codice appena serializzato la tabella dei dati e si deve deserializzare esso. Non so che cosa formattatore è stato utilizzato, in modo da avere a guardare il contenuto di te campo binario. Se si tratta di binario, utilizzare il BinaryFormater (vedere il codice di esempio in basso nella pagina). Se non è binaria, prova a SoapFormatter e XmlSerializer .

Si potrebbe essere meglio utilizzare XmlSerializer o BinaryFormatter per serializzare il vostro DataTable e quindi memorizzare in una colonna binaria.

Link per farlo:
http://sadeveloper.net/forums/p/439/1772.aspx
http://bytes.com/topic/net/answers/428472-serializing- DataTable

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top