读取数据库的数据并转换成List

时间:2022-01-29 13:30:30

一、在有帮助类DbHelperSQL的时候

1、下为其中返回SqlDataReader的方法

 1 /// <summary>
 2         /// 执行查询语句,返回SqlDataReader ( 注意:调用该方法后,一定要对SqlDataReader进行Close )
 3         /// </summary>
 4         /// <param name="strSQL">查询语句</param>
 5         /// <returns>SqlDataReader</returns>
 6         public static SqlDataReader ExecuteReader(string strSQL)
 7         {
 8             SqlConnection connection = new SqlConnection(connectionString);
 9             SqlCommand cmd = new SqlCommand(strSQL, connection);
10             try
11             {
12                 connection.Open();
13                 SqlDataReader myReader = cmd.ExecuteReader(CommandBehavior.CloseConnection);
14                 return myReader;
15             }
16             catch (System.Data.SqlClient.SqlException e)
17             {
18                 throw e;
19             }   
20 
21         }

2、三层DAL层方法

 1 /// <summary>
 2         /// 把读出的数据转换成List
 3         /// </summary>
 4         public List<int> GetUserList(int hid)
 5         {
 6             string sql = " select V_UserID from UserVoters where V_HeadlineID=" + hid + "";
 7             SqlDataReader dr = DbHelperSQL.ExecuteReader(sql);
 8             List<UserVotersModel> plist = new List<UserVotersModel>();
 9             while (dr.Read())
10             {
11                 UserVotersModel uvm = new UserVotersModel();
12                 uvm.V_UserID = int.Parse(dr["V_UserID"].ToString());
13                 plist.Add(uvm);
14             }
15             List<int> list = new List<int>();
16             for (int i = 0; i < plist.Count; i++)
17             {
18                 list.Add(int.Parse(plist[i].V_UserID.ToString()));
19             }
20             return list;
21         }

3、把List当参数放到sql语句里的方法

 1  /// <summary>
 2         /// 获得未投票用户列表
 3         /// </summary>
 4         public DataSet GetNoPersonList(List<int> list)
 5         {
 6             StringBuilder strSql = new StringBuilder();
 7             if (list != null && list.Count > 0)
 8             {
 9                 string listMes = string.Empty;
10                 foreach (int str in list)
11                 {
12                     listMes += "'" + str + "',";
13                 }
14                 strSql.Append("select U_Uid,U_Name,U_Sex,U_Phone,U_QQ  from dbo.UsersInfo where U_ID not in(" + listMes.TrimEnd(',') + ") and U_Level=4 and U_Name='' ORDER BY  U_ID DESC ");
15                 return DbHelperSQL.Query(strSql.ToString());
16             }
17             else
18             {
19                 strSql.Append(" select U_Uid,U_Name,U_Sex,U_Phone,U_QQ  from dbo.UsersInfo where U_Level=4 and  U_Name='' ORDER BY  U_ID DESC ");
20                 return DbHelperSQL.Query(strSql.ToString());
21             }
22         }

二、没有帮助类直接读取数据库

 1 /// <summary>
 2         /// 读取数据库的信息,并转换成List
 3         /// </summary>
 4         public List<MailData> GetExpiredLicense()
 5         {
 6             string connectionString = "Data Source=01;Initial Catalog=Music;Persist Security Info=True;User ID=Musicname;Password=123456";
 7             SqlConnection conn = new SqlConnection(connectionString);
 8             conn.Open();         
 9             string sql = string.Format( @" select * from Tale" );
10             
11             SqlDataAdapter da = new SqlDataAdapter(sql, connectionString);
12             DataSet ds = new DataSet();
13             da.Fill(ds);
14             List<MailData> list = new List<MailData>(); //MailData为要查询表的实体类    
15             foreach (DataRow item in ds.Tables[0].Rows)
16             {
17                 list.Add(MailData.ConvertRow(item));
18             }
19             return list;
20         }