1

我有一个包含事件的表格,并希望根据用户选择的日期范围列出所有事件。我使用 jQuery datepicker,从中获取值并放入 sql 查询以显示所选日期范围内的事件。我的日期格式是 YYYY-mm-dd (fe 2016-05-05),但是当我从日期选择器中选择日期时,它是 (YYYY-05-05)。由于某种原因,它不会将 yyyy 转换为日期,而是将月份和日期转换为日期。这是我的代码:

 <link rel="stylesheet" href="//code.jquery.com/ui/1.11.4/themes/smoothness/jquery-ui.css">
 <script src="//code.jquery.com/jquery-1.10.2.js"></script>
 <script src="//code.jquery.com/ui/1.11.4/jquery-ui.js"></script>
 <link rel="stylesheet" href="/resources/demos/style.css">

 <script>
 $(function() {
 var firstdate = $('#firstdatepicker').datepicker({ dateFormat: 'YYYY- mm-dd' }).val();
 });
 </script>


 <script>
 $(function() {
 var lastdate = $('#lastdatepicker').datepicker({ dateFormat: 'YYYY-mm- dd' }).val();
 });
 </script>
</head>
<body>
<form method="post" action="archive.php">
  <p>First Date: <input name = "firstdatepicker" type="text"  id="firstdatepicker"></p>

 <p>Last Date: <input name = "lastdatepicker" type="text"  id="lastdatepicker"></p>

 <input type="submit" value="Get Data" name="data"/>

 </form>

我在 php 中的查询

 if(!isset($_POST['filters']) && isset($_POST['firstdatepicker']) && isset($_POST['lastdatepicker']) ){

 $firstdate = $_POST['firstdatepicker'];
 $lastdate = $_POST['lastdatepicker'];

$query= "SELECT *
        FROM Event
        WHERE Event.`start_date` BETWEEN '$firstdate' and '$lastdate'
        ORDER BY start_date DESC";

}

4

3 回答 3

2

YYYY不是有效的日期格式,您应该使用yy(两个小写 y)

另外,只是一个建议-您应该post使用某种功能(例如mysqli_real_escape_string或适合您的 SQL 连接的任何功能)转义用户输入()

于 2016-12-11T15:52:53.750 回答
1

改成:

var lastdate = $('#lastdatepicker').datepicker({ dateFormat: 'yy-mm-dd' }).val();

var firstdate = $('#firstdatepicker').datepicker({ dateFormat: 'yy-mm-dd' }).val();

看看:http ://api.jqueryui.com/datepicker/#option-dateFormat

于 2016-12-11T15:54:02.260 回答
0

使用 yy 作为 4 位数年份占位符: dateFormat: "yy-mm-dd"

于 2016-12-11T15:55:22.693 回答