foreach语句不能对';gerant';因为';gerant';不包含';GetEnu
本文关键字:gerant 包含 GetEnu 因为 foreach 语句 不能 | 更新日期: 2023-09-27 18:27:33
你好,我试图创建一个名为"gerant"的对象
class gerant
{
public double CIN_GERANT, NUM_TEL_GERANT, MOBILE_GERANT;
public string NOM_GERANT, PRENOM_GERANT, ADRESSE__GERANT, MAIL_GERANT, VILLE_GERANT;
public int CP_GERANT;
public DateTime DATE_GERANT;
public gerant(double _Cin_gerant, string _Nom_Gerant, string _Prenom_Gerant, string _Adresse_Gerant, double _Num_Tel_Gerant, string _Mail_Gerant, double _Mobile_Gerant, int _cp_gerant, string _ville_gerant, DateTime _date_gerant)
{
this.CIN_GERANT = _Cin_gerant;
this.NOM_GERANT = _Nom_Gerant;
this.PRENOM_GERANT = _Prenom_Gerant;
this.ADRESSE__GERANT = _Adresse_Gerant;
this.NUM_TEL_GERANT = _Num_Tel_Gerant;
this.MAIL_GERANT = _Mail_Gerant;
this.MOBILE_GERANT = _Mobile_Gerant;
this.CP_GERANT = _cp_gerant;
this.VILLE_GERANT = _ville_gerant;
this.DATE_GERANT = _date_gerant;
}
public gerant getinfogerant()
{
gerant gerer = null;
string sql_gerant = "select CIN,NOM,PRENOM,ADRESS_PERSONNEL,NUM_TEL,MAIL,MOBILE,CP_GERANT,VILLE_GERANT,DATE_CIN from GERANT";
connexion connect = new connexion();
OleDbConnection connection = connect.getconnexion();
// try
//{
connection.Open();
OleDbCommand cmd = new OleDbCommand(sql_gerant, connection);
OleDbDataReader reader = cmd.ExecuteReader();
if (reader.Read())
{
gerer = new gerant(reader.GetDouble(0),
reader.GetString(1),
reader.GetString(2),
reader.GetString(3),
reader.GetDouble(4),
reader.GetString(5),
reader.GetDouble(6),
reader.GetInt32(7),
reader.GetString(8),
reader.GetDateTime(9)
);
}
connection.Close();
return gerer;
}
}
但是当我尝试用gerant填充我的combobox时,我尝试插入这个代码
foreach(Modele.gerant ligne in liste_gerant)
{
}
但是我犯了这个错误foreach语句无法对类型为"gerant"的变量进行操作,因为"gernt"不包含"GetEnumerator"的公共定义
我该如何解决这个问题?
基于您的评论。gerant类不是任何类型的集合,您的getinfogerant也不返回集合。
因此,问题在于您试图对单个值进行迭代。
根据您在getinfogerant中使用的查询,我想您希望它能获得数据库中的所有"gerant",而不仅仅是一个?
然而,现在你只是返回第一个。您应该将其返回类型更改为List,并将if(reader.Read())转换为while循环来填充列表,然后在末尾返回整个列表。