C#

[".0s4*0|collections;datetime-format;.",["FIeCD","OCECNCJADEIAMAOLBEJIJAOCRCKIOGHAKAPEIAECLA","OOOCCCSTUUUUTTUUUUYFGHDGDGDRDGDGDADADADADADOBOBOCBCPGDGDHDGDRDFOCCBCPGHDGDRDRDGDADADGDFOCBCPGDGDGDGDADADADGDGDADADADGDGDRDGHDGDGDGDGDGDHDGDHDGDOCCOCCBOCPGDHDOBCOBOBOBOBOBOBOBBBBBBBOBBWSTTUUUUTTUUUU","e..w..tt.td.s.trs.",".NET","Array","Dictionary","List","String","2D","Async","Console","DataTable","Dates","DateTime","Enum","File","For","Foreach","Format","IEnumerable","If","IndexOf","Lambda","LINQ","Optimization","Parse","Path","Process","Property","Random","Regex","Replace","Sort","Split","Static","Substring","Switch","Tuple","While","DataTable."," A crystal has many sides. It has many aspects. It reflects light. With computer data we have many rows and columns: each cell (each facet) is part of the whole.","The DataTable class"," stores rows and columns of data. It is part of the System.Data namespace. We add, select and iterate over stored data.","First program."," Data can come from a database, from a method, from memory. Here, GetTable generates a table with 4 columns of different types. ","Then: ","The table could be persisted to disk, displayed, or stored in memory. It is like any other object.","GetTable: ","This method creates a new DataTable reference. It adds 4 column collections, then 5 rows.","Typeof: ","We must specify a type (as with typeof) to create a Column. All fields from rows in this column must have this type.","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","br","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","Based on:"," .NET 4.6\n\n","C# program that uses DataTable","\n\nusing System;\nusing System.Data;\n\nclass Program\n{\n static void Main()\n {","\n // Get the DataTable.\n ","DataTable"," table = GetTable();","\n // ... Use the DataTable here with SQL.\n ","}","\n\n /// <summary>\n /// This example method generates a DataTable.\n /// </summary>\n ","static DataTable ","GetTable","()\n {","\n // Here we create a DataTable with four columns.\n ","DataTable table = new DataTable();\n table.Columns.Add(\"Dosage\", typeof(int));\n table.Columns.Add(\"Drug\", typeof(string));\n table.Columns.Add(\"Patient\", typeof(string));\n table.Columns.Add(\"Date\", typeof(DateTime));","\n\n // Here we add five DataRows.\n ","table.Rows.Add(","25",", \"Indocin\", \"David\", DateTime.Now);\n table.Rows.Add(","50",", \"Enebrel\", \"Sam\", DateTime.Now);\n table.Rows.Add(","10",", \"Hydralazine\", \"Christoff\", DateTime.Now);\n table.Rows.Add(","21",", \"Combivent\", \"Janet\", DateTime.Now);\n table.Rows.Add(","100",", \"Dilantin\", \"Melanie\", DateTime.Now);\n return table;\n }\n}","Foreach-loop."," Often we want to loop over our DataTable rows. This can be done with a foreach-loop. The exact syntax can be confusing, and objects are sometimes needed. ","Foreach ","datatable-foreach","Compare rows."," Data may sometimes contain duplicate rows. This condition can be detected with a simple looping algorithm. The syntax can be used for many DataTable tasks. ","Compare Rows ","datatable-compare-rows","Rows, field."," We build in complexity\u2014here we loop over all Rows of our DataTable. We then access the first field, with the Field extension method, as an int. ","Generic method: ","Field is a generic method. So we must specify its parametric type (here, int) to indicate its behavior.","Field ","datarow-field","Rows: ","Often we must access the rows of a DataTable. The Rows property, which can be looped over, is ideal here.","C# program that uses Rows, Field","\n\nusing System;\nusing System.Data;\n\nclass Program\n{\n static void Main()\n {","\n // This uses the GetTable method (please paste it in).\n ","DataTable data = GetTable();","\n\n // ... Loop over all rows.\n ","foreach (DataRow row in data.","Rows",")\n {","\n // ... Write value of first field as integer.\n ","Console.WriteLine(row.","Field<int>","(0));\n }\n }\n}\n\n","Output","\n\n25\n50\n10\n21\n100","Using."," DataTable can be placed in a using statement. This can help programs' performance. Often the using block construct helps improve resource management. ","Tip: ","We can add Columns and Rows to the DataTable instance inside (but not outside) the using block.","Tip 2: ","In this example, the Dispose method is invoked. After the using statement, Dispose() on DataTable is called.","Using ","using","Dispose: ","When Dispose is called, native resources are released. This may help resource usage problems.","C# program that uses using statement","\n\nusing System;\nusing System.Data;\n\nclass Program\n{\n static void Main()\n {","\n // Safely create and dispose of a DataTable.\n ","using"," (DataTable table = new DataTable())\n {","\n // Two columns.\n ","table.Columns.Add(","\"Name\"",", typeof(string));\n table.Columns.Add(","\"Date\"",", typeof(DateTime));","\n\n // ... Add two rows.\n ","table.Rows.Add(","\"cat\"",", DateTime.Now);\n table.Rows.Add(","\"dog\"",", DateTime.Today);","\n\n // ... Display first field.\n ","Console.WriteLine(table.Rows[0].Field<string>(0));\n }\n }\n}\n\n","Output","\n\ncat","DataGridView example."," We insert data from object collections (like List) into DataTable. We then render that table to the screen with Windows Forms. DataTable helps display data. ","Tip: ","DataTable works well with DataGridView. It makes DataGridView simpler and easier.","DataGridView ","datagridview","Caution: ","DataGridView has performance problems with manually adding rows. Using DataTable, List and DataSource helps.","C# program that uses DataGridView","\n\nusing System.Collections.Generic;\nusing System.Data;\nusing System.Windows.Forms;\n\nnamespace WindowsFormsApplication1\n{\n public partial class Form1 : Form\n {","\n /// <summary>\n /// Contains column names.\n /// </summary>\n ","List<string> _names = new List<string>();","\n\n /// <summary>\n /// Contains column data arrays.\n /// </summary>\n ","List<double[]> _dataArray = new List<double[]>();\n\n public Form1()\n {\n InitializeComponent();","\n\n // Example column.\n ","_names.Add(\"Cat\");","\n // Three numbers of cat data.\n ","_dataArray.Add(new double[]\n {\n ","1.0",",\n ","2.2",",\n ","3.4","\n });","\n\n // Another example column.\n ","_names.Add(\"Dog\");","\n // Add three numbers of dog data.\n ","_dataArray.Add(new double[]\n {\n ","3.3",",\n ","5.0",",\n ","7.0","\n });","\n // Render the DataGridView.\n ","dataGridView1.DataSource = GetResultsTable();\n }","\n\n /// <summary>\n /// This method builds a DataTable of the data.\n /// </summary>\n ","public DataTable ","GetResultsTable","()\n {","\n // Create the output table.\n ","DataTable"," d = new DataTable();","\n\n // Loop through all process names.\n ","for (int i = 0; i < this._dataArray.Count; i++)\n {","\n // The current process name.\n ","string name = this._names[i];","\n\n // Add the program name to our columns.\n ","d.Columns.Add(name);","\n\n // Add all of the memory numbers to an object list.\n ","List<object> objectNumbers = new List<object>();","\n\n // Put every column's numbers in this List.\n ","foreach (double number in this._dataArray[i])\n {\n objectNumbers.","Add","((object)number);\n }","\n\n // Keep adding rows until we have enough.\n ","while (d.Rows.Count < objectNumbers.Count)\n {\n d.Rows.","Add","();\n }","\n\n // Add each item to the cells in the column.\n ","for (int a = 0; a < objectNumbers.Count; a++)\n {\n d.Rows[a][i] = objectNumbers[a];\n }\n }\n return d;\n }\n }\n}","Notes on example."," The code creates a DataTable and populates it with data. It is an entire Form and can be dropped into a Windows Forms application with a DataGridView in the designer. ","Arrays: ","The two arrays are initialized in the class and constructor. They contain column information.","Note: ","Sorry for the confusing code. The important parts are how we interact with the DataTable, as with Columns.Add.","Loop through columns."," We have a collection that contains many arrays. Each of those arrays needs to be a new column. We use DataTable's methods to expand its size. ","Add: ","We add the column names to our DataTable with Columns.Add. These are the column headers.","Tip: ","DataTable requires objects to assign to the cells. Objects can hold any type of data.","Object ","object","DataSource."," With this property in Windows Forms, we can assign a DataTable to render the data. DataSource improves display performance. Everything is added at once. ","Sometimes: ","It is helpful to assign DataSource to null to clear it\u2014this internally resets the data binding.","Example code that sets DataSource: C#","\n\n","// ... Draw new cells on DataGridView.\n","dataGridView1.","DataSource"," = null;\ndataGridView1.DataSource = GetResultsTable();","Convert."," The List type is often useful. DataTable is better when we interact with controls such as DataGridView or with SQL databases. We can convert between the types. ","Convert List, DataTable ","convert-list-datatable","Note: ","Many DataTable-List conversions may be needed. Often conversions require custom logic to be successful.","Rows."," Two important parts of DataTable are its Rows and Columns collections. With Rows, we access fields from a DataTable. We can loop over Rows with foreach. ","DataRow ","datarow","Columns."," Think of columns as templates for rows. The fields in rows must adhere to the types specified in the corresponding DataColumns. Only a few columns are usually needed. ","DataColumn ","datacolumn","DataSet."," We can combine multiple DataTable instances into one collection with the DataSet type. So a DataSet is a set of DataTables (and other things from System.Data). ","DataSet ","dataset","DataView."," With this type, we can sort a DataTable's representation. We use the Sort property. The underlying data is not mutated. ","DataView ","dataview","Select."," We can use the Select method on DataTable. This filters elements based on some criteria. We receive an array of DataRow instances that match our filter. ","Select ","datatable-select","RowChanged."," A DataTable can monitor its changes. We use the RowChanged event, and similar events like ColumnChanged to detect changes. The AcceptChanges method too is helpful. ","RowChanged ","datatable-rowchanged","SQL types."," With SQL, we formulate queries to database servers. SqlClient is used with many related types. These types reside alongside DataTable in System.Data. ","SqlClient ","sqlclient","SqlCommand ","sqlcommand","SqlCommandBuilder ","sqlcommandbuilder","SqlConnection ","sqlconnection","SqlDataAdapter ","sqldataadapter","SqlDataReader ","sqldatareader","SqlParameter ","sqlparameter","SQL types, other."," Sometimes SqlClient does not work on a specific database. Types such as OdbcConnection are helpful here. With OdbcConnection we can use MySQL database servers. ","OdbcConnection ","odbcconnection","SQLCE ","sqlce","A summary."," DataTable is a powerful, convenient class. We added columns. We added rows. DataTable is faster, in Windows Forms, than manually adding rows. It reduces complexity. ","br","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","3679700504","data-ad-format","link","br","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto"],"url()","url()","url()"]

["url()","url()","url()","url()","url()","url()","url()","url()","A","url()","url()","url()","url()","url()","url()","url()","B","url()"]