С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.76/21: Рейтинг темы: голосов - 21, средняя оценка - 4.76
0 / 0 / 0
Регистрация: 26.03.2011
Сообщений: 66

массив и база данных

30.03.2011, 16:55. Показов 3897. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
У меня есть такой массив, в который входят имена писателей
$arr=(name=>"Пушкин", name1=>"Лермонтов", .. и.т.д. );

О каждом авторе у меня в базе есть данные
Как мне их запросить одним махом, используя лишь один этот массив, не вбивая каждый раз в запросе имя автора? В литературе я такого примера не нашел
Заранее спасибо!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.03.2011, 16:55
Ответы с готовыми решениями:

Массив и база данных
Заполняю массив данными через preg_match_all(); преобретает такой вид => Array ( =>...

База данных, основанная на службах vs База данных SQL Server
Доброго времени суток. Делал я, значит, Data Access Layer для ASP.NET MVC проекта. Создал обычную библиотеку классов, моделей туда...

Массив записей: база данных студентов - найти ошибку в коде
program spravochnik; uses crt; type sprav=record fio: string; kurs, ball: integer; facul: string; ...

11
 Аватар для RosenR@t
136 / 136 / 7
Регистрация: 07.07.2010
Сообщений: 774
30.03.2011, 16:58
SQL
1
SELECT * FROM имя таблицы WHERE имя поля='имя писателя'
1
0 / 0 / 0
Регистрация: 26.03.2011
Сообщений: 66
30.03.2011, 17:01  [ТС]
Это я знаю. но как мне с помощью одного массива получить сразу же данные обо всех писателях, а не вбивая имя каждого?
0
 Аватар для RosenR@t
136 / 136 / 7
Регистрация: 07.07.2010
Сообщений: 774
30.03.2011, 17:04
SQL
1
SELECT * FROM имя таблицы
Просто не совсем пойму вопрос, есть какой-нить код, какие-нить попытки?!
Что бы посмотреть и подсказать где, что и как...
1
0 / 0 / 0
Регистрация: 26.03.2011
Сообщений: 66
30.03.2011, 18:02  [ТС]
Мне нужно с помощью массива получить данные обо всех писателях, чьи имена в этот массив входят в качестве переменных

Я применил вот такой код

PHP
1
2
3
4
5
6
7
8
9
10
$arr = ('name'=>"Пушкин", 'name1'=>"Лермонтов" ...)';
 
$sql=SELECT Author FROM table1 WHERE Author="$arr"; //// вставил название массива, однако это не сработало
 
$result=mysql_query($sql);
 
while($row = mysql_fetch_assoc($result))
{
    echo $row["Author"];
}
ДАльше что делать не знаю. Догадываюсь, что надо ввести переменную name=''имя автора", но как ее вставить не могу догадаться.
0
763 / 270 / 57
Регистрация: 13.12.2009
Сообщений: 1,110
30.03.2011, 18:47
PHP
1
2
3
4
5
6
7
8
9
10
11
12
$arr = ('name'=>"Пушкин", 'name1'=>"Лермонтов" ...)';
 for ($i =0; $i < 10;$i++)     // 10 -число авторов
{
$sql=SELECT Author FROM table1 WHERE Author="$arr[$i]"; //работать с эл. массива
 // echo $sql; //для проверки запроса только проверяй отключая обращения к базе
$result=mysql_query($sql);
 
while($row = mysql_fetch_assoc($result))
{
    echo $row["Author"];
}
}
попробуй так
1
0 / 0 / 0
Регистрация: 26.03.2011
Сообщений: 66
02.04.2011, 09:47  [ТС]
спасибо! вышло!
0
14 / 50 / 3
Регистрация: 26.12.2009
Сообщений: 406
04.04.2011, 17:27
PHP
1
 for ($i =0; $i < 10;$i++)     // 10 -число авторов
лучше заменить на
PHP
1
 for ($i =0; $i < count($arr);$i++)     // число авторов, сколько их  в массиве
В текущем варианте для каждого автора выполняется отдельный запрос.
Можно все получить в одном.
1
763 / 270 / 57
Регистрация: 13.12.2009
Сообщений: 1,110
06.04.2011, 00:28
Если взять за критерий количество запросов - то неправ.
наличие for предполагает несколько запросов. Работа по объединению материала выполняется РНР.
для выполнения одного запроса нужно заставить работать Базу данных. Следовательно переписать
SQL запрос. Выбрать всех авторов не нужен массив. условие Where лишнее. и последнее применить нужно цикл Do loop c EOF.
Это слишком радикально, я не знаю предыдущего и последующего в тексте проги.
1
0 / 0 / 0
Регистрация: 26.03.2011
Сообщений: 66
06.04.2011, 15:01  [ТС]
Всем большое спасибо! проблема решена!
0
 Аватар для StagnantIce
125 / 105 / 40
Регистрация: 06.03.2011
Сообщений: 334
06.04.2011, 15:07
лучше использовать функцию implode
0
14 / 50 / 3
Регистрация: 26.12.2009
Сообщений: 406
06.04.2011, 16:16
Цитата Сообщение от all_angarsk Посмотреть сообщение
Если взять за критерий количество запросов - то неправ.
наличие for предполагает несколько запросов. Работа по объединению материала выполняется РНР.
для выполнения одного запроса нужно заставить работать Базу данных. Следовательно переписать
SQL запрос. Выбрать всех авторов не нужен массив. условие Where лишнее. и последнее применить нужно цикл Do loop c EOF.
Это слишком радикально, я не знаю предыдущего и последующего в тексте проги.
Что это за поток сознания?

Цитата Сообщение от all_angarsk Посмотреть сообщение
Если взять за критерий количество запросов - то неправ.
Лучше 10 запросов за 1? Можете считать, что Вы правы.

Цитата Сообщение от all_angarsk Посмотреть сообщение
для выполнения одного запроса нужно заставить работать Базу данных. Следовательно переписать
SQL запрос
Прям КО.

Почитайте об
SQL
1
WHERE column_name IN (value1,value2,...)
или операторе OR

Цитата Сообщение от all_angarsk Посмотреть сообщение
Выбрать всех авторов не нужен массив.
Всех авторов из базы задание не стоит выбрать.

Почитайте вопрос ТС:
Цитата Сообщение от Novichok PHP Посмотреть сообщение
Как мне их запросить одним махом, используя лишь один этот массив, не вбивая каждый раз в запросе имя автора?
Цитата Сообщение от Novichok PHP Посмотреть сообщение
и последнее применить нужно цикл Do loop c EOF
Это лишнее.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.04.2011, 16:16
Помогаю со студенческими работами здесь

База данных, массив и другие варианты хранения информации. Как выбрать подходящий
Добрый день, уважаемые! На Visual Studio разрабатывается программа с Win формами. На форме большое количество Combobox. Причем...

Оптовая база: База данных!
Для оптовой базы требуется разработать информационную систему, позво- ляющую обрабатывать данные о товарах на складе. Информация ...

База данных, которая не база данных
Доброго времени суток. С базой данных никогда не работал, а начать не могу, выглядит сложно для короткого времени срока. В общем суть...

Не открывается база данных Access , пишет неразпознаваемый формат базы данных
Не открывается база данных Access , пишет неразпознаваемый формат базы данных,что делать

Как подключиться к базе данных на Wpf. База данных Sql Server
Раньше работал с Windows Worms, и то не долго. Щас хочу перейти на WPF. Я в этом деле еще новичок. Не могли бы вы объяснить как...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru