我正在为 SessionHandlerInterface 类 使用以下写入方法:
public function write($session_id, $session_data) {
$sth = DBCxn::get()->prepare("UPDATE sessions SET session_data = ?, last_update = NOW() WHERE session_id = ?");
$sth->execute(array($session_data, $session_id));
if ($sth->rowCount() == 0) {
$sth = DBCxn::get()->prepare("INSERT INTO sessions (session_id, session_data, last_update) VALUES (?, ?, NOW())");
$sth->execute(array($session_id, $session_data));
}
问题在于,如果更新查询的session_data
没有改变,rowCount()
会返回0,反过来函数会尝试插入一个 session_id
已经存在并返回错误。
我想做一个选择查询来验证 session_id
是否存在的解决方案。
还有哪些替代方法可以用来解决这个问题?
最佳答案
read()
在 write()
之前调用(在 session 开始时),您将有一个 SELECT
查询在那里。
因此,您已经知道是否应该执行 INSERT
或 UPDATE
- 只需使用一个属性作为“行存在”标志,这是您从内部设置的read()
,您稍后可以在 write()
中检查它。
关于php - SessionHandlerInterface 写方法替代方案,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35158792/