>백엔드 개발 >C#.Net 튜토리얼 >C# 데이터 그리드 보기

C# 데이터 그리드 보기

王林
王林원래의
2024-09-03 15:32:22598검색

One of the important tasks of a programmer is to fetch details or information stored in a database and display in on the UI/Screen. This is achieved in c# windows forms using DataGrid view control. This control acts as an interface between the UI layer and database layer and fetches the information from the DB and displays it on the screen in a tabular/grid view format. The data grid view is used to display both editable and read-only views. Each value in a data grid is present in a cell and the cell is the fundamental unit of interaction. This article will explain in detail about Data Grid view and its usage. In this topic, we are going to learn about C# Data Grid View.

Syntax of C# Data Grid View

There is no actual syntax as such for the data grid view. It is present in the namespace System.Windows.Forms and assembly that is associated with it is System.Windows.Forms.dll. It is always not necessary to have a data connection to a data source. Even without a data source, rows and columns with respective data can be created and can be added to the data grid view using rows and columns properties.

Steps involved in Binding Database data to a DataGrid View:

  • Establish a connection to the database
  • Create a data adapter(This generally defines the query to be used)
  • Create a data table
  • Fil the data table with the result returned from the data adapter
  • Bind the data table to the grid view
  • Close the connection

Examples of C# Data Grid View

Here are the following examples mention below

Example #1

Connect to SQL Database Table and Display Information

Input:

string sqlconstr = "Data Source=.;Initial Catalog=Test;Integrated Security=True";
string qu = "SELECT * FROM Test";
SqlConnection cx = new SqlConnection(sqlconstr);
SqlDataAdapter dt = new SqlDataAdapter(qu, cx);
DataSet dase = new DataSet();
cx.Open();
dt.Fill(ds, "Test_table");
cx.Close();
dgvt.DataSource = dase;
dgvt.DataMember = "Test_table";

The above is the sample code to fetch information from the sql database table and bind it to a data grid view.

As you can see, the first line contains the sql server information. “.” Represents the local server. The initial catalog denotes the database name and integrated security denotes windows authentication. Next is defining the query that needs to be executed on the table. That is the query string. Then a sql connection is established. Then a data adapter is created, which will run the query and get the results. Then this result is filled in the data set. This data set is then bounded to the grid view. Before binding the connection is closed.

Output:

C# 데이터 그리드 보기

Example #2

Writing Output of Data grid to a text file

Input:

private void outputgrid()
{
//Establishing connection
OleDbDatardr rdr;
OleDbCommand command1=new OleDbCommand();
this.oleDbConnection1.Open();
//query to be executed
command1.ctxt="SELECT FirstName, LastName, Phone, City FROM ptable";
command1.Connection=this.oleDbConnection1;
using (Streamwtr wtr = new Streamwtr("C:\\op.txt",false))
{
while (rdr.Read())
{
wtr.Write(rdr["LastName"]);
wtr.Write("***");
wtr.Write(rdr["FirstName"]);
wtr.Write("***");
wtr.Write(rdr["City"]);
wtr.Write("***");
wtr.Write(rdr["Phone"]);
wtr.WriteLine(); //next new line
}//while
}
}

Output:

C# 데이터 그리드 보기

Example #3

Populating a data grid from excel and export a data grid to excel

Input: 

private void button1_Click(object sender, EventArgs e)
{
System.Data.OleDb.OleDbConnection mycon;
System.Data.DataSet DtSet;
System.Data.OleDb.OleDbDataAdapter mycmd;
mycon = new System.Data.OleDb.OleDbConnection(@"provider=Microsoft.Jet.OLEDB.4.0;Data Source='c:\test.xls';Extended Properties=Excel 8.0;");
mycmd = new System.Data.OleDb.OleDbDataAdapter("select * from [Sheet1$]", mycon);
mycmd.TableMappings.Add("test", "excel data");
DtSet = new System.Data.DataSet();
mycmd.Fill(DtSet);
dataGridView1.DataSource = DtSet.test[0];
mycon.Close();
}
private void exportoexcel(object sender, EventArgs e)
{
Excel.Application appli;
Excel.Workbook WB;
Excel.Worksheet WS;
object mv = System.Reflection.Missing.Value;
Int16 i, j;
appli = new Excel.ApplicationClass();
WB = appli.Workbooks.Add(mv);
WS = (Excel.Worksheet)WB.Worksheets.get_Item(1);
for (i = 0; i <= dataGridView1.RowCount - 2; i++)
{
for (j = 0; j <= dataGridView1.ColumnCount - 1; j++)
{
WS.Cells[i + 1, j + 1] = dataGridView1[j, i].Value.ToString();
}
}
WB.SaveAs(@"c:\test.xls", Excel.XlFileFormat.WBNormal, mv, mv, mv, mv, Excel.XlSaveAsAccessMode.xlExclusive, mv, mv, mv, mv, mv);
WB.Close(true, mv, mv);
appli.Quit();
releaseObject(WS);
releaseObject(WB);
releaseObject(appli);
}

Output:

C# 데이터 그리드 보기

Example #4

Adding a row to data grid via a button click without DB

Input:

public void createnewrow()
{
DataTable dtab = new DataTable();
DataColumn col1 = new DataColumn("Name", typeof(string));
DataColumn col2 = new DataColumn("Subject1", typeof(int));
DataColumn col3 = new DataColumn("Subject2", typeof(int));
DataColumn col4 = new DataColumn("Subject3", typeof(int));
DataColumn col5 = new DataColumn("Subject4", typeof(int));
DataColumn col6 = new DataColumn("Subject5", typeof(int));
DataColumn col7 = new DataColumn("Subject6", typeof(int));
DataColumn col8 = new DataColumn("Subject7", typeof(int));
DataColumn col9 = new DataColumn("Subject8", typeof(int));
dtab.Columns.Add(col1);
dtab.Columns.Add(col2);
dtab.Columns.Add(col3);
dtab.Columns.Add(col4);
dtab.Columns.Add(col5);
dtab.Columns.Add(col6);
dtab.Columns.Add(col7);
dtab.Columns.Add(col8);
dtab.Columns.Add(col9);
dtab.Rows.Add("Vk",12,23,45,67,89,90,78,80);
dtab.Rows.Add("Vksdfsdf",45,23,65,67,99,30,78,50);
dtab.Rows.Add("test1",42,33,45,70,29,90,78,40);
dataGridView1.DataSource = dtab;
}

Example #5

Creating a data grid from an xml file and saving data grid to an xml file

Import XML to data grid view

Input:

private void readfromxml()
{
try
{
XmlReader xip ;
xip = XmlReader.Create("test.xml", new XmlReaderSettings());
DataSet ds = new DataSet();
ds.ReadXml(xip);
dataGridView1.DataSource = ds.Tables[0];
}
catch (Exception ex)
{
MessageBox.Show (ex.ToString());
}
}

Export Data Grid to XML

Input:

private void exportotxml()
{
DataSet ds = new DataSet();
dt = new DataTable();
dt.Columns.Add(new DataColumn("sub1", Type.GetType("System.Int32")));
dt.Columns.Add(new DataColumn("sub2", Type.GetType("System.Int32")));
dt.Columns.Add(new DataColumn("sub3", Type.GetType("System.Int32")));
fillRows(22, 22, 22);
fillRows(33, 33, 33);
fillRows(44, 44, 44);
fillRows(55, 55, 55);
ds.Tables.Add(dt);
ds.Tables[0].TableName = "test";
ds.WriteXml("test.xml");
}
private void createrows(int sub1, string sub2, int sub3)
{
DataRow dr ;
dr = dt.NewRow();
dr["sub1"] = sub1;
dr["sub2"] = sub2;
dr["sub3"] = sub3;
dt.Rows.Add(dr);
}

Conclusion

Thus, the article covered in detail the data grid view in c#. It showed various examples like how a data grid view can be loaded from the sql database or an excel file. It also showed how a grid view data can be exported to an excel file or csv file. It also showed how a data grid can be populated without a DB or a data source. It also showed how a new row can be added to a table via a button click. It also explained in detail about the way xml data can be imported into a grid view and how data grid values can be exported into the xml file. To learn more in detail, it would be advisable to write sample programs and practice them.

위 내용은 C# 데이터 그리드 보기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
이전 기사:IEnumerable C#다음 기사:IEnumerable C#