首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PHP用于搜索SQL DB之间的日期

PHP用于搜索SQL DB之间的日期
EN

Stack Overflow用户
提问于 2013-04-25 23:44:03
回答 3查看 940关注 0票数 0

我有一个SQL DB,其中我根据日期和时间存储信息。

SQL存储格式为2013-04-25 15:13:37

列名为date_time且为Var

我的搜索PHP如下:

代码语言:javascript
复制
<form action="control_lbsresult.php" method="get">
                <input type="hidden" name="member_msisdn" value="<?=$query?>" 
/>
                <input type="text" name="query" />
                <br />
                <label for="dates"></label>
                <input type="date" name="dates" id="dates" />
                 Start Date<br />
                <label for="datee"></label>
                <input type="date" name="datee" id="datee" />
                 End Date<br />
                <input type="submit" value="Search" />
            </form>

这是它在URL中提供的字符串

代码语言:javascript
复制
/control_lbsresult.php?member_msisdn=&query=0827910119&dates=2013-04-01&datee=2013-04-
25

这是我在我的结果页面中的内容:

代码语言:javascript
复制
<?php
$host="localhost"; // Host name 
$username="***"; // Mysql username 
$password="****"; // Mysql password 
$db_name="****"; // Database name 
$tbl_name="lbs_"; // Table name

// Connect to server and select database.
mysql_connect("$host", "$username", "$password")or die("cannot connect"); 
mysql_select_db("$db_name")or die("cannot select DB");

// get value of id that sent from address bar
$id=$_GET['id'];

// Retrieve data from database 
$sql="SELECT * FROM $tbl_name WHERE date between  '" . $dates . "' AND '" . $datee . "'    
msisdn='$msisdn'";

它不是在日期之间进行过滤,而是为我提供MSISDN的所有结果

我认为问题出在WHERE字符串中,请协助

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-04-25 23:45:16

对日期使用BETWEEN可能会得到意想不到的结果。试着这样做:

代码语言:javascript
复制
SELECT * 
FROM $tbl_name 
WHERE date >=  '" . $dates . "' 
AND date <= '" . $datee . "' 
票数 1
EN

Stack Overflow用户

发布于 2013-04-25 23:59:02

使用BETWEEN>= & <=,两者都应该可以工作。

您需要确保字段类型为DATE

另外,我建议使用mysqli。

以下是为您提供的示例代码:

代码语言:javascript
复制
$stmt = $db->prepare("SELECT * FROM tbl_name WHERE date_field between ? AND ?");

$stmt->bind_param("ss",$start_date,$end_date);

$stmt->execute();
票数 1
EN

Stack Overflow用户

发布于 2013-04-25 23:48:19

  1. 更改列的类型。

ALTER TABLE tbl MODIFY COLUMN date datetime;

使用BETWEEN.的

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16219190

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档