При добавлении информации в mysql вы должны учитывать символы, используемые mysql и PHP, и обращаться к ним, так как они могут привести к сбою кода, и даже позволить людям вставлять / выполнять код на вашем сайте. Простейший метод, который я использовал, - заставить PHP «экранировать» символы, чтобы они могли правильно вставляться в mysql следующим образом:
$email = "This isn't my first time 'round here";
Это должно вставить отлично, как есть, но давайте предположим, что ваш SQL выглядит так:
$query = "INSERT INTO table (timestamp,email) VALUES (time(),'$email')";
одинарные кавычки в запросе MySQL будут заштрихованы одинарными кавычками в ваших данных. Чтобы избежать этого, установите переменную вашей электронной почты для экранирования:
$email = "This isn't my first time 'round here";
$email = mysql_escape_string($email);
Недостатком использования этого является то, что теперь в вашей базе данных есть дополнительные escape-символы (обычно обратная косая черта "/") в ваших данных, поэтому, когда вы захотите использовать их из базы данных, вам придется удалить их, а у PHP есть удобный Функция только для этого:
$query = "SELECT * FROM table WHERE id='the id you want'";
$result = mysql_query($query) or die(mysql_error());
while ($data = mysql_fetch_array($result)) {
$email = stripslashes($data['email']);
}
echo "This is your email text from the database: <br>\n".$email."<br>\n";
Надеюсь, это поможет прояснить одно возможное решение (если это действительно то, почему электронное письмо не вставляется в базу данных, как ожидалось).