实现了数据库的建表、存储数据的功能后,还需要实现数据库的读取,综合查资料后发现有两种发发比较好;
一、如需要界面操作,需要将数据表格在界面上显示出来的话,需要使用DataGrid控件。
基本操作流程:声明一个数据适配器和数据集,并将读取指令赋值给数据适配器的指令,打开数据库,执行数据适配器的指令,然后将适配器读取的数据填充到数据集中,最后将数据集通过DATAGrid的控件显示出来。
string myConn="server=127.0.0.1;uid=data;database=test;Trusted_Connection=no"; //定义数据库连接参数 SqlConnection MyConnection=new SqlConnection(MyConn); //定义一个数据连接实例 SqlCommand MyCommand=new SqlCommand("SELECT wavelength FROM data",MyConnection); //定义一个数据库操作指令 SqlDataAdapter SelectAdapter=new SqlDataAdapter(); //定义一个数据适配器 SelectAdapter.SelectCommand=MyCommand; //定义数据适配器的操作指令 DataSet MyDataSet=new DataSet(); //定义一个数据集 MyConnection.Open(); //打开数据库连接 SelectAdapter.SelectCommand.ExecuteNonQuery(); //执行数据库查询指令 MyConnection.Close(); //关闭数据库 SelectAdapter.Fill(MyDataSet); //填充数据集 DataGrid1.DataSource=MyDataSet; DataGrid1.DataBind(); //将数据表格用数据集中的数据填充
二、通过SqlDataReader直接读取数据库中某行或者某列的数据
//1.构建数据库查询语句,X为你所查询的值所在的列名,table 为你保存数据的表名。string sql = "select x from [table]"; //2.数据库查询 SqlConnection conn = new SqlConnection(_connstring); SqlCommand command = new SqlCommand(sql, conn); //3.执行数据库查询获取返回值 List<string> list = new List<string>(); use(conn) { conn.Open(); SqlDataReader reader = command.ExecuteReader(); while(reader.read()) { for(int i=0;i<reader.FiledCount;i++) { list.Add(reader[i].ToString()); } }
原文链接:C#从MySQL数据库中读取