如果我在edit_profile()没有任何参数的情况下运行我的函数,那么空字符串将写入DB.$input['email']例如,如果为空,我不想UPDATE更新此列.
我试着这样做:
SET email = IF(LENGTH(:email)=0, email, :email),
Run Code Online (Sandbox Code Playgroud)
它不起作用,我不知道如何使用PDO如上所述.
function edit_profile($input) {
//
$user_id = 1;
//
try {
//
$conn = new PDO('mysql:host='.DB_HOST.';dbname='.DB_NAME, DB_USERNAME, DB_PASSWORD);
$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$stmt = $conn->prepare('UPDATE users SET
email = :email,
password = :password,
name_surname = :name_surname,
age = :age,
sex = :sex,
education = :education,
avatar = :avatar
WHERE id = :id');
$stmt->execute(array(
':id' => $user_id,
':email' => $input['email'],
':password' => $input['password'],
':name_surname' => $input['name_surname'],
':age' => $input['age'],
':sex' => $input['sex'],
':education' => $input['education'],
':avatar' => $input['avatar']
));
echo $stmt->rowCount(); // 1
//
} catch(PDOException $e) {
echo 'ERROR: ' . $e->getMessage();
}
//
}
edit_profile();
Run Code Online (Sandbox Code Playgroud)
尝试
UPDATE users SET
email = COALESCE(NULLIF(:email, ''),email),
password = :password,
name_surname = :name_surname,
age = :age,
sex = :sex,
education = :education,
avatar = :avatar
WHERE id = :id
Run Code Online (Sandbox Code Playgroud)
我基本上试图使用COALESCE(http://dev.mysql.com/doc/refman/5.0/en/comparison-operators.html#function_coalesce):email仅在不为null时使用.如果它为null,请使用旧的email.
如果:email是空字符串而不是简单的NULL,我已添加NULLIF将空字符串转换为NULL;)
| 归档时间: |
|
| 查看次数: |
1386 次 |
| 最近记录: |