4

我将 DataTable 类型的对象保存到 SQL 2005 数据库中 varbinary 类型的字段中。我想找回它,但我无法输入它。这就是我保存它的方式。

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();

}

'dt' 是 DataTable 对象实例。

4

4 回答 4

7

你所说的是二进制序列化和反序列化。也许会有所帮助。

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();
        }
    }
}
于 2009-08-19T13:58:42.620 回答
1

恐怕我不得不让你失望,至少在你告诉我们你已经为处理数据表的 StreamWriter 类创建了一个扩展方法之前。

接受 DataTable 实例的方法的唯一重载是Write接受对象的方法,并且根据MSDN 文档,它只保存对象的“文本表示”。

所以,我们希望 DataTable 的 .ToString 方法以包含 DataTable 实例的所有内容的格式输出一个字符串,但是,唉。.ToString 方法仅返回 TableName 属性的内容和显示表达式(如果存在)。

所以你保存的不是DataTable实例的全部内容,只是表的名称。

您应该查看Serialization,它应该能够生成 DataTable 对象的所有内容的二进制或 XML 表示。

于 2009-08-19T13:57:43.090 回答
0

我假设你的代码只是序列化了数据表,你必须反序列化它。我不知道使用了什么格式化程序,所以您必须查看二进制字段的内容。如果它是二进制的,请使用BinaryFormater(参见页面下方的示例代码)。如果它不是二进制文件,请尝试SoapFormatterXmlSerializer

于 2009-08-19T14:00:11.760 回答
0

最好使用 XmlSerializer 或 BinaryFormatter 序列化 DataTable,然后存储在二进制列中。

这样做的链接:
http ://sadeveloper.net/forums/p/439/1772.aspx
http://bytes.com/topic/net/answers/428472-serializing-datatable

于 2009-08-19T14:01:28.920 回答