我有一个名为memberreport的表,其中成员可以发送多个报告。然而,我正试图对提交了3份以上报告的成员进行检查。
每个成员帐户都有一个唯一的属性,即memberID。所有成员报告都需要一个成员帐户(包含一个memberID )才能报告。
从下面的SQL代码中可以看到
SqlConnection con = new SqlConnection("Data Source = localhost; Initial Catalog = MajorProject; Integrated Security= SSPI");
con.Open();
DataSet ds = new DataSet();
SqlDataAdapter da = new SqlDataAdapter("Select distinct memberID from MemberReport where memberID >= 3", con);
da.Fill(ds);
ddlNRIC.DataSource = ds;
ddlNRIC.DataTextField = "memberID";
ddlNRIC.DataValueField = "memberID";
ddlNRIC.DataBind();
con.Close();我正在尝试显示提交了3份以上报告的memberID。但是,我从Visual接收到此错误
Conversion failed when converting the varchar value 'Q12345T' to data type int.数字&字母'Q12345T‘是一个memberID。我的属性是varchar。但是我插入了这行代码
memberID >= 3应该能够显示出memberID谁已经提交了超过3份报告,但没有工作。我试图在下拉列表中显示提交了3份以上报告的memberID。我添加了一个不同的,应该能够防止重复的memberID。
发布于 2013-07-30 06:30:08
where检查列的值,而不是该列在表中出现的次数。对于这样的任务,您需要having子句:
select memberID from MemberReport
group by memberID
having (count(memberID) >= 3)https://stackoverflow.com/questions/17939719
复制相似问题