我的本地灯组上有一个可用的 Yii 应用程序。现在,当我将应用程序放在灯服务器上时,应用程序读取数据库并运行,但应用程序没有成功写入数据库。我没有收到任何错误日志。有什么想法吗?
这是我更新数据库的方式:
public function actionIndex()
{
if ($_GET["yep"] == "") {
pd_error("You are not logged in!");
}
list($uid, $domain) = preg_split("/@/",$_GET["yep"],2);
$model=$this->loadModel($uid);
$this->redirect($model->URL."?".$model->Unique_ID);
}
public function loadModel($uid)
{
$model=People::model()->findByPk($uid);
$model->Login_Count++;
$model->Last_Logged=date('Y-m-d H:i:s');
if ($model->validate()) {
$model->save();
} else {
$this->render('notice');
}
return $model;
}
奇怪的是,即使数据库没有更新 Login_Count 和 Last_Logged 用户仍然会被重定向到他们的 url,所以 sql 必须是有效的,因为通知页面永远不会加载。有什么想法吗?
更新+解决方案
问题最终是 mysql 服务器将自动提交设置为 false。要在应用程序级别覆盖它,将以下行添加到 config/main.php 数据库数组:
'db'=>array(
...
'initSQLs'=>array('SET AUTOCOMMIT=1',),
...
);