Ho una semplice applicazione che recupera un set di dati dal database e lo converte in un file xml. Questo file xml viene quindi letto e compresso in un file .gz.Compressione diretta da uno streaming
Questo sembra piuttosto inefficiente: è possibile saltare la fase di scrittura in un file .xml temporaneo e leggerlo di nuovo in comprimerlo? Posso inviare automaticamente il file a un flusso che lo converte direttamente in un formato xml convertito?
Ecco il mio codice:
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);
}
}
}
}
}
È possibile semplificare il codice molto mettendo tutto il usando sullo stesso livello, anche fs non è mai usato nel tuo esempio. –