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

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Поиск совпадений по базе данных и самый простейший вывод информации

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


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

> Без описания
Crowley
Отправлено: 03 Февраля, 2014 - 12:38:26
Post Id


Гость


Покинул форум
Сообщений всего: 67
Дата рег-ции: Янв. 2014  


Помог: 0 раз(а)




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

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

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



Участник


Покинул форум
Сообщений всего: 1472
Дата рег-ции: Сент. 2012  
Откуда: Запорожье, Украина


Помог: 19 раз(а)




Простейший запрос

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


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

(Отредактировано автором: 03 Февраля, 2014 - 13:01:04)



-----
PHP:
скопировать код в буфер обмена
  1. do {box != cat;} while (cat != box);


Когда нормальный человек, уезжая из дома одевает на жену пояс верности, веб-дизайнер ставит на нее счетчик...
 
My status
 Top
Crowley
Отправлено: 03 Февраля, 2014 - 15:15:11
Post Id


Гость


Покинул форум
Сообщений всего: 67
Дата рег-ции: Янв. 2014  


Помог: 0 раз(а)




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. }

А дальше? А дальше не понятно...(Хоть этот-то код верный?)

(Отредактировано автором: 03 Февраля, 2014 - 15:23:04)

 
 Top
IllusionMH
Отправлено: 03 Февраля, 2014 - 15:24:32
Post Id



Активный участник


Покинул форум
Сообщений всего: 4254
Дата рег-ции: Февр. 2011  
Откуда: .kh.ua


Помог: 242 раз(а)




Crowley, ну так если не в курсе что делать, то сначала почитать что делает функция mysql_query (рассмотреть примеры), потом посмотреть функции из списка См. также (конкретно mysql_fetch_array (внимательно рассмотреть примеры)).
 
 Top
Crowley
Отправлено: 03 Февраля, 2014 - 15:58:54
Post Id


Гость


Покинул форум
Сообщений всего: 67
Дата рег-ции: Янв. 2014  


Помог: 0 раз(а)




IllusionMH пишет:
Crowley, ну так если не в курсе что делать, то сначала почитать что делает функция mysql_query (рассмотреть примеры), потом посмотреть функции из списка См. также (конкретно mysql_fetch_array (внимательно рассмотреть примеры)).

Я все это читал, и не раз(под редакцией разных авторов), но дело в том, что ждать и учится, чтобы написать это самому - я не могу, работа нужна сегодня, до 00:00, поэтому я создал тему в разделе(НАПОМИНАЮ!) "Напишите за меня, пожалуйста"(А не "Дайте совет, я буду пробовать еще ~месяц, пока у меня не получится и не выйдут все сроки")

(Отредактировано автором: 03 Февраля, 2014 - 15:59:27)

 
 Top
imya
Отправлено: 03 Февраля, 2014 - 16:43:19
Post Id



Участник


Покинул форум
Сообщений всего: 1472
Дата рег-ции: Сент. 2012  
Откуда: Запорожье, Украина


Помог: 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: только при таком коде, оно столько раз выведет сообщение, сколько записей найдет. Проще выбирать найденные в массив и вне цикла вывод делать.

(Отредактировано автором: 03 Февраля, 2014 - 16:50:28)



-----
PHP:
скопировать код в буфер обмена
  1. do {box != cat;} while (cat != box);


Когда нормальный человек, уезжая из дома одевает на жену пояс верности, веб-дизайнер ставит на нее счетчик...
 
My status
 Top
Crowley
Отправлено: 03 Февраля, 2014 - 16:57:46
Post Id


Гость


Покинул форум
Сообщений всего: 67
Дата рег-ции: Янв. 2014  


Помог: 0 раз(а)




imya пишет:
Так а что вам нужно-то? чтобы, если email был найден в базе - он вывелся на экран ??

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

Грубо говоря, если одна и та же почта будет встречаться в базе 2 раза(например), он 2 раза напишет "Mail $mail is founded"?

(Отредактировано автором: 03 Февраля, 2014 - 16:59:30)

 
 Top
imya
Отправлено: 03 Февраля, 2014 - 17:37:35
Post Id



Участник


Покинул форум
Сообщений всего: 1472
Дата рег-ции: Сент. 2012  
Откуда: Запорожье, Украина


Помог: 19 раз(а)




Crowley пишет:
он 2 раза напишет "Mail $mail is founded"?

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

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


-----
PHP:
скопировать код в буфер обмена
  1. do {box != cat;} while (cat != box);


Когда нормальный человек, уезжая из дома одевает на жену пояс верности, веб-дизайнер ставит на нее счетчик...
 
My status
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Напишите за меня, пожалуйста »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB