ASPのDateDiff()関数を使用して、2つの日付の日付の違いを見つけています。
この関数は正常に機能し、2つの日付の正確な日付の違いを表示しますが、この値をデータベースに挿入する場合、日付の違いに関係なく、値として9を取ります。
2つの日付の差が15日または20日を超えるとすると、データベースでは「9」かかります。
日付の差を表示する列のデータ型としてINTを使用しました。
ここでDATATYPEが問題を引き起こしていますか?セッション変数を使用して値を格納しようとしましたが、うまくいきませんでした-以下に私のコードを示します:
if request.Form("sub") <> "" then
sql = "Select * from emp_leave_details"
rs.open sql , con, 1, 2
dim diff
dim todate
dim fromdate
fromdate= rs("leave_from")
todate= rs("leave_to")
session("date_diff")=datediff("d",fromdate,todate)
rs.addnew
rs("emp_name") = request.Form("name")
rs("emp_no") = request.Form("number")
rs("address") = request.Form("address")
rs("contact_no") = request.Form("contact")
rs("mobile_no") = request.Form("mobile")
rs("contact_onleave") = request.Form("contact_details")
rs("leave_type") = request.Form("rad")
rs("other_leave_details") = request.Form("PS")
rs("leave_from") = request.Form("from")
rs("leave_to") = request.Form("to")
rs("applied_by") = request.Form("apply")
rs("accepted_by") = request.Form("accept")
rs("approved_by") = request.Form("approve")
rs("no_of_leave_taken")= session("date_diff")
rs.update
response.Write("<script language='javascript'>{update();}</script>")
rs.close
end if