Хобрук: Ваш путь к мастерству в программировании

каков правильный синтаксис для вставки в php mysql. W или W/O переменные сеанса

Я пробовал много тестов синтаксиса с одинарными кавычками и переменными $session, теперь я решил поместить переменные сеанса в обычные переменные, чтобы избежать сложностей с синтаксисом.

$conn = mysql_connect($servername, $username, $password);
        // Check connection
        if (!$conn) {
            die("Connection failed: " . mysql_error());
        } 
        if (!mysql_select_db($dbname)) {
            die('Could not select database: ' . mysql_error());
        }


    $this_email = $_SESSION['email'];
    $this_password = $_SESSION['pw'];
    $this_number = $_SESSION['phone'];

    $sql = mysql_query("INSERT INTO user_accounts(Email, Password, Phone#) VALUES ('$this_email','$this_password','$this_number')");
    if (!$sql) {
      echo mysql_error();
    }

    mysql_close($conn);

Это ошибка, которую я получаю:

У вас есть ошибка в синтаксисе SQL; проверьте руководство, соответствующее вашей версии сервера MariaDB, чтобы узнать правильный синтаксис для использования рядом с '' в строке 1

10.03.2016

  • Если вы можете, вероятно, лучше просто использовать имя столбца, которое не обязательно должно быть в обратных кавычках для начала. 10.03.2016
  • stackoverflow.com/questions/4300669/what-does-mean-in-sql 10.03.2016

Ответы:


1

Имена столбцов могут иметь basic Latin letters, digits 0-9, dollar, underscore. Все остальные символы должны быть заключены в обратные кавычки.

http://dev.mysql.com/doc/refman/5.7/en/identifiers.html

поэтому постарайтесь:

INSERT INTO user_accounts(Email, Password, `Phone#`)

Вы также должны обновить свой драйвер и использовать подготовленные операторы.

10.03.2016

2

Поскольку в Phone# есть специальный символ (#), вам нужно написать его обратными кавычками!

Кроме того, я бы порекомендовал вам использовать библиотеку PDO или mysqli, а также подготовленные операторы, потому что библиотека mysql устарела.

10.03.2016
  • Это не проблема только потому, что он не буквенно-цифровой. # на самом деле что-то значит. 10.03.2016
  • Новые материалы

    Основы принципов S.O.L.I.D, Javascript, Git и NoSQL
    каковы принципы S.O.L.I.D? Принципы SOLID призваны помочь разработчикам создавать надежные, удобные в сопровождении приложения. мы видим пять ключевых принципов. Принципы SOLID были разработаны..

    Как настроить Selenium в проекте Angular
    Угловой | Селен Как настроить Selenium в проекте Angular Держите свое приложение Angular и тесты Selenium в одной рабочей области и запускайте их с помощью Mocha. В этой статье мы..

    Аргументы прогрессивного улучшения почти всегда упускают суть
    В наши дни в кругах веб-разработчиков много болтают о Progressive Enhancement — PE, но на самом деле почти все аргументы с обеих сторон упускают самую фундаментальную причину, по которой PE..

    Введение в Джанго Фреймворк
    Схема «работать умно, а не усердно» В этой и последующих статьях я познакомлю вас с тем, что такое фреймворк Django и как создать свое первое приложение с помощью простых и понятных шагов, а..

    Настольный ПК как «одно кольцо, чтобы править всеми» домашних компьютеров
    Вид после 9 месяцев использования С настольных компьютеров все началось, но в какой-то момент они стали «серверами», и мы все перешли на ноутбуки. В прошлом году я столкнулся с идеей настольных..

    Расширенные методы безопасности для VueJS: реализация аутентификации без пароля
    Руководство, которое поможет вам создавать безопасные приложения в долгосрочной перспективе Безопасность приложений часто упускается из виду в процессе разработки, потому что основная..

    стройный-i18следующий
    Представляем стройную оболочку для i18next. Эта библиотека, основанная на i18next, заключает экземпляр i18next в хранилище svelte и отслеживает события i18next, такие как languageChanged,..