Diskuze: Export SQL databáze do Ecelu
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 6 zpráv z 6.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
V první řadě používej tlačítko pro vložení kódu (druhé zleva), bo takhle je to strašně nepřehledný. Jestli jsem ten tvůj kód dobře pochopil, přijde mi, že při načítání dat otevíráš při každém průchodu cyklem nový excel, nemůže to být tím?
Díky za první radu takže
oprava.
Druhá rada tím si nejsem jistý vzhledem k tomu že při změně se soubor
přepíše správně problém nastává v tom že nejsem schopný vzít celý
sloupec po příkazu v SQL se vypíše 1 sloupec se 6 hodnotama a příkazem
oSheet.Cells[2, 1] = reader.GetString(0); vezmu první ale oSheet.Cells[3, 1]
= reader.GetString(1); již nevezme druhou hodnotu ze sloupce je možné že
to hledá druhý sloupec?
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using Excel = Microsoft.Office.Interop.Excel;
namespace VerifyWidowsForm
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
SqlConnection myCon = new SqlConnection(VerifyWidowsForm.Properties.Settings.Default.MySqlConection);
String comand0 = ("SELECT[ts_Operator] FROM [DIG_ENGINE_TEST].[dbo].[taskstats]group by ts_Operator");
SqlCommand sqlcomand0 = new SqlCommand(comand0, myCon);
DataTable dt = new DataTable();
DataSet ds = new DataSet();
try
{
Microsoft.Office.Interop.Excel.Application oXL;
Microsoft.Office.Interop.Excel._Workbook oWB;
Microsoft.Office.Interop.Excel._Worksheet oSheet;
Microsoft.Office.Interop.Excel.Range oRng;
myCon.Open();
SqlDataReader reader = sqlcomand0.ExecuteReader();
while (reader.Read())
{
try
{
//Start Excel and get Application object.
oXL = new Microsoft.Office.Interop.Excel.Application();
oXL.Visible = true;
//Get a new workbook.
oWB = (oXL.Workbooks._Open("C:\\Temp\\VerDatabase.xlsx", System.Reflection.Missing.Value,
System.Reflection.Missing.Value, System.Reflection.Missing.Value, System.Reflection.Missing.Value,
System.Reflection.Missing.Value, System.Reflection.Missing.Value, System.Reflection.Missing.Value,
System.Reflection.Missing.Value, System.Reflection.Missing.Value, System.Reflection.Missing.Value,
System.Reflection.Missing.Value, System.Reflection.Missing.Value));
oSheet = (Microsoft.Office.Interop.Excel._Worksheet)oWB.Worksheets[1];
oSheet.Name = "Average Validate by Operator";
//Add table headers going cell by cell.
oSheet.Cells[1, 1] = "Operators";
oSheet.Cells[1, 2] = "Average Time";
oSheet.Cells[1, 3] = "Total Batches";
int row = 2;
int column = 1;
List<string> allSSN = new List<string>();
var tableSchema = reader.GetSchemaTable();
string ssn = reader.GetString(0);
allSSN.Add(ssn);
foreach (var item in allSSN)
{
oSheet.Cells[row++, column] = item;
reader.NextResult();
}
oXL.Visible = false;
oXL.UserControl = false;
oWB.Save();
oWB.SaveAs("C:\\Temp\\VerDatabase.xlsx", Microsoft.Office.Interop.Excel.XlFileFormat.xlWorkbookDefault, Type.Missing, Type.Missing,
false, false, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange,
Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);
oWB.Close();
}
catch (Exception)
{
throw;
}
reader.Close();
myCon.Close();
}
}
catch (Exception g)
{
Console.WriteLine(g.ToString());
}
}
private void Form1_Load(object sender, EventArgs e)
{
}
}
}
Pokud chceš vypisovat hodnoty jen z prvního sloupce musí být vždycky s indexem 0 a při projití tím cyklem
while(reader.Read()){}
to pokaždé vezme hodnotu z prvního sloupce ale z dalšího řádku.
Já používám zápis ve stylu
string hodnota = reader[0].ToString();
Díky moc ,
už jsem to vyřešil a to i díky tvé radě
ještě jednou dík.
Zobrazeno 6 zpráv z 6.