在mysql中显示创建行的日期

时间:2012-09-21 12:10:37

标签: php mysql

我在用户表中添加了一个新行,以显示每个用户的创建日期。 我尝试了时间戳和日期时间类型,但它仍然显示每个用户旁边的00:00:00。

这是我将代码添加到用户表中的代码

$first_name = trim($_REQUEST['first_name']);
$last_name = trim($_REQUEST['last_name']);
$username = trim($_REQUEST['username']);
$password = trim($_REQUEST['password']);
$email = trim($_REQUEST['email']);
$created = strftime("%Y-%m-%d %H:%M:%S", time());
$insert_sql = sprintf("INSERT INTO users (first_name, last_name, username, password, email, created)" .
"VALUES('%s', '%s', '%s', '%s', '%s', '%s');",
mysql_real_escape_string($first_name),
mysql_real_escape_string($last_name),
mysql_real_escape_string($username),
mysql_real_escape_string(crypt($password, $username)),
mysql_real_escape_string($email),
mysql_real_escape_string($created));
mysql_query($insert_sql) or die(mysql_error());

这是显示信息的代码

$select_users = "SELECT * FROM users";
$result =  mysql_query($select_users);
while ($user = mysql_fetch_array($result)) {
$user_row = sprintf(
"<td><input type='checkbox' name='checkbox[]' id='checkbox[]' value='%d'/></td>" .
"<td>%s %s</td> " .
"<td>%s</td>" .
"<td><a href='mailto:%s'>%s</a></td> " .
"<td>%s</td>" .
"<td><a href='javascript:delete_user(%d);'><img class='delete_user' src='images/trash.png' alt='' title='' border='0' /></a></td>",
$user['user_id'], $user['first_name'], $user['last_name'], $user[username],
$user['email'], $user['email'], $user['created'], $user['user_id']);
echo $user_row;

除了显示00:00:00以前的创建日期外,我正确显示了所有字段。 我不知道我做错了什么。 谢谢你的帮助。

编辑:我已经有一个名为“updated”的字段,它使用“Current_timestamp”。

5 个答案:

答案 0 :(得分:3)

您可以在数据库中创建一个使用timestamp类型创建的字段,并将默认值设置为CURRENT_TIMESTAMP,而不是使用php设置时间。这将自动做你需要的没有PHP。 这是代码:

    ALTER TABLE `users` ADD COLUMN `created` timestamp DEFAULT CURRENT_TIMESTAMP;

答案 1 :(得分:1)

MySQL可以在创建记录时插入的字段上加上时间戳。

在你的SQL中把它放在创建的:

`Created` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP

您不需要任何PHP代码来处理时间戳。

答案 2 :(得分:0)

试     $ created = date(“m-d -y H:i:s”,time());

答案 3 :(得分:0)

您实际上可以在MySQL中添加当前时间,而无需重复使用current_timestamp。试试这个作为插入查询;它不涉及任何数据库架构更改,它仍然可以得到正确的结果:

$query = "INSERT INTO users (first_name, last_name, username, password, email, created)"
. "VALUES('%s', '%s', '%s', '%s', '%s', now())"

答案 4 :(得分:0)

一个潜在的解决方法是,既然你知道$ created的值,那么你真的不需要逃避它。因此,$ insert_sql将是:

$insert_sql = sprintf("INSERT INTO users (first_name, last_name, username, password, email, created)"
. "VALUES('%s', '%s', '%s', '%s', '%s', '".$created."');",
mysql_real_escape_string($first_name),
mysql_real_escape_string($last_name),
mysql_real_escape_string($username),
mysql_real_escape_string(crypt($password, $username)),
mysql_real_escape_string($email));

请注意,这仅限于您绝对控制变量的所有内容。