您的位置:首页 > 大数据

WEB Service 下实现大数据量的传输(转)

2008-08-28 10:52 405 查看
Vs2005里面的,查询12000条记录,设置RemotingFormat = SerializationFormat.Binary;

再序列化,通过WebService传输,客户端接收,再反序列化,确实效果大大的优于直接传送DataSet,不仅网络传输中如此,即使本机,性能改善也非常明显.

下面分别是WebService里面的方法和客户端反序列化取DataSet的方法.

1. 服务器上面取数据,填充数据集,转换为二进制格式.

public byte[] BinaryUserSelect(ref string err)

{

ClearCommand();

m_commandStringBuilder.Append("SELECT * FROM t_Users ;");

DataSet dsResult = new DataSet();

byte[] bArrayResult = null;

try

{

dsResult = SqlHelper.ExecuteDataset(m_currentConnectionString, CommandType.Text, m_commandStringBuilder.ToString());

// 上面都是取数据的,无需关心.二进制压缩数据集是下面一小段

dsResult.RemotingFormat = SerializationFormat.Binary;

MemoryStream ms = new MemoryStream();

IFormatter bf = new BinaryFormatter();

bf.Serialize(ms, dsResult);

bArrayResult = ms.ToArray();

ms.Close();

//

}

catch (Exception ee)

{

err = ee.ToString();

}

return bArrayResult;

}

2. 通过WebService把byte[]格式的数据发送到客户端,这里就是WebService自己的事情了,我们无需关心

3.客户端接收到byte[]格式的数据,对其进行反序列化,得到数据集,进行客户端操作.

public DataSet GetBinaryUserData()

{

string err = "";

byte[] bUserData = svc.ByteArrayUserSelect(ref err);

if (err != "")

{

MessageBox.Show(err);

err = "";

return null;

}

// 反序列化的过程

MemoryStream ms = new MemoryStream(bUserData);

IFormatter bf = new BinaryFormatter();

object obj = bf.Deserialize(ms);

DataSet dsResult = (DataSet)obj;

//

ms.Close();

return dsResult;

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: