Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP 5/6. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. MySQL 5. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум PHP

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Цикл не отображает элементы массива
 
 автор: provizorokl   (04.08.2011 в 22:42)   письмо автору
53.7 Кб
 
 

Долго Гуглил и попал сюда. Проблема... Есть файл пхп в котором перечень категорий и из него методом ГЕТ передается переменная
<?php 
$bada 
mysql_connect("localhost","neofrontuser","152634");
mysql_select_db("neofront"$bada);
$result3 mysql_query("SELECT * FROM categorias ORDER BY title"$bada);
$mifila3 mysql_fetch_array($result3);
         do 
        {
printf ("| <a class='catlink' href='ex2.php?bid=%s'>%s</a> |",$mifila3["bid"],$mifila3["title"]);}
        while (
$mifila3 mysql_fetch_array($result3));
?>

(она же создается запросом к таблице базы даных) - (первая таблица на рисунке)

, которую проверяет на наличие запросом к другой таблице (вторая таблица на рисунке) Базы даных другой файл.
<?php 
$bada 
mysql_connect("localhost","neofrontuser","152634");
mysql_select_db("neofront"$bada);
if (!empty(
$_GET['bid'])) $bid   $_GET['bid'];
 
$result2 mysql_query("SELECT id, cat, title, m_key, text, imagen_median FROM articulos WHERE MATCH(cat) AGAINST('$bid') ORDER BY fecha LIMIT 10"$bada);
 
$mifila2 mysql_fetch_array($result2);
        do
        {
printf("%s"$mifila2["title"]);}
        while (
$mifila2 mysql_fetch_array($result2))

?>


И теперь проблема. Как результат выводит даные в нужном мне списке, НО.. если вторая таблица содержит больше, чем 2 результата для вывода, то цикл ничего не выводит. Тоесть, выводятся статьи со значением переменной (bbb2, bbb3, bbb6). bbb1 - НЕ ВЫВОДИТ НИЧЕГО. Если, же я из второй таблицы удалю bbb1 и оставлю только в двух строках, то это значения переменной (соответствующие ей статьи) выводятся без проблем. Прошу извинить и помочь.

  Ответить  
 
 автор: Valick   (04.08.2011 в 22:55)   письмо автору
 
   для: provizorokl   (04.08.2011 в 22:42)
 

это хорошо что вы попали сюда, только несколько непонятно выражаетесь
в принципе это не удивительно Е.Попов ничему хорошему не научит :)
1) (пишу в 1257 раз) цикл do{}while тут не уместен лучше его заменить на while{}
2) 5 раз прочитал ваш текст, и так и не понял кто куда кого не выводит)
___
щас прочитаю еще раз 20 может разберусь))

  Ответить  
 
 автор: provizorokl   (04.08.2011 в 23:07)   письмо автору
 
   для: Valick   (04.08.2011 в 22:55)
 

Скрипт не выводит в браузере...)))

do{}while я менял на while{}

Эффект идентичен.. Сейчас еще раз попробую..

  Ответить  
 
 автор: Valick   (04.08.2011 в 23:08)   письмо автору
 
   для: provizorokl   (04.08.2011 в 23:07)
 

он ничего и не изменит тут, он сыграет злую шутку при пустой выборке

  Ответить  
 
 автор: Valick   (04.08.2011 в 23:02)   письмо автору
 
   для: provizorokl   (04.08.2011 в 22:42)
 

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

  Ответить  
 
 автор: provizorokl   (04.08.2011 в 23:09)   письмо автору
 
   для: Valick   (04.08.2011 в 23:02)
 

Да, но запрос у меня идет через MATCH AGAINST.. Да и находит, но не больше двух.

  Ответить  
 
 автор: provizorokl   (04.08.2011 в 23:11)   письмо автору
 
   для: Valick   (04.08.2011 в 23:02)
 

Мне здесь только этот тип запроса подошел с моими знаниями и нуждами... Поэтому и создал поля под него.

  Ответить  
 
 автор: Valick   (04.08.2011 в 23:20)   письмо автору
 
   для: provizorokl   (04.08.2011 в 23:11)
 

ничего страшного, изменим и знания и нужды ))

  Ответить  
 
 автор: provizorokl   (04.08.2011 в 23:30)   письмо автору
 
   для: Valick   (04.08.2011 в 23:20)
 

Насчет таблицы связей попробую составить и реализовать (пока только слышал об этом). Почитаю, составлю и отпишусь..
Хотя мне кажется, что здесь, в моем случае, собака в другом зарыта. Все-таки что-то, да выводит... Но это чисто интуитивное мнение.. За сложность предложений, извиняюсь (тут не Попов виной), но мне сейчас 80% времени приходится, общатся на испанском (там построение предложений чуть другое), а родной украинский.

  Ответить  
 
 автор: Valick   (04.08.2011 в 23:52)   письмо автору
 
   для: provizorokl   (04.08.2011 в 23:30)
 

в моем случае, собака в другом зарыта
и эту собаку (более одного значения в поле) не стоит "откапывать"))

  Ответить  
 
 автор: provizorokl   (05.08.2011 в 00:01)   письмо автору
 
   для: Valick   (04.08.2011 в 23:02)
 

Вот еще интерессный факт. После реализации (той неверной) скрипта на странице больше ничего не выводится. Точнее все, что идет на страничке ниже скрипта в html-коде не выводится. Тоесть ламается полностью страница внизу (футер и т. д.)

  Ответить  
 
 автор: Valick   (05.08.2011 в 00:14)   письмо автору
 
   для: provizorokl   (05.08.2011 в 00:01)
 

значит критическая ошибка какая-то, а отображение ошибок скорее всего отключено
___
погуглите на предмет нормализации таблиц и нормализации баз данных
и почитайте в каких случаях нужна денормализация
после этого гораздо легче сможете проектировать БД
а это 70% успеха, остальные 30% это код

  Ответить  
 
 автор: provizorokl   (05.08.2011 в 01:02)   письмо автору
 
   для: Valick   (05.08.2011 в 00:14)
 

Подозреваю, что это то, что нужно. СПАСИБО. Придется половину работы перекроивать, ну что поделать....(. Ученье - свет.

PS Впервые форум помог, а не Гугл. (Хотя впервые обращаюсь). Пока думаю, что помог.))) Еще раз благодарю, за терпение.

  Ответить  
 
 автор: Valick   (05.08.2011 в 07:46)   письмо автору
 
   для: provizorokl   (05.08.2011 в 01:02)
 

вот посмотрите тему
там по-моему как раз таблица связи засветилась (в конце темы)
на самом деле перекраивать в большинстве случаев не так много как кажется, а при правильной организации и вовсе очень легко вносить изменения

  Ответить  
 
 автор: provizorokl   (05.08.2011 в 21:24)   письмо автору
 
   для: Valick   (05.08.2011 в 07:46)
 

Да, там последний скрипт, то что мне, нужно. Пока не просматривал, только тему прочитал. Я знал о существовании JOIN, но как-то не приходилось использовать, поэтому и не знал применение. Свою работу, пока откладываю. Придется читать "недоделки" Попова, чтобы как то перестраховатся в будущем. Спасибо, что "взяли за руку" и привели к тому, что надо.

  Ответить  
 
 автор: provizorokl   (08.08.2011 в 02:11)   письмо автору
 
   для: Valick   (05.08.2011 в 00:14)
 

Проблема решилась использованием LIKE вместо MATCH ... AGAINST. Там bbb1 тупо набирает 50%-й порог и MySQL считает его словом-мусором с нулевой ценностью и его нет в выборке.

  Ответить  
 
 автор: provizorokl   (06.08.2011 в 20:15)   письмо автору
 
   для: Valick   (04.08.2011 в 23:02)
 

Я опять вернусь, к это же проблеме.. А дело вот в чем. Я пробовал менять поле bid с типа varchar на тип text (хотя здесь это не так важно), потом первый скрипт переделывал на форму поиска и передавал переменную методом ПОСТ. Тоже самое в результате. Тоесть, если я попробую создать поиск на страничке, он не будет работать. Я плотно читал о недочетах Попова и пытался их учитывать в коде, но еще хуже. Вообще нету никакого вывода иформации. Чет сомнения у меня на счет конструктивности критики Попова... А мне будет нужным поиск на сайте....

  Ответить  
 
 автор: Valick   (06.08.2011 в 21:04)   письмо автору
 
   для: provizorokl   (06.08.2011 в 20:15)
 

оставьте вопрос о конструктивности на года через два :) потом все станет ясно.
тоже самое сделайте и с интернетом... он вам в данном вопросе не помощник
если действительно хотите чему то научиться, то купите книгу, а если серьезно настроены на изучение языка то одной книгой дело не обойдется (лично у меня по РНР и MySQL около 15-ти книг)
___
напишите подробно техническое задание того что вы хотите сделать, и я постараюсь вам помочь с "фундаментом"

  Ответить  
 
 автор: provizorokl   (07.08.2011 в 00:33)   письмо автору
 
   для: Valick   (06.08.2011 в 21:04)
 

Я по ходу знаю то, что хочу реализовать. И оно неплохо получается (как на меня). Вы мне очень помогли, насчет, создания таблиц связей. Оно наверно и лучше в будущем, если количество страниц на сайте превысит 1000 и больше. Я пока их не создавал, но думаю вопросов не возникнет. Я пока новичек, и пока интересуюсь всем понемногу, что касается сайтостроения. Как говорят капля не силой долбит, а частотой падения. Поэтому скоро определюсь, что глубже изучать.. СЕО-оптимизацию или ПХП...и т.д. Просто на самом деле же, я хочу избежать проблемы на сайте с созданием поиска... При его реализации используются MATCH и AGAINST. Еще есть LIKE. Потом почитаю разницу. Если не получится, буду обращатся. Хотя просто "зудит" где-то внутри, - "А почему этот не работает". Знаете, оставив одне непонятку, на нее наслаивается другая и ... и в результате вечно на форумах сидеть с глупыми вопросами. Нет уж, увольте. Пока, спасибо, и буду продолжать работать над собой.
PS. А, если честно, то боюсь, что что-то упущу при создании защиты сайта...) Вот здесь точно буду благодарен, если сбросите ссылку на нормалный ресурс с описанием и обьяснением(обязательно) защитных механизмов сайтов. Гуглить не считаю правильным, там кто с СЕО лучше дружит, тот и выше. И еще страницу на указание помарок Попова. А то каждый пишет свое)).
Так и тема поменялась.. Извините. И еще раз благодарю

  Ответить  
 
 автор: Valick   (07.08.2011 в 07:35)   письмо автору
 
   для: provizorokl   (07.08.2011 в 00:33)
 

вы пропустили мимо ушей самое главное - книга
и опять просите от меня ссылки на какие-то ресурсы
года полтора назад я ввел для себя понятие "зомбикодер" - последователь учения Попова, и "франкенсайт" - это результат учения Попова. Более того неважно Попов это или еще кто-то, просто увидев названия "Сайт за 5 минут", "Сайт - это легко" и тд. бегите от этих ресурсов и этих книг.
Как раз на желании сделать все легко и быстро Попов сделал себе денег, чему-то научить купившему видео курс не входило в его планы. Он дал готовый код (готовых бесплатных CMS в интернете полно, причем на порядок лучше Попова), но преподнес это так как будто вы сами пишите сайт. Поверьте вы не первый и не последний кто приходит на этот форум с подобного рода проблемами (проблема одна - отсутствие базовых знаний) именно "от Попова".
Вы думаете я ярый противник Попова? Это не совсем так, более того он мне нравиться как бизнесмен сумевший сделать деньги по сути из воздуха.
__
вот некоторые размышления о видеокурсах от Николай2357

  Ответить  
 
 автор: provizorokl   (08.08.2011 в 02:13)   письмо автору
 
   для: Valick   (07.08.2011 в 07:35)
 

Проблема решилась использованием LIKE вместо MATCH ... AGAINST. Там bbb1 тупо набирает 50%-й порог и MySQL считает его словом-мусором с нулевой ценностью и его нет в выборке.

  Ответить  
 
 автор: Valick   (08.08.2011 в 07:50)   письмо автору
 
   для: provizorokl   (08.08.2011 в 02:13)
 

проблемы у вас еще даже не начинались
вы сейчас строите дом на кривом фундаменте
первый, второй, третий этажи еще ничего, а дальше начнутся проблемы
и этаже на шестом будете выбирать либо сносить все здание и делать нормальный фундамент, либо все пипец приплыли
за сим оставляю свое нудное повествование, по видимому вам самому нужно хорошенько наступить на грабли и чужие синяки вас не интересуют
а ваше решение в простонародье называется "костыль" и только от вас зависит "побежите" вы или так и будете ковылять "на костылях"

  Ответить  
 
 автор: cheops   (07.08.2011 в 10:07)   письмо автору
 
   для: provizorokl   (07.08.2011 в 00:33)
 

Лучше под разные вопросы заводить разные темы - так будет проще разобрать проблему, да и искать и ссылаться на темы потом проще. Кроме того, собственные темы всегда можно быстро найти через список "Мои темы" форума.

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования