У меня есть простое приложение, которое извлекает набор данных из базы данных и преобразует его в XML-файл. Этот xml-файл затем считывается и сжимается в файл .gz.Сжатие непосредственно из потока
Это кажется довольно неэффективным - возможно ли пропустить шаг записи во временный XML-файл и прочитать его обратно в сжатие? Могу ли я автоматически отправить файл в поток, который преобразует его непосредственно в преобразованный формат XML?
Вот мой код:
public partial class _Default : System.Web.UI.Page
{
DataSet dataset = new DataSet();
string uri = "C:\\tester.xml";
string compressedfileuri = "C:\\tester.gz";
protected void Page_Load(object sender, EventArgs e)
{
//get the dataset
RetrieveData();
//serialize data to a xml file
dataset.WriteXml(uri);
//compress the data
Compress();
}
public void RetrieveData()
{
string connString = ConfigurationManager.ConnectionStrings["Platform"].ConnectionString;
using (SqlConnection conn = new SqlConnection(connString))
{
SqlDataAdapter adapter = new SqlDataAdapter();
adapter.SelectCommand = new SqlCommand("SELECT * FROM expenses.CST_COSTHEADER", conn);
adapter.Fill(dataset);
}
}
public void Compress()
{
using (FileStream fs = new FileStream(uri, FileMode.Open))
{
using (FileStream outFile = File.Create(compressedfileuri))
{
using (GZipStream Compress = new GZipStream(outFile, CompressionMode.Compress))
{
fs.CopyTo(Compress);
}
}
}
}
}
Вы можете упростить код много, поставив все из использования на том же уровне, также fs никогда не используется в вашем примере. –