【发布时间】:2013-12-05 21:36:57
【问题描述】:
public static DataTable ReportsCityFilter(DateTime dtStart, DateTime dtEnd)
{
//Dictionary<DateTime.TryParse((string DateString, IFormatProvider provider, System.Globalization.DateTimeStyles styles, "ddMMyyyy"), object> objDic = new Dictionary<DateTime, object>();
Dictionary<string, object> objDic = new Dictionary<string, object>();
objDic.Add("@start_date", dtStart);
objDic.Add("@end_date", dtEnd);
return dal.execute(objDic, "sp_admin_reports_city_filter_select").Tables[0];
}
我有一个按城市报告的页面,现在我在其上添加了一个下拉列表以按日期过滤结果,即周、今天、月、年等
其他一切正常,但这段代码有问题,因为它给我错误“从字符串转换日期和/或时间时转换失败。”
附:这是我的存储过程
更改程序 [dbo].[sp_admin_reports_city_filter_select] -- 这里添加存储过程的参数 --@id INT = NULL @start_date 日期时间 , @end_date 日期时间 作为 开始 --declare @startdate 日期时间 设置@start_date = '2999-01-01'
if @start_date = 'today'
begin
select jp.id, city.name[City]
, row_number() over (order by city.name) [sr_no]
, count(jp.id) over (partition by name) as no_of_posts
, COUNT(od.id) over (partition by name) as no_of_employers
,CONVERT(varchar(12), jp.posting_date, 103) [date_created]
from rs_job_posting jp
inner join rs_job_posting_location jpl on jpl.id = jp.id
inner join rs_cor_city city on city.id = jpl.city_fk
inner join rs_organization_detail od on od.id = jp.id
where DAY(posting_date) = DAY(GETDATE())
order by no_of_posts Desc
select jp.date_updated
from rs_job_posting jp
END
else if @start_date = 'weekly'
begin
select jp.id, city.name[City]
, row_number() over (order by city.name) [sr_no]
, count(jp.id) over (partition by name) as no_of_posts
, COUNT(od.id) over (partition by name) as no_of_employers
,CONVERT(varchar(12), jp.posting_date, 103) [date_created]
from rs_job_posting jp
inner join rs_job_posting_location jpl on jpl.id = jp.id
inner join rs_cor_city city on city.id = jpl.city_fk
inner join rs_organization_detail od on od.id = jp.id
where DAY(posting_date) = DAY(GETDATE())
order by no_of_posts Desc
select jp.date_updated
from rs_job_posting jp
end
else if @start_date = 'byweekly'
begin
select jp.id, city.name[City]
, row_number() over (order by city.name) [sr_no]
, count(jp.id) over (partition by name) as no_of_posts
, COUNT(od.id) over (partition by name) as no_of_employers
,CONVERT(varchar(12), jp.posting_date, 103) [date_created]
from rs_job_posting jp
inner join rs_job_posting_location jpl on jpl.id = jp.id
inner join rs_cor_city city on city.id = jpl.city_fk
inner join rs_organization_detail od on od.id = jp.id
where DAY(posting_date) = DAY(GETDATE())
order by no_of_posts Desc
select jp.date_updated
from rs_job_posting jp
end
else if @start_date = 'monthly'
begin
select jp.id, city.name[City]
, row_number() over (order by city.name) [sr_no]
, count(jp.id) over (partition by name) as no_of_posts
, COUNT(od.id) over (partition by name) as no_of_employers
,CONVERT(varchar(12), jp.posting_date, 103) [date_created]
from rs_job_posting jp
inner join rs_job_posting_location jpl on jpl.id = jp.id
inner join rs_cor_city city on city.id = jpl.city_fk
inner join rs_organization_detail od on od.id = jp.id
where DAY(posting_date) = DAY(GETDATE())
order by no_of_posts Desc
select jp.date_updated
from rs_job_posting jp
end
else if @start_date = 'yearly'
begin
select jp.id, city.name[City]
, row_number() over (order by city.name) [sr_no]
, count(jp.id) over (partition by name) as no_of_posts
, COUNT(od.id) over (partition by name) as no_of_employers
,CONVERT(varchar(12), jp.posting_date, 103) [date_created]
from rs_job_posting jp
inner join rs_job_posting_location jpl on jpl.id = jp.id
inner join rs_cor_city city on city.id = jpl.city_fk
inner join rs_organization_detail od on od.id = jp.id
where DAY(posting_date) = DAY(GETDATE())
order by no_of_posts Desc
select jp.date_updated
from rs_job_posting jp
end
结束
【问题讨论】:
-
如果您告诉我们错误的实际位置。谢谢
-
我很确定这是您的过程
sp_admin_reports_city_filter_select中发生的 SQL 错误。您可以发布程序定义吗?此错误是已选择 the wrong data type 的模式的特征,并且您将日期存储为字符串。这将继续导致问题,直到从源头得到纠正。即将日期存储为日期。
标签: c# sql sql-server