我在用户表中添加了一个新行,以显示每个用户的创建日期。 我尝试了时间戳和日期时间类型,但它仍然显示每个用户旁边的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”。
答案 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));
请注意,这仅限于您绝对控制变量的所有内容。