我想要实现的目标如下: -
1-从数据库中获取具有当前日期(今天)的记录。 2-如果数据库没有今天的记录我希望它从前一天获得它。 3-如果前一天没有任何记录,我希望它从前一天获得,依此类推。
try
{
string date = DateTime.Now.ToShortDateString();
conn.Open();
//string str = "insert into Table1 (title , date_ ,www, cat) values (' " + TextBox1.Text + "','" + DateTime.Now.ToShortDateString() + "','" + TextBox2.Text + "','" + DropDownList1.SelectedItem.Text + "')";
////string str = "INSERT INTO Table1 (title,date_,www ) values ('ddddddd','aaaaaaa','qqqqqq')";
string str =
//"SELECT from table1 WHERE cat = 1 and datee='" + date + "'ORDER BY datee";
"SELECT * FROM table1 WHERE cat = 1 and datee = @dt ORDER BY datee DESC ";
SqlCommand objcmd = new SqlCommand(str, conn);
objcmd.Parameters.AddWithValue("@dt", date);
SqlDataAdapter da1 = new SqlDataAdapter(objcmd);
DataTable dt = new DataTable();
da1.Fill(dt);
//DataRow dr = new DataRow();
//DataRow dr = ds.Tables[0].Rows[0];
int id = 1;
foreach (DataRow dr in dt.Rows)
{
if (id == 1)
{
ll1.Text = dr[1].ToString();
l1.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 2)
{
ll2.Text = dr[1].ToString();
l2.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 3)
{
ll3.Text = dr[1].ToString();
l3.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 4)
{
ll4.Text = dr[1].ToString();
l4.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 5)
{
ll5.Text = dr[1].ToString();
l5.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 6)
{
ll6.Text = dr[1].ToString();
l6.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 7)
{
ll7.Text = dr[1].ToString();
l7.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 8)
{
ll8.Text = dr[1].ToString();
l8.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 9)
{
ll9.Text = dr[1].ToString();
l9.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 10)
{
ll10.Text = dr[1].ToString();
l10.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 11)
{
ll11.Text = dr[1].ToString();
l11.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 12)
{
ll12.Text = dr[1].ToString();
l12.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 13)
{
ll13.Text = dr[1].ToString();
l13.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 14)
{
ll14.Text = dr[1].ToString();
l14.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 15)
{
ll15.Text = dr[1].ToString();
l16.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 16)
{
ll16.Text = dr[1].ToString();
l16.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 17)
{
ll17.Text = dr[1].ToString();
l17.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 18)
{
ll18.Text = dr[1].ToString();
l18.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 19)
{
ll19.Text = dr[1].ToString();
l19.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 20)
{
ll20.Text = dr[1].ToString();
l20.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 21)
{
ll21.Text = dr[1].ToString();
l21.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 22)
{
ll22.Text = dr[1].ToString();
l22.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 23)
{
ll23.Text = dr[1].ToString();
l23.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
if (id == 24)
{
ll24.Text = dr[1].ToString();
l24.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
id = id + 1;
}
}
catch (Exception ex)
{
lblError.Text = "فشل في إحظار الأخبار";
}
finally
{
conn.Close();
}
}
答案 0 :(得分:0)
我建议您更新SQL查询以完成工作并避免2次数据库命中,您可以使用以下内容执行此操作:
string str =
"SELECT * FROM table1 WHERE cat = 1 and datee = @dt ORDER BY datee DESC " +
"UNION SELECT * FROM table1 WHERE cat = 1 and datee < @dt AND (SELECT COUNT(*) FROM table1 WHERE cat = 1 and datee = @dt) = 0 ORDER BY datee DESC";
如果这些结果的计数为0(意味着如果没有选择任何内容,请选择那个日期之前的那些),您可以看到我在结果日期之前加入了所有结果。
答案 1 :(得分:0)
int id = 1;//???????
foreach (DataRow dr in dt.Rows)
{
if (id == 1)//???????
{
ll1.Text = dr[1].ToString();
l1.ImageUrl = @"photo\" + dr[1].ToString() + @".jpg";
}
您始终检查ID = 1的ID 而不是使用这个:
if ( dr[1] == id)
{
...
}
id++
.
.
.
答案 2 :(得分:0)
这里有一些代码可以让整个第一天的所有项目都有任何行(在时间上倒退)。这假设是SQL Server 2005或更高版本(您没有说明您正在使用的DBMS和版本,请执行此操作!):</ p>
WITH Data AS (
SELECT TOP 1 WITH TIES
*
FROM dbo.table1
WHERE
cat = 1
AND datee >= DateAdd(day, -5, @dt)
ORDER BY
Convert(date, datee) DESC
)
SELECT *
FROM Data
ORDER BY datee DESC
;
如果您可以在前端订购行(并且您可能应该这样做),那么您不需要额外的外部查询。使用此TOP 1 WITH TIES
语法,您无法向内部ORDER BY
子句添加更多表达式,因为这会更改所选内容。
您也应该只选择所需的列而不是表格中的所有内容。