С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
 Аватар для sunjan
12 / 7 / 7
Регистрация: 02.04.2014
Сообщений: 342

Вытащить переменную из таблицы mysql

18.12.2015, 08:30. Показов 1202. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
У меня банальный,тупой вопрос:у меня есть база данных words_and_letters в ней таблица words.Пользователь вводит слово и оно ищется в таблице.Потом,по идее должен выводиться url,соответствующий этому слову.У меня соответственно не получается
вот код
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<?php
    session_start();//  вся процедура работает на сессиях. Именно в ней хранятся данные  пользователя, пока он находится на сайте. Очень важно запустить их в  самом начале странички!!!
if (isset($_POST['words'])) { $words = $_POST['words']; if ($words == '') { unset($words);} } //заносим введенный пользователем логин в переменную $words, если он пустой, то уничтожаем переменную
    if (isset($_POST['letters'])) { $letters=$_POST['letters']; if ($letters =='') { unset($letters);} }
    //заносим введенный пользователем пароль в переменную $letters, если он пустой, то уничтожаем переменную
 
  
$db=mysql_connect("localhost","root","1") or die(mysql_error());
mysql_select_db("words_and_letters",$db);// файл db_connect.php должен быть в той же папке, что и все остальные, если это не так, то просто измените путь 
 
$result = mysql_query("SELECT url FROM words"); //извлекаем из базы все данные о пользователе с введенным логином
    $myrow = mysql_fetch_array($result);
    echo $myrow[url];
    
    ?>
подскажите,пожалуйста,как мне лечиться

Добавлено через 1 минуту
Не понятно почему он ругается на url?он же в таблице есть
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.12.2015, 08:30
Ответы с готовыми решениями:

Как вытащить данные из таблицы БД и записать в js-переменную?
Допустим есть следующие файлы: 1) index.php - макет программы; 2) calc.js - скрипт осуществляющий сложение полученных из БД чисел A...

Как вытащить записи таблицы в строковую переменную
Имеется таблица в базе данных Access. Как программно из delphi из этой таблицы вытащить все записи какого-нибудь поля в строковую...

Из таблицы MySQL получить данные и записать их в переменную
Добрый день, Может кто подскажет на примере как реализовать. Есть товары, цены на которые находятся в БД. Делаю калькулятор на странице...

3
9 / 10 / 4
Регистрация: 14.02.2011
Сообщений: 253
18.12.2015, 08:46
попробуй вывести так:
PHP
1
echo $myrow[0];
Это в роде обычный массив....

Добавлено через 10 минут
а лучше сделай :
PHP
1
2
3
echo "<pre>";
print_r($myrow);
echo "</pre>";
И посмотри как там и что храниться
0
 Аватар для sunjan
12 / 7 / 7
Регистрация: 02.04.2014
Сообщений: 342
18.12.2015, 09:03  [ТС]
JohnLemon, попробовал так ничего не выводит.Вообще я вот так код переделал,ошибка исчезла,но браузер ничего не отображает
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<?php
    session_start();//  вся процедура работает на сессиях. Именно в ней хранятся данные  пользователя, пока он находится на сайте. Очень важно запустить их в  самом начале странички!!!
if (isset($_POST['words'])) { $words = $_POST['words']; if ($words == '') { unset($words);} } //заносим введенный пользователем логин в переменную $words, если он пустой, то уничтожаем переменную
    if (isset($_POST['letters'])) { $letters=$_POST['letters']; if ($letters =='') { unset($letters);} }
    //заносим введенный пользователем пароль в переменную $letters, если он пустой, то уничтожаем переменную
 
  
$db=mysql_connect("localhost","root","1") or die(mysql_error());
mysql_select_db("words_and_letters",$db);// файл db_connect.php должен быть в той же папке, что и все остальные, если это не так, то просто измените путь /
$result = mysql_query("SELECT url FROM words WHERE words='words'"); //извлекаем из базы все данные о пользователе с введенным логином
    $myrow = mysql_fetch_array($result,MYSQL_ASSOC);
    echo $myrow["$myrow"];
 
    
    ?>
Добавлено через 2 минуты
Сделал,как вы написали,но все равно ничего не отображается(((

Добавлено через 13 минут
Вот нахлобучил еще сессии.В браузере стала появляться запись"данного слова не существует в нашей библиотеке",хотя на самом деле оно там есть
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
<?php
    session_start();//  вся процедура работает на сессиях. Именно в ней хранятся данные  пользователя, пока он находится на сайте. Очень важно запустить их в  самом начале странички!!!
if (isset($_POST['words'])) { $words = $_POST['words']; if ($words == '') { unset($words);} } //заносим введенный пользователем логин в переменную $words, если он пустой, то уничтожаем переменную
    if (isset($_POST['letters'])) { $letters=$_POST['letters']; if ($letters =='') { unset($letters);} }
    //заносим введенный пользователем пароль в переменную $letters, если он пустой, то уничтожаем переменную
 
  
$db=mysql_connect("localhost","root","1") or die(mysql_error());
mysql_select_db("words_and_letters",$db);// файл db_connect.php должен быть в той же папке, что и все остальные, если это не так, то просто измените путь /
$result = mysql_query("SELECT url FROM words WHERE words='words'"); 
//извлекаем из базы все данные о пользователе с введенным логином
    $myrow = mysql_fetch_array($result,MYSQL_ASSOC);
    /*echo $myrow["$myrow"];*/
    /*echo"<pre>";
    print_r($myrow);
    echo "</pre>";*/
  
    if (empty($myrow['words']))
    {
    //если пользователя с введенным логином не существует
    exit ("Извините, введённого вами слова еще нет в нашей библиотеке.");
    }
    else {
       $_SESSION['words']=$myrow['words'];
       $_SESSION['url']=$myrow['url'];       
    }
    
    ?>
0
162 / 161 / 66
Регистрация: 28.06.2015
Сообщений: 576
18.12.2015, 09:49
Цитата Сообщение от sunjan Посмотреть сообщение
PHP
1
$result = mysql_query("SELECT url FROM words WHERE words='words'");
Вы в курсе что ищите url, в таблице "words" где поле "words" равно "words", т.е. у вас при любых условиях выполняется запрос, который я описал раньше?
Нужно хотя бы так
PHP
1
$result = mysql_query("SELECT url FROM words WHERE words='$words'");
Цитата Сообщение от sunjan Посмотреть сообщение
$myrow = mysql_fetch_array($result,MYSQL_ASSOC);
Вобще mysql уже устарел, и не рекомендуется, но насколько я помню mysql, если вы хотите использовать ассоциативный массив, то есть функция mysql_fetch_assoc вроде, можно посмотреть в мануале

И еще у вас не верно построена архитектура, получается если неверный пароль, поиск по бд будет производиться, и даже если не верный логин, поиск будет производиться, но только будет искаться пустое значение, смысл тогда в проверке?
надо хотя бы так:
PHP
1
2
3
4
5
6
7
8
9
10
11
if(isset($_POST['words']) && isset($_POST['letters'])) { //Проверка на существование переменных
  if(!empty($_POST['words']) && !empty($_POST['letters'])) { //Проверка на то что переменные не пусты
 
    $words = $_POST['words'];
    $letters = $_POST['words'];
//Делаем запрос, поиск и все что вам нужно
  }
}else{
//Ошибка не введен логин или пароль, или введены пустые значения
//Удаление переменных и т.д. все остальные действия
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.12.2015, 09:49
Помогаю со студенческими работами здесь

Не удается вытащить переменную
Добрый день, вернее ночи уже) Что то у меня глюки какие-то в программе. Помогите с игрой. Игра в приложении к теме main.zip. Это гонки,...

Вытащить переменную из функции
Есть вот такая функция: setInterval(function() { var name = '&lt;?= $_GET ?&gt;'; var title = '&lt;?= $_GET ?&gt;'; $.ajax({ ...

Как вытащить переменную из if?
Как вытащить переменную из if? А также из циклов. Например: string A= &quot;loloooLdggd&quot;; int t = A.IndexOf('L'); if(t&gt;0){ int g...

Вытащить число в переменную
Здравствуйте! надо вытащить число в переменную. Возвращает -1, хотя в таблице 1944 записи, в чем ошибка? static void Main(string...

Не могу вытащить переменную из функции
суть: Есть функция добавления элемента в структуру, в неё закидываю этот самый элемент, она его добавляет, теперь мне нужно вытащить этот...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru