Потоковая передача данных в.csv не показывает результаты C#
Я пытаюсь передать данные из базы данных SQLServer в файл.CSV; Однако после выполнения файл.csv остается пустым. Первый цикл while был / был для целей тестирования, который выполнялся правильно. Я знаю, что делаю что-то не так в своей потоковой части.
Любая помощь очень ценится!
using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Diagnostics;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace ConsoleApp1
{
class Program
{
static void Main(string[] args)
{
SqlConnection conn = new SqlConnection("Server=*******;Database=*********;Integrated Security=true");
conn.Open();
SqlCommand cmd = new SqlCommand("SELECT p.cFName, p.cLName, s.cSugTitle, s.cEcrno, g.cName, h.mNotes, u.UserID, u.NetworkID FROM people p INNER JOIN suggest s ON p.cidPeople = s.cidPeople_WhoEntered INNER JOIN Grp g on s.cidGrp = g.cidGrp INNER JOIN history h ON h.cidSuggest = s.cidSuggest INNER JOIN users u ON u.cidPeople = p.cidPeople", conn);
SqlDataReader reader = cmd.ExecuteReader();
while (reader.Read())
{
Console.WriteLine("{0}, {1}, {2}, {3}, {4}, {5}, {6}, {7}", reader.GetString(0), reader.GetString(1), reader.GetString(2), reader.GetString(3), reader.GetString(4), reader.IsDBNull(5) ? null : reader.GetString(5), reader.GetString(6), reader.IsDBNull(7) ? null : reader.GetString(7));
}
String path = @"C:\Users\AEEVANS\Desktop\example.csv";
using (StreamWriter sr = File.AppendText(path))
{
while (reader.Read())
{
sr.WriteLine("{0}, {1}, {2}, {3}, {4}, {5}, {6}, {7}", reader.GetString(0), reader.GetString(1), reader.GetString(2), reader.GetString(3), reader.GetString(4), reader.IsDBNull(5) ? null : reader.GetString(5), reader.GetString(6), reader.IsDBNull(7) ? null : reader.GetString(7));
sr.Close();
}
}
Console.ReadKey();
reader.Close();
conn.Close();
if (Debugger.IsAttached)
{
Console.ReadLine();
}
}
}
}
РЕДАКТИРОВАТЬ Я отредактировал свой исходный код, чтобы он не включал первый цикл while для каждой рекомендации. Я сейчас сталкиваюсь со следующей ошибкой:
System.ObjectDisposedException: "Невозможно записать в закрытый TextWriter."
using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Diagnostics;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace ConsoleApp1
{
class Program
{
static void Main(string[] args)
{
SqlConnection conn = new SqlConnection("Server=********;Database=*********;Integrated Security=true");
conn.Open();
SqlCommand cmd = new SqlCommand("SELECT p.cFName, p.cLName, s.cSugTitle, s.cEcrno, g.cName, h.mNotes, u.UserID, u.NetworkID FROM people p INNER JOIN suggest s ON p.cidPeople = s.cidPeople_WhoEntered INNER JOIN Grp g on s.cidGrp = g.cidGrp INNER JOIN history h ON h.cidSuggest = s.cidSuggest INNER JOIN users u ON u.cidPeople = p.cidPeople", conn);
SqlDataReader reader = cmd.ExecuteReader();
String path = @"C:\Users\AEEVANS\Desktop\example.csv";
using (StreamWriter sr = File.AppendText(path))
{
while (reader.Read())
{
sr.WriteLine("{0}, {1}, {2}, {3}, {4}, {5}, {6}, {7}", reader.GetString(0), reader.GetString(1), reader.GetString(2), reader.GetString(3), reader.GetString(4), reader.IsDBNull(5) ? null : reader.GetString(5), reader.GetString(6), reader.IsDBNull(7) ? null : reader.GetString(7));
sr.Close();
}
}
reader.Close();
conn.Close();
if (Debugger.IsAttached)
{
Console.ReadLine();
}
}
}
}
1 ответ
while (reader.Read())
это односторонняя поездка через считыватель данных. Если вы делаете другой while (reader.Read())
, вы ничего не получите, потому что указатель уже находится в конце содержимого читателя.
Похоже, вы должны быть в состоянии объединить два while (reader.Read())
блокирует в один.