我可以保存在SQL Server数据库中的“对象”? [英] Can I save an 'Object' in a SQL Server database?

查看:204
本文介绍了我可以保存在SQL Server数据库中的“对象”?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想一个对象(任何类型)保存到一个字段在SQL Server 2005中是否有可能一个数据库?我必须将对象转换成的东西,就像一个字节数组,例如和检索它时,它转换回?

I want to save an object (of any type) into a field in a database in SQL Server 2005. Is it possible? Do I have to convert the object into something, like a byte array for example and cast it back when retrieving it?

推荐答案

您可以使用 VARBINARY(MAX)字段类型在SQL Server中,如果你喜欢。您可以存储任何类型的对象在那里,高达2 GB的大小。

You can use the VARBINARY(MAX) field type in SQL Server, if you like. You can store any type of object in there, up to 2 GB in size.

要访问它,您可以使用ADO.NET - 是这样的:

To access it, you can use ADO.NET - something like this:

object yourMysteryObject = (whatever you like it to be);

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

sw.Write(yourMysteryObject);

SqlCommand sqlCmd = new SqlCommand("INSERT INTO TableName(VarBinaryColumn) VALUES (@VarBinary)", sqlConnection);

sqlCmd.Parameters.Add("@VarBinary", SqlDbType.VarBinary, Int32.MaxValue);

sqlCmd.Parameters["@VarBinary"].Value = memStream.GetBuffer();

sqlCmd.ExecuteNonQuery();

马克·

这篇关于我可以保存在SQL Server数据库中的“对象”?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆