這裏是我的功能,並在婁代碼的日期爲什麼getdate不存儲在數據庫中?
$data->datecreated = getdate();
不會得到保存在數據庫中。爲什麼? 注意,一條記錄被插入,但dateCreated會現場貌似是忽略
public function generateCode($characters) {
//Generate the code
$possible = '23456789bcdfghjkmnpqrstvwxyz';
$code = '';
$i = 0;
while ($i < $characters) {
$code .= substr($possible, mt_rand(0, strlen($possible)-1), 1);
$i++;
}
// Get the curent session id of the user
$session = JFactory::getSession();
$session_id = $session->getId();
//Create an stdClass
$data =new stdClass();
$data->sessionid = (integer)$session_id;
$data->captchacode = (string)$code;
$data->datecreated = getdate();
$db = JFactory::getDBO();
$query = $db->getQuery(true);
$query->delete($db->nameQuote('#__captchasessions'));
$query->where($db->nameQuote('sessionid').'='.$db->quote($session_id));
$db->setQuery($query);
$db->query();
$db->insertObject('#__captchasessions', $data, id);
return $code;
}
這是表
delimiter $$
CREATE TABLE `ok6ut_captchasessions` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`sessionid` varchar(200) DEFAULT NULL,
`captchacode` varchar(10) DEFAULT NULL,
`datecreated` datetime DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=26 DEFAULT CHARSET=utf8$$
告訴我們發生了什麼和在哪裏。 PHP錯誤? MySQL錯誤? – Jocelyn 2012-08-15 23:18:54
沒有錯誤,它只是忽略條目,但其餘的被插入 – themis 2012-08-15 23:23:41
你不需要使用'$ db = JFactory :: getDBO();'兩次 – Lodder 2012-08-15 23:25:27