Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
 Аватар для Rurr
23 / 23 / 11
Регистрация: 12.01.2013
Сообщений: 223

Обращение к БД в своей функции

05.01.2014, 19:38. Показов 1593. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
здраствуйте

самописная функция выводит немного хтмл кода и должна заполнить <select> виборкой из базы данных никак не хочет работать по отдельности все норм но внутри функции запрос к бд не выполняется. подскажите мож так вообще нельзяделать или надо использовать дополнительные средства

листинг:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
        print "<div class=\"label2\">Категория<br>
            <select name=\"cat\">";
            $cat_list = mysql_query("SELECT * FROM categories", $db);
            if($cat_list and mysql_num_rows($cat_list) > 0){
                while($cat_list_arr = mysql_fetch_array($cat_list)){
                    print "<option value=\"".$cat_list_arr['catannotation']."\">".$cat_list_arr['catname']."</option>";
                }
            }else{
                print "<option>Не удалось получить данные</option>";
            }
            print "</select>
        </div>
постоянно получаю сообщение о неудачи(
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.01.2014, 19:38
Ответы с готовыми решениями:

Visual C++ обращение к форме из своей функции
Здравствуйте, в общем суть такая, создал я в Visual C++ программу с формой...и добавил еще два файла stud.h в которой хранятся свои классы...

Использование функции в своей программе из своей dll
Среда разработки Visual Studio 2008 Язык C++ Написал dll как в примере на сайте...

Обращение из своей проги к контролу в MSOffice
Доброго времени суток, уважаемые гуру. У меня такая задача. Мне необходимо в окне Открытия/Сохранения файлов Excel обратится к полю...

7
75 / 75 / 17
Регистрация: 29.11.2013
Сообщений: 262
05.01.2014, 19:54
Подозреваю, что $cat_list находиться за пределами видимости функции. Попробуйте использовать функцию вида:
PHP
1
2
3
4
function method(&$cat_list)
{
// mysql_fetch_array($cat_list)
}
1
 Аватар для cellse
70 / 68 / 22
Регистрация: 12.08.2013
Сообщений: 297
05.01.2014, 20:58
PHP
1
if(mysql_num_rows($cat_list) > 0){
Попробуйте изменить проверку на такую
0
 Аватар для Rurr
23 / 23 / 11
Регистрация: 12.01.2013
Сообщений: 223
05.01.2014, 23:59  [ТС]
Цитата Сообщение от cellse Посмотреть сообщение
PHP
1
if(mysql_num_rows($cat_list) > 0){
Попробуйте изменить проверку на такую
реакция таже. проверку не проходит

ilikesmile - передавать указатель на переменную отличная идея и главное что она исправила проблему. спасибо большое. только вот все равно непонятно почему она так? ведь переменная создается внутри области видимости функции.....
0
75 / 75 / 17
Регистрация: 29.11.2013
Сообщений: 262
06.01.2014, 00:35
Цитата Сообщение от Rurr Посмотреть сообщение
только вот все равно непонятно почему она так? ведь переменная создается внутри области видимости функции.....
Честно говоря, я "сыграл вангу", т.к. предположил, что код выглядит следующим образом:
PHP
1
2
3
4
5
6
$cat_list = mysql_query("SELECT * FROM categories", $db);
function method()
{
if($cat_list and mysql_num_rows($cat_list) > 0){
//...
}
Если дело обстоит так, то не имеет значения, где Вы декларируете функцию, до или после объявления переменной.

В любом случае, функция это отдельная под-программа, которая мало о чем знает, кроме $_POST,$_GET и других глобальных.
Ознакомьтесь с материалом, части про global и static должны быть особенно интересны.
0
 Аватар для cellse
70 / 68 / 22
Регистрация: 12.08.2013
Сообщений: 297
06.01.2014, 00:41
Зачем вот надо было вырезать куски кода, если бы ilikesmile не применил телепатию, то не разобрались бы)
0
 Аватар для Rurr
23 / 23 / 11
Регистрация: 12.01.2013
Сообщений: 223
06.01.2014, 04:24  [ТС]
Цитата Сообщение от cellse Посмотреть сообщение
Зачем вот надо было вырезать куски кода, если бы ilikesmile не применил телепатию, то не разобрались бы)
присмотритесь. запрос к базе у меня внутри функции, что указано в листинге. а после того как mysql_query вынес за пределы функции и передал ей указатель на результат выполнения запроса данные были правильно выведены

Честно говоря, я "сыграл вангу", т.к. предположил, что код выглядит следующим образом:
тоже самое. запрос находился внутри тела функции(что представлено в первом посте), о глобальных переменных читал но не было нужды использовать
0
 Аватар для Rurr
23 / 23 / 11
Регистрация: 12.01.2013
Сообщений: 223
08.01.2014, 04:21  [ТС]
а ведь ilikesmile - был просто в миллиметре от ответа, $cat_list = инициализировалась внутри функции и не могла быть за пределами видимости функции а вот другая переменная, $db как раз таки туда не попадала и для использования запроса нужно либо передавать указатель на результат коннекта с базой данных либо не использовать его в запросе.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.01.2014, 04:21
Помогаю со студенческими работами здесь

Код не дожидается своей функции. Необходимо строго остановить работу кода до появления функции
Собственно пару слов о коде. Организован бесконечный цикл ожидания приёма 1 с клиента серверу и посылка данных от сервера клиенту при...

Найти среднее арифметическое значений функции f(x) в точках a, b, (a+b)/2 используя обращение к функции
А этой нету: 3.Найти среднее арифметическое значений функции f(x) в точках a, b, (a+b)/2 используя обращение к функции f=(x*sin⁡...

Найти среднее арифметическое значений функции f(x) в точках а, b, (a+b)/2, используя обращение к функции
Помогите срочно, хотя бы перевести формулу на язык С++

Найти среднее арифметическое значений функции f(x) в точках а, b, (a+b)/2, используя обращение к функции
f=((e^x+e^(-x))/2)*lg()2*x) Добавлено через 3 часа 7 минут что реально никто не может помочь?

Найти среднее арифметическое значений функции f(x) в точках а, b, (a+b)/2, используя обращение к функции
здраствуйте знатаки!! помогите пожалуйсто решить задачу.Найти среднее арифметическое значений функции f(x) в точках а, b, (a+b)/2,...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru