我正在尝试从特定日期到另一个日期从数据库表中获取数据;但是当我进行过滤时,并没有带来任何结果。
在我的数据库中,日期的格式为 2010-01-29 00:00:00.000 ,但是我想使用 YMD进行过滤,即2010-01-29
下面是我的查询:
$froms = $_POST['from'];
$tos = $_POST['to'];
if($froms==""){
$froms = "AND Loans.Disb_Date <= company.BRSES_DATE";
}else{
$froms = "AND Loans.Disb_Date <= '".$from."'";
}
if($to != ""){
$tos = "AND Loans.Disb_Date = '".$to."'";
}
和sql查询
SELECT ".$limitresult."
coa.loan_lmt,
company.BRSES_DATE,
Loans.Branch,
Loans.GL_NO,
Loans.AC_No,
Loans.Cycle,
Loans.Disb_Date,
Loans.Loan_Amt+Loans.Tot_Int as Loan_amount_and_Interest_added,
Loans.Loan_Amt,
Loans.Tot_Int,
Loans.Exp_Date,
Loans.cust_type,
LN_Period AS
LN_PERIODx,
Inst_Type AS Inst_TYpeX,
Customer.Cust_No, Loans.fx_rate,
Customer.Name,
Ref_NO AS Ref_No8,
Customer.Phone,
Loans.Officer,
Loans.LNP_Code,
Loans.bus_type,
bustype.descriptio,
inst_type, Loans.ln_period,
Loans.full_paid, Loans.Class_Age,
Loans.Gl_No+Loans.Ac_No+Loans.Branch+LTRIM(str(Loans.cycle)) AS LoanId,
member.ac_status,
-SUM(CASE WHEN trx_type='LD' THEN LoanHist.principal+LoanHist.interest ELSE 0 END) -
SUM(CASE WHEN trx_type='LP' THEN LoanHist.principal+LoanHist.interest ELSE 0 END) AS outstanding_balance,
MAX(CASE WHEN trx_type='LD' THEN LoanHist.principal+LoanHist.interest ELSE 0 END) AS instalment_amount,
-SUM(CASE WHEN trx_type='LD' THEN LoanHist.principal+LoanHist.interest ELSE 0 END) AS loan_amount,
MAX(CASE WHEN trx_type='LP' THEN trx_date ELSE NULL END) AS last_payment_date,
SUM(CASE WHEN trx_type='LP' THEN LoanHist.principal+LoanHist.interest ELSE 0 END) AS amount_paid,
-SUM(CASE WHEN trx_type='LD' AND trx_date < company.BRSES_DATE THEN LoanHist.principal+LoanHist.interest ELSE 0 END) -
SUM(CASE WHEN trx_type='LP' AND trx_date < company.BRSES_DATE THEN LoanHist.principal+LoanHist.interest ELSE 0 END) AS overdue
FROM Loans INNER JOIN Member
ON Loans.Branch = Member.Branch AND Loans.GL_NO = Member.GL_NO AND Loans.AC_NO = MEMBER.AC_NO INNER JOIN Customer
ON Member.Branch = Customer.Branch AND Member.CUST_NO = Customer.Cust_NO
INNER JOIN Company ON Customer.Branch = Company.Branch
INNER JOIN bustype ON loans.bus_type=bustype.code
INNER JOIN coa ON loans.gl_no = coa.gl_no
INNER JOIN Loanhist ON LoanHist.Branch = Loans.Branch
AND LoanHist.GL_NO = Loans.GL_NO
AND LoanHist.AC_NO = Loans.AC_NO
AND LoanHist.Cycle = Loans.Cycle
WHERE Loans.Branch = company.Branch AND Loans.full_paid != 1 AND Company.Reg_Code = 0 ".$froms." ".$tos."
".$branchid." ".$accnos." ".$stas."
GROUP BY LoanHist.Branch,LoanHist.GL_NO,LoanHist.AC_No,LoanHist.Cycle,Loans.branch,Loans.gl_no, Loans.ac_no, Loans.cycle,
Loans.disb_date, Loans.loan_amt, Loans.tot_int,Loans.exp_date,Loans.ln_period,Loans.inst_type,Customer.cust_no,Loans.fx_rate,
Customer.name, Customer.ref_no, Customer.phone,Loans.officer,Loans.LNP_Code,Loans.bus_type,bustype.descriptio,Loans.full_paid,
Loans.Class_Age,Member.ac_status,Loans.cust_type,company.BRSES_DATE, coa.loan_lmt
我在做什么错了?
答案 0 :(得分:1)
我不是用十英尺高的杆触碰该查询,但是一个简化的查询示例将类似于:
SELECT id FROM dbTable WHERE LEFT(dateStamp,10) = '2010-10-29';
如果您有dateFrom
和dateTo
列,并且想要查找对单个日期有效的结果,则可以执行以下操作:
SELECT id FROM dbTable WHERE ('2010-01-29 00:00:00' BETWEEN dateFrom and dateTo)
ORDER BY dateTo DESC;