PHP Создание списка переменных из базы данных Mysql

У меня есть база данных, которая использует 3 языка следующим образом:

id  name    de_de   al_sq
1   title   titel   titulli
2   points  punkte  pike

Теперь, когда в php для $lang установлено значение «al_sq»:

$lang = 'al_sq';

Я пытаюсь сгенерировать переменные, используя имена этого языка, в этом случае:

$langtitle = 'titulli';
$langpoints = 'pike';

Попытка что-то вроде:

$sql = "SELECT * FROM `langs`";
$result = $conn->query($sql);
if ($result->num_rows > 0) {
  while($row = $result->fetch_assoc()) {
    $lang{$row["lang"]} = $row[$lang];
  }
}

но что-то не хорошо, как генерировать эти переменные?

У вас есть непарная фигурная скобка после $lang в 5-й строке.

dmikester1 14.03.2019 17:35

Что происходит, когда вы используете код, который вы разместили?

Dave 14.03.2019 17:36

Если вы попытаетесь развернуть свою собственную систему локализации таким образом, у вас будут очень плохие времена. Используйте что-то вроде Получить текст и избавьте себя от многих проблем в будущем.

Sammitch 14.03.2019 17:38

@Sammitch - однако у Gettext есть определенные ограничения; вы не можете иметь дело с лингвистическими нюансами в очень сортированных строках, например, под "спасти" вы имеете в виду "регистратор" (кнопка в форме) или "эконом" (сэкономьте 10%)... и вам нужно перезагружать Apache каждый раз, когда вы меняете .po файлы - это если вы даже можете заставить его работать, если вы разрабатываете на коробке Windows.

CD001 14.03.2019 17:55

Вы можете попробовать сопоставить { с }

RiggsFolly 14.03.2019 17:55

@ CD001 CD001 да, есть крайние случаи и предостережения для Gettext, но у меня была локализация, реализованная разработчиком, такая как OP, которая мгновенно превзошла базу данных при выпуске. Уровень взаимодействия с серверным хранилищем, необходимый для такой локализации, растет в геометрической прогрессии и полностью уничтожит вас с накладными расходами. Не стесняйтесь предлагать альтернативу Gettext, но я однозначно рекомендую против всем, кто занимается локализацией хранилища в mysql или любой другой СУБД.

Sammitch 14.03.2019 18:04

@Sammitch - как ни странно, у меня было смутное воспоминание, что я ответил на такой вопрос некоторое время назад - оказывается это было 6 лет назад!. Не сильно изменилось, теперь я бы, вероятно, использовал статический класс перевода для коротких строк (например, из массива button_save => "enregistrer") и базу данных для больших фрагментов текста (например, HTML из CMS); не так эффективен, как Gettext, но гораздо проще в управлении, особенно при разработке для Windows.

CD001 15.03.2019 10:18
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
7
66
3
Перейти к ответу Данный вопрос помечен как решенный

Ответы 3

Кажется, вы используете базу данных как хранилище ключей и значений с несколькими полями значений в зависимости от языка, вы можете использовать PDO::FETCH_KEY_PAIR, чтобы он возвращал массив с именем в качестве ключа. Таким образом вы также избегаете загрузки данных для других языков, которые вам могут вообще не понадобиться:

    $query = "SELECT `name`, :column as value FROM `langs`";
    $statement = $pdo->prepare($query);
    $statement->execute(["column"  => $lang]);
    $data = $statement->fetchAll(\PDO::FETCH_KEY_PAIR);

    // $data becomes an array with the name as the key:
    $langtitle = $data['title'];
    $langpoints = $data['points'];

Если пользователь указывает значение для $lang, убедитесь, что это допустимое значение столбца.

Используя этот код, автор должен изменить $conn, чтобы он был экземпляром PDO, а не mysqli (как в его фрагменте).

Kalle 14.03.2019 18:05

Это должно быть близко к тому, что вы хотите, исходя из того, как представлена ​​ваша база данных. Масштабирование было бы неуклюжим, если бы было сохранено больше титулов и очков.

$lang = 'al_sq';
$sql = "SELECT $lang FROM 'langs'";
$result = $conn->query($sql);
if ($result->num_rows > 0) {
 while($row = $result->fetch_assoc()) {
 $langtitle = $row[1];
 $langpoints = $row[2];
 }
}
Ответ принят как подходящий

В вашем коде есть незначительная синтаксическая ошибка, которая вызывает ошибку. Что вам нужно сделать здесь, это:

  1. Извлеките столбцы name и al_sq из таблицы базы данных. Это делается путем выбора значения $lang (на основе вашего кода). Из соображений безопасности значение $lang защищено от SQL-инъекций, так как вы не указали, откуда было получено значение.

  2. Затем вы должны проверить, были ли какие-либо результаты, и в случае их отсутствия он просто завершит выполнение скрипта с ошибкой.

  3. Затем, наконец, вы должны выполнить итерацию по каждой строке возвращаемых результатов и выполнить присвоение переменной переменной. Это заставит работать $langpoints и т. д. (и любые другие, которые вы можете добавить в будущем).

Код:

$sql = 'SELECT `name`, `' . $conn->real_escape_string($lang) . '` FROM `langs`';

$result = $conn->query($sql);

if (!$result || !$result->num_rows) {
  echo 'Invalid language selected';
  exit;
}

while ($phrase = $result->fetch_assoc()) {
  ${'lang' . $phrase['name']} = $phrase[$lang];
}

// $langtitle
// $langpoints

Да, вы поняли, что я хочу, но если вы можете проверить еще раз, он показывает эту ошибку: Неустранимая ошибка: Непойманная ошибка: Вызов неопределенного метода mysqli_result::fetchAssoc() в /srv/users/serverpilot/apps/testapp/public/lang. php:24 Трассировка стека: #0 {main} добавлено в /srv/users/serverpilot/apps/testapp/public/lang.php в строке 24

AlbaStar 15.03.2019 08:16

Основываясь на вашем коде, я изменил свой код на: ${'lang' . $строка['имя']} = $строка[$язык]; и теперь работает, спасибо.

AlbaStar 15.03.2019 08:57

@AlbaStar У меня была небольшая опечатка (fetchAssoc() должна была быть fetch_assoc()), рад, что у вас все заработало \o/

Kalle 15.03.2019 10:27

Другие вопросы по теме