Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: Поиск совпадений по базе данных и самый простейший вывод информации
Форумы портала PHP.SU » PHP » Напишите за меня, пожалуйста » Поиск совпадений по базе данных и самый простейший вывод информации

Страниц (1): [1]
 

1. Crowley - 03 Февраля, 2014 - 12:38:26 - перейти к сообщению
Нужно осуществить поиск по базе данных 1 значения($mail), которое будет приходить post запросом, с последующим выводом.
Пример :
$mail = "123@mail.ru:456";
Если в базе данных есть значение $mail, то вывести его вот так :
echo "$mail - Есть совпадение";
Если совпадения нету, то так :
echo "$mail - Совпадения нету";

База данных размером в 41 миллион строк.

Буду безмерно благодарен, если кто-то с этим поможет(Желательно с комментариями, т.к. работать с базами не умею пока, и учусь на практике. Пока ничего не выходит... )
2. imya - 03 Февраля, 2014 - 13:00:15 - перейти к сообщению
Простейший запрос

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT * FROM `your_table` AS t WHERE `t.mail` = {$mail} ORDER BY `id` ASC


На словах звучит так:
Хочу выбрать все строки из таблицы your_table , так чтобы поле mail было равно тому mail, который я введу в поле.
3. Crowley - 03 Февраля, 2014 - 15:15:11 - перейти к сообщению
imya пишет:
Простейший запрос

CODE (SQL):
скопировать код в буфер обмена
SELECT * FROM `your_table` AS t WHERE `t.mail` = {$mail} ORDER BY `id` ASC


На словах звучит так:
Хочу выбрать все строки из таблицы your_table , так чтобы поле mail было равно тому mail, который я введу в поле.

Так это-то понятно, но куда вставлять этот код, который ты дал? Как мне из PHP обратится к sql базе, и что передать туда?
Я создал тему здесь по тому, что мало понимаю что к чему(я неплохо знаю функции и синтаксис php, но с сервером работать практически не умею(только учусь)), а дело это - очень срочное.

Допустим, я понял основу.
PHP:
скопировать код в буфер обмена
  1. $mail = $_POST['mail'];
  2. $server = "servername";
  3. $user = "login";
  4. $password = "pass";
  5. $db = "mails";
  6. if (!mysql_connect($server, $user, $password))
  7. {
  8. echo "Ошибка подключения к серверу MySQL";
  9. }
  10. else
  11. {
  12. $q = mysql_query("SELECT * FROM `your_table` AS t WHERE `t.mail` = {$mail} ORDER BY `id` ASC");
  13. }

А дальше? А дальше не понятно...(Хоть этот-то код верный?)
4. IllusionMH - 03 Февраля, 2014 - 15:24:32 - перейти к сообщению
Crowley, ну так если не в курсе что делать, то сначала почитать что делает функция mysql_query (рассмотреть примеры), потом посмотреть функции из списка См. также (конкретно mysql_fetch_array (внимательно рассмотреть примеры)).
5. Crowley - 03 Февраля, 2014 - 15:58:54 - перейти к сообщению
IllusionMH пишет:
Crowley, ну так если не в курсе что делать, то сначала почитать что делает функция mysql_query (рассмотреть примеры), потом посмотреть функции из списка См. также (конкретно mysql_fetch_array (внимательно рассмотреть примеры)).

Я все это читал, и не раз(под редакцией разных авторов), но дело в том, что ждать и учится, чтобы написать это самому - я не могу, работа нужна сегодня, до 00:00, поэтому я создал тему в разделе(НАПОМИНАЮ!) "Напишите за меня, пожалуйста"(А не "Дайте совет, я буду пробовать еще ~месяц, пока у меня не получится и не выйдут все сроки")
6. imya - 03 Февраля, 2014 - 16:43:19 - перейти к сообщению
Так а что вам нужно-то? чтобы, если email был найден в базе - он вывелся на экран ??

PHP:
скопировать код в буфер обмена
  1.  
  2. $query = mysql_query("SELECT * FROM `your_table` AS t WHERE `t.mail` = {$mail} ORDER BY `id` ASC");
  3. while($sql_res = mysql_fetch_array($query))
  4. {
  5.     if($mail == $sql_res['mail'])
  6.         echo "Mail $mail is founded";
  7.     else
  8.         echo "Oops";
  9. }
  10.  


your_table соответственно, смените на название вашей таблицы


upd: только при таком коде, оно столько раз выведет сообщение, сколько записей найдет. Проще выбирать найденные в массив и вне цикла вывод делать.
7. Crowley - 03 Февраля, 2014 - 16:57:46 - перейти к сообщению
imya пишет:
Так а что вам нужно-то? чтобы, если email был найден в базе - он вывелся на экран ??

Да.
Спасибо, буду тестировать.
P.S. В базе данных ничего изменять не нужно будет? Просто подгрузить туда почты и проиндексировать строки?
imya пишет:
upd: только при таком коде, оно столько раз выведет сообщение, сколько записей найдет. Проще выбирать найденные в массив и вне цикла вывод делать.

Грубо говоря, если одна и та же почта будет встречаться в базе 2 раза(например), он 2 раза напишет "Mail $mail is founded"?
8. imya - 03 Февраля, 2014 - 17:37:35 - перейти к сообщению
Crowley пишет:
он 2 раза напишет "Mail $mail is founded"?

Угадали.
Crowley пишет:
В базе данных ничего изменять не нужно будет?

А зачем там что-то менять?
Или у вас пустая база ? Тогда импортните дамп(если есть конечно) и выполняйте поиск.

 

Powered by ExBB FM 1.0 RC1