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 Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


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

> Описание: нужно при выборе из списка записывать ссылку в базу
ecipuser
Отправлено: 01 Июля, 2009 - 21:05:11
Post Id


Новичок


Покинул форум
Сообщений всего: 15
Дата рег-ции: Май 2009  


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




Нужно, чтобы при заполнении некой формы:
Поле 1 - Загловок страницы
Поле 2 - Выподающий список доступных категорий изображений галерей

CODE (text):
скопировать код в буфер обмена
  1.  
  2.  
  3. $url=$_GET["url"];
  4.  if (!isset($url)){
  5.  echo "<br>Выберите из списка
  6.  
  7.  <select name=name>";
  8.   $query = "SELECT * FROM catalog_galery ORDER BY name";  
  9.   $result = mysql_query($query);
  10.   while($r=mysql_fetch_array($result))
  11.   {
  12.   $id_catalog=$r["id_catalog"];
  13.   $name=$r["name"];
  14.   echo "<option value=$id_catalog selected>$name</option>";
  15.   }
  16.   mysql_close($db);
  17.   echo "</select>
  18.   <input type=submit value=выбрать></form>";
  19.  }
  20.  
  21.  
  22.  


Поле 3 - Текст страницы

Мне нужно при выборе из списка записывать ссылку в базу.

Ссылка вида :
CODE (text):
скопировать код в буфер обмена
  1.  
  2.  
  3. <a hhref="gallery.php?id_catalog=$id_catalog" target="self">$name</a>
  4.  
  5.  


Как это сделать?
Заранее всем благодарен
 
 Top
maxtet
Отправлено: 01 Июля, 2009 - 22:38:13
Post Id



Новичок


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


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




Что у вас передается в переменной $_GET['url']?
 
 Top
ecipuser
Отправлено: 02 Июля, 2009 - 00:36:04
Post Id


Новичок


Покинул форум
Сообщений всего: 15
Дата рег-ции: Май 2009  


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




maxtet пишет:
Что у вас передается в переменной $_GET['url']?


Я так думаю, что в этой переменной должна передаваться сама ссылка для записи в базу. Но как это выполнить не знаю!
 
 Top
JustUserR
Отправлено: 02 Июля, 2009 - 01:56:48
Post Id



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


Покинул форум
Сообщений всего: 8715
Дата рег-ции: Июнь 2009  


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




Вопервых
Цитата:
while($r=mysql_fetch_array($result)) .......
echo "<option value=$id_catalog selected>$name</option>";
Вы уверены что хотите выделять ВСЕ записи полученные из базы (Ибо WHERE в этом запросе я не наблюдаю)
Вовторых где сама форма с передачей данных
И втретьих советую вам обрамлять HTML-атрибуты в кавычки например <option value="123"> чтобы потом не искать еще проблемы (Если вдруг проскочит пробел в значении или еще что)


-----
Сделать можно все что угодно - нужно только старание, терпение и хороший поисковик Улыбка
Безлимитный web-хостинг от 15 рублей за 40 МБ дискового пространства - http://ihost[dot]oks71[dot]ru/
 
 Top
maxtet
Отправлено: 02 Июля, 2009 - 11:36:11
Post Id



Новичок


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


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




ecipuser, в приведенном вами примере отсутствует открывающий тег - <form>, то есть не понятно, передаются данные скрипту или нет.

В этом участке кода



добавьте строку



тогда станет видно, что именно передается в переменной $_GET['url'].
Теперь нам необходимо узнать в каком поле хранятся ссылки, после чего можно сгенерировать структуру ссылки в новом запросе к базе данных.

(Отредактировано автором: 02 Июля, 2009 - 11:37:00)

 
 Top
ecipuser
Отправлено: 03 Июля, 2009 - 02:55:13
Post Id


Новичок


Покинул форум
Сообщений всего: 15
Дата рег-ции: Май 2009  


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




maxtet пишет:
ecipuser, в приведенном вами примере отсутствует открывающий тег - <form>, то есть не понятно, передаются данные скрипту или нет.

В этом участке кода



добавьте строку



тогда станет видно, что именно передается в переменной $_GET['url'].
Теперь нам необходимо узнать в каком поле хранятся ссылки, после чего можно сгенерировать структуру ссылки в новом запросе к базе данных.

Цитата:

при подключеном

выводиться ссылка
вида

принажатии кнопки выбора
передается в базу. С эти вроде разобрался...
Но возник новый вопрос: -
Каким образом вот этот код записать в форму обратываемую классом форм,
проще говоря нужно записать в таком виде:
CODE (text):
скопировать код в буфер обмена
  1.  
  2.  
  3.   //Поле для выбора ссылки на катаолг фотографий       
  4.   $url = new field_select("url",
  5.                            "Ссылка на фотогалерею",
  6.                            /* я так понимаю, сюда нужно вставить код */ ,
  7.                            $_REQUEST['url']);
  8.  
  9.  
  10.  


А вот как это сделать не знаю.
Заранее благодарен
 
 Top
ecipuser
Отправлено: 03 Июля, 2009 - 14:20:05
Post Id


Новичок


Покинул форум
Сообщений всего: 15
Дата рег-ции: Май 2009  


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




ecipuser пишет:
maxtet пишет:
ecipuser, в приведенном вами примере отсутствует открывающий тег - <form>, то есть не понятно, передаются данные скрипту или нет.

В этом участке кода



добавьте строку



тогда станет видно, что именно передается в переменной $_GET['url'].
Теперь нам необходимо узнать в каком поле хранятся ссылки, после чего можно сгенерировать структуру ссылки в новом запросе к базе данных.

Цитата:

при подключеном

выводиться ссылка
вида

принажатии кнопки выбора

передается в базу. С эти вроде разобрался...
Но возник новый вопрос: -
Каким образом вот этот код записать в форму обратываемую классом форм,
проще говоря нужно записать в таком виде:
CODE (text):
скопировать код в буфер обмена
  1.  
  2.  
  3.   //Поле для выбора ссылки на катаолг фотографий       
  4.   $url = new field_select("url",
  5.                            "Ссылка на фотогалерею",
  6.                            /* я так понимаю, сюда нужно вставить код */ ,
  7.                            $_REQUEST['url']);
  8.  
  9.  
  10.  


А вот как это сделать не знаю.
Заранее благодарен

Вроде разобрался, но в выделеной строке
CODE (text):
скопировать код в буфер обмена
  1.  
  2.       $query = "SELECT id_catalog, name FROM catalog_photo ORDER BY name";
  3.       if(!($res = mysql_query($query)))
  4.           throw new ExceptionMySQL(mysql_error(),
  5.                          $query,   "Ошибка извлечения селектора");
  6.       [b]for($opts = array(); $r = mysql_fetch_row($res); $opts[$r[0]]=$r[1];) ;[/b]
  7.       unset($res);
  8.       $url = new field_select("id_catalog", "Наименование списка", $opts, 0);
  9.       unset($opts);  
  10.  

ошибка типа:
CODE (text):
скопировать код в буфер обмена
  1. Parse error: syntax error, unexpected ';', expecting ')'

вроде все логично... а в чем ошибка, понять не могу???


 
 Top
maxtet
Отправлено: 03 Июля, 2009 - 14:41:07
Post Id



Новичок


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


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




Откуда вы взяли такую строку?

CODE (text):
скопировать код в буфер обмена
  1. [b]for($opts = array(); $r = mysql_fetch_row($res); $opts[$r[0]]=$r[1];) ;[/b]

(Отредактировано автором: 03 Июля, 2009 - 14:55:31)

 
 Top
ecipuser
Отправлено: 03 Июля, 2009 - 14:45:38
Post Id


Новичок


Покинул форум
Сообщений всего: 15
Дата рег-ции: Май 2009  


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




maxtet пишет:
Откуда вы взяли такую строку?

CODE (text):
скопировать код в буфер обмена
  1. [b]for($opts = array(); $r = mysql_fetch_row($res); $opts[$r[0]]=$r[1];) ;[/b]


Вы про теги [b][/b] - так это я пытался выделить строку, на которую ругается вэб сервер
 
 Top
maxtet
Отправлено: 03 Июля, 2009 - 14:48:09
Post Id



Новичок


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


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




ecipuser пишет:
maxtet пишет:
Откуда вы взяли такую строку?

CODE (text):
скопировать код в буфер обмена
  1. [b]for($opts = array(); $r = mysql_fetch_row($res); $opts[$r[0]]=$r[1];) ;[/b]


Вы про теги [b][/b] - так это я пытался выделить строку, на которую ругается вэб сервер


Будет ругаться и без тегов поскольку перед и после закрывающихся скобок стоит точка с запятой.

(Отредактировано автором: 03 Июля, 2009 - 14:49:53)

 
 Top
ecipuser
Отправлено: 03 Июля, 2009 - 14:51:02
Post Id


Новичок


Покинул форум
Сообщений всего: 15
Дата рег-ции: Май 2009  


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




maxtet пишет:
ecipuser пишет:
maxtet пишет:
Откуда вы взяли такую строку?

CODE (text):
скопировать код в буфер обмена
  1. [b]for($opts = array(); $r = mysql_fetch_row($res); $opts[$r[0]]=$r[1];) ;[/b]


Вы про теги [b][/b] - так это я пытался выделить строку, на которую ругается вэб сервер


Будет ругаться и без тегов поскольку перед и после закрывающихся скобок стоит точка с запятой.


А как исправить? Я еще слабовато в этом разбираюсь!
или нужно убрать последнюю точку с запятой?

(Отредактировано автором: 03 Июля, 2009 - 14:52:20)

 
 Top
maxtet
Отправлено: 03 Июля, 2009 - 14:54:35
Post Id



Новичок


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


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




перепишите в таком виде
PHP:
скопировать код в буфер обмена
  1. <?PHP
  2. $query = "SELECT id_catalog, name FROM catalog_photo ORDER BY name";
  3. if(!($res = mysql_query($query)))
  4. throw new ExceptionMySQL(mysql_error(),
  5. $query, "Ошибка извлечения селектора");
  6. for($opts = array(); $r = mysql_fetch_row($res); $opts[$r[0]]=$r[1])
  7. unset($res);
  8. $url = new field_select("id_catalog", "Наименование списка", $opts, 0);
  9. unset($opts);  
  10. ?>
 
 Top
ecipuser
Отправлено: 03 Июля, 2009 - 14:59:21
Post Id


Новичок


Покинул форум
Сообщений всего: 15
Дата рег-ции: Май 2009  


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




maxtet пишет:
перепишите в таком виде
PHP:
скопировать код в буфер обмена
  1. <?PHP
  2. $query = "SELECT id_catalog, name FROM catalog_photo ORDER BY name";
  3. if(!($res = mysql_query($query)))
  4. throw new ExceptionMySQL(mysql_error(),
  5. $query, "Ошибка извлечения селектора");
  6. for($opts = array(); $r = mysql_fetch_row($res); $opts[$r[0]]=$r[1])
  7. unset($res);
  8. $url = new field_select("id_catalog", "Наименование списка", $opts, 0);
  9. unset($opts);  
  10. ?>


Спасибо, счас попробую!
(Добавление)
ecipuser пишет:
maxtet пишет:
перепишите в таком виде
PHP:
скопировать код в буфер обмена
  1. <?PHP
  2. $query = "SELECT id_catalog, name FROM catalog_photo ORDER BY name";
  3. if(!($res = mysql_query($query)))
  4. throw new ExceptionMySQL(mysql_error(),
  5. $query, "Ошибка извлечения селектора");
  6. for($opts = array(); $r = mysql_fetch_row($res); $opts[$r[0]]=$r[1])
  7. unset($res);
  8. $url = new field_select("id_catalog", "Наименование списка", $opts, 0);
  9. unset($opts);  
  10. ?>


Спасибо, счас попробую!

Эта ошибка исправилась, но появилась ошибка вот такого рода:
CODE (text):
скопировать код в буфер обмена
  1.  
  2. Fatal error: Uncaught exception 'ExceptionMySQL' with message 'Ошибка извлечения селектора' in ..../catadd.php:30 Stack trace: #0 {main} thrown in ....
  3.  

А это то из за чего?
То что это оибка мускуля - это и так понятно...
Почему она появилась?

(Отредактировано автором: 03 Июля, 2009 - 15:58:17)

 
 Top
JustUserR
Отправлено: 03 Июля, 2009 - 17:09:46
Post Id



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


Покинул форум
Сообщений всего: 8715
Дата рег-ции: Июнь 2009  


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




Ужас зачем использовать throw? И new field_select как экзмеляр класса? Не люблю я такой сильно ООП-подход


-----
Сделать можно все что угодно - нужно только старание, терпение и хороший поисковик Улыбка
Безлимитный web-хостинг от 15 рублей за 40 МБ дискового пространства - http://ihost[dot]oks71[dot]ru/
 
 Top
ecipuser
Отправлено: 03 Июля, 2009 - 17:29:52
Post Id


Новичок


Покинул форум
Сообщений всего: 15
Дата рег-ции: Май 2009  


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




JustUserR пишет:
Ужас зачем использовать throw? И new field_select как экзмеляр класса? Не люблю я такой сильно ООП-подход


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


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB