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

Выпадающий список при редактировании инфы из БД (PHP)

18.06.2017, 12:43. Показов 1672. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток. Возник вопрос о выпадающем списке. Есть две таблицы "Сотрудники" и "Должности". Каждый сотрудник связан с определенной должностью. То-есть это две связных таблицы. Так вот в чем проблема. Делать выпадающий список с данными из БД умею, но вот что-то бы бралось конкретное значение из БД, записывалось в выпадающий список, а затем при изменении, записывалось на которое пользователь изменил, понять не могу.

//выбор сотрудника, информацию по которому мы хотим редактировать
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<form method="GET" action="">
 
    <label>Редактировать инофрмацию по сотруднику: </label>
    <select name="redakt">
    <option value="0"></option> 
                    <?php  //выбор сотрудников из существующих
                        $link = mysql_connect('localhost', 'root', '') or die('Error: ' . mysql_error());
                        echo 'successfully entered';
                        mysql_select_db('itrem') or die('What is u BD');
    
                        $query="SELECT FIO, ID FROM sotrudniki";
                        $res = mysql_query($query);
                        while($row = mysql_fetch_assoc($res)){
                    ?>
                        <option value="<?=$row['ID']?>" ><?=$row['FIO']?></option>
                            <?
                        }
                    ?>
    </select>
    <input type="submit" name="submit" value='Редактировать' >
    
    </p>
    <br>

//после нажатия кнопки "Редактировать" должны появится поля с заполненными данными, которые можно редактировать и потом сохранить. Кнопка НЕ работает... грузит страницу, но никакого результата

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
<?php
if(isset($_GET['submit']) and isset($_GET['ID']))
{   
    $id = htmlentities(mysqli_real_escape_string($link, $_GET['ID']));
    
    $link = mysql_connect('localhost', 'root', '') or die('Error: ' . mysql_error());
    echo 'successfully entered';
    mysql_select_db('itrem') or die('What is u BD');
     
     
    // создание строки запроса
    $query ="SELECT FIO, Nazvanie_d, DateBD FROM sotrudniki, Dolgnosty WHERE sotrudniki.ID_dolgnosty = Dolgnosty.ID_dolgnosty AND ID = '$id'";
    // выполняем запрос
    $result = mysqli_query($link, $query) or die("Ошибка " . mysqli_error($link)); 
    //если в запросе более нуля строк
    if($result && mysqli_num_rows($result)>0) 
    {
        $row = mysqli_fetch_row($result); // получаем первую строку
        $fio = $row[1];
        $nazvanie_d = $row[2];
    $datebd = $row[3];
 
         
        echo "<h2>Изменить информацию о сотруднике</h2>
            <form method='POST'>
            <input type='hidden' name='id' value='$id' />
            <p>ФИО:<br> 
            <input type='text' name='fio' maxlength='50' value='$fio' /></p>
            <p>Должность:
            <select name='dolgnosty'>
            <option value='0'>'$nazvanie_d'</option>
//здесь должен быть выпадающий список с названиями должностей
            </select><br>
            
            <p>Дата рождения: <br> 
            <input type='date' name='datebd' value='$datebd' /></p>
            
            <input type='submit' value='Сохранить'>
            </form>";
         
        mysqli_free_result($result);
    }
}
?>
Добавлено через 1 час 1 минуту
Строчку

Цитата Сообщение от MPolina Посмотреть сообщение
if(isset($_GET['submit']) and isset($_GET['ID']))
изменила на

PHP
1
if(isset($_GET['submit']) and isset($_GET['ID']))
Выдает ошибки:

Warning: mysqli_real_escape_string() expects exactly 2 parameters, 1 given in W:\domains\itrem\redactsotr.php on line 48

Warning: mysqli_query() expects parameter 1 to be mysqli, resource given in W:\domains\itrem\redactsotr.php on line 53

Warning: mysqli_error() expects parameter 1 to be mysqli, resource given in W:\domains\itrem\redactsotr.php on line 53

line 48:
PHP
1
$id = mysqli_real_escape_string($_GET['redakt']);
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.06.2017, 12:43
Ответы с готовыми решениями:

Выпадающий список на php
Доброго времени суток. Помогите решить проблему. У меня есть код который выводит из базы данных из определенной таблицы все картинки. ...

Выпадающий список php+mysql
Ребята, не могу понять в чем ошибка, выводит пустой список: &lt;?php include 'connect.php'; function engineer_list(){ ...

Выпадающий список (php + postgresql)
Здравствуйте уважаемые форумчане, не могли вы бы мне помочь со следующем вопросом, есть БД в postgresql там таблица с 2 полями: 1 поле -...

11
313 / 312 / 221
Регистрация: 11.07.2015
Сообщений: 1,107
18.06.2017, 13:47
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<?php
$link = mysql_connect('localhost', 'root', '') or die('Error: ' . mysql_error());
echo 'successfully entered';
mysql_select_db('itrem') or die('What is u BD');
?>
<form method="GET" action="">
    <label>Редактировать инофрмацию по сотруднику: </label>
    <select name="redakt">
    <option value="0"></option> 
    <?php  
    //выбор сотрудников из существующих
    $query="SELECT FIO, ID FROM sotrudniki";
    $res = mysql_query($query);
    while($row = mysql_fetch_assoc($res)){
    ?>
    <option value="<?=$row['ID']?>" ><?=$row['FIO']?></option>
    <?
    }
    ?>
    </select>
    <input type="submit" name="submit" value='Редактировать' >
    <br>
Добавлено через 6 минут
Попробуйте использовать [РЕЦЕПТ] Класс для работы с БД

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<?php
require 'db.php';
?>
<form method="GET" action="">
    <label>Редактировать инофрмацию по сотруднику: </label>
    <select name="redakt">
    <option value="0"></option> 
    <?php  
    //выбор сотрудников из существующих
    $so = ma("SELECT FIO, ID FROM sotrudniki");
    foreach ($so as $row) {
    ?>
    <option value="<?=$row['ID']?>" ><?=$row['FIO']?></option>
    <?
    }
    ?>
    </select>
    <input type="submit" name="submit" value='Редактировать' >
    <br>
0
Особый статус
 Аватар для FloppyDisc
623 / 221 / 164
Регистрация: 18.11.2015
Сообщений: 1,086
18.06.2017, 13:48
Цитата Сообщение от MPolina Посмотреть сообщение
Warning: mysqli_real_escape_string() expects exactly 2 parameters, 1 given in W:\domains\itrem\redactsotr.php on line 48
PHP
1
mysqli_real_escape_string ( mysqli $link , string $escapestr )
у вас там вообще неразбериха выберите одно mysqli_ или mysql_
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<?php
$link = mysqli_connect('localhost', 'root', '', 'db');
if (!$link) {
    die('Connect Error (' . mysqli_connect_errno() . ') '
            . mysqli_connect_error());
}
 
// или
 
$link = new mysqli('localhost', 'root', '', 'db');
if ($link->connect_error) {
    die('Connect Error (' . $link->connect_errno . ') '
            . $link->connect_error);
}
?>
0
0 / 0 / 0
Регистрация: 03.06.2015
Сообщений: 23
18.06.2017, 13:57  [ТС]
Цитата Сообщение от FloppyDisc Посмотреть сообщение
у вас там вообще неразбериха выберите одно mysqli_ или mysql_
Насколько я поняла и выбрала что-то одно, то вышло такое:
PHP
1
2
3
4
5
6
$link = mysql_connect('localhost', 'root', '') or die('Error: ' . mysql_error());
    echo 'successfully entered';
    mysql_select_db('itrem') or die('What is u BD');
    
    
    $id = mysqli_real_escape_string(mysql $link, string $_GET['redakt']);
Но выдает ошибку на последней строчке :
Parse error: syntax error, unexpected '$link' (T_VARIABLE) in W:\domains\itrem\redactsotr2.php on line 49
0
313 / 312 / 221
Регистрация: 11.07.2015
Сообщений: 1,107
18.06.2017, 13:59
PHP
1
$id = mysqli_real_escape_string($link, $_GET['redakt']);
0
0 / 0 / 0
Регистрация: 03.06.2015
Сообщений: 23
18.06.2017, 14:15  [ТС]
Цитата Сообщение от plohoyav Посмотреть сообщение
$id = mysql_real_escape_string($link, $_GET['redakt']);
При такой записи выдает ошибку:

Warning: mysql_real_escape_string() expects parameter 1 to be string, resource given in

Добавлено через 7 минут
В общем исправив всё на mysql_
PHP
1
2
3
4
5
6
$link = mysql_connect('localhost', 'root', '') or die('Error: ' . mysql_error());
    echo 'successfully entered';
    mysql_select_db('itrem') or die('What is u BD');
    
    
    $id = mysql_real_escape_string($link, $_GET['redakt']);
Выдает данную ошибку:

Warning: mysql_real_escape_string() expects parameter 1 to be string, resource given in

Добавлено через 4 минуты
Возможно ошибка из-за того, что я передаю в параметр $redakt что-то не то
0
313 / 312 / 221
Регистрация: 11.07.2015
Сообщений: 1,107
18.06.2017, 14:25
PHP
1
$id = mysql_real_escape_string($_GET['redakt'], $link);
1
0 / 0 / 0
Регистрация: 03.06.2015
Сообщений: 23
18.06.2017, 14:30  [ТС]
Цитата Сообщение от plohoyav Посмотреть сообщение
PHPВыделить код
1
$id = mysql_real_escape_string($_GET['redakt'], $link);
Помогло, спасибо, но появилась следующая

PHP
1
2
3
$query ="SELECT FIO, Nazvanie_d, DateBD, Telefon, DataOfYstr, Nazvanie_ot FROM sotrudniki, Otdel, Dolgnosty WHERE sotrudniki.ID_dolgnosty = Dolgnosty.ID_dolgnosty AND sotrudniki.ID_otdela = Otdel.ID_otdela AND ID = '".$id."'";
    // выполняем запрос
    $result = mysql_query($link, $query) or die("Ошибка " . mysql_error($link)); // 55 строка
Ошибка:

Warning: mysql_query() expects parameter 1 to be string, resource given in ... on line 55
0
313 / 312 / 221
Регистрация: 11.07.2015
Сообщений: 1,107
18.06.2017, 14:41
PHP
1
mysql_query($query, $link)
1
0 / 0 / 0
Регистрация: 03.06.2015
Сообщений: 23
18.06.2017, 15:20  [ТС]
Цитата Сообщение от plohoyav Посмотреть сообщение
1
mysql_query($query, $link)

Большое спасибо, всё заработало!

Добавлено через 25 минут
Еще проблема, как всё-таки сделать выпадающий список с уже известным значением $nazvanie_d

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
echo "<form>
<p>Должность:
            <select name='dolgnosty'>
            <option value='0'>'$nazvanie_d'</option>
                                                        <?php
                                            $link = mysql_connect('localhost', 'root', '') or die('Error: ' . mysql_error());
                                            mysql_select_db('itrem') or die('What is u BD');
    
                        $query='SELECT Nazvanie_d, ID_dolgnosty FROM Dolgnosty';
                        $res = mysql_query($query);
                        while($row = mysql_fetch_assoc($res)){
                    ?>
                        <option value='<?=$row['ID_dolgnosty']?>' ><?=$row['Nazvanie_d']?></option>
                            <?
                        }
                        ?>
            </select><br></form>"
0
313 / 312 / 221
Регистрация: 11.07.2015
Сообщений: 1,107
18.06.2017, 15:43
PHP
1
2
3
4
5
6
7
8
9
10
$query ="SELECT * FROM sotrudniki WHERE ID = '$id'";
$result = mysql_query($query, $link) or die("Ошибка " . mysqli_error($link)); 
$row = mysqli_fetch_row($result);
$id_dolgnosti = $row['ID_dolgnosty'];
 
$query='SELECT Nazvanie_d, ID_dolgnosty FROM Dolgnosty';
$res = mysql_query($query);
while($row = mysql_fetch_assoc($res)){
echo '<option value="'.$row['ID_dolgnosty'].'"'.($row['ID_dolgnosty']==$id_dolgnosti?' selected':'').'>'.$row['Nazvanie_d'].'</option>';
}
Добавлено через 4 минуты
Обычно сравнивают по id, можно по названию

PHP
1
2
3
4
5
$query='SELECT Nazvanie_d, ID_dolgnosty FROM Dolgnosty';
$res = mysql_query($query);
while($row = mysql_fetch_assoc($res)){
echo '<option value="'.$row['ID_dolgnosty'].'"'.($row['Nazvanie_d']==$nazvanie_d?' selected':'').'>'.$row['Nazvanie_d'].'</option>';
}
0
0 / 0 / 0
Регистрация: 03.06.2015
Сообщений: 23
18.06.2017, 16:17  [ТС]
Сделала так
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
echo "<center><h2>Изменить информацию о отруднике</h2>
            <form method='POST'>
            <input type='hidden' name='id' value='$id' />
            <p>ФИО:<br> 
            <input type='text' name='fio' maxlength='50' value='$fio' /></p>
            <p>Должность:
            <select name='dolgnosty'>
                        <?php
                        $link = mysql_connect('localhost', 'root', '') or die('Error: ' . mysql_error());
                        mysql_select_db('itrem') or die('What is u BD');
    
                        
 
                        $query='SELECT Nazvanie_d, ID_dolgnosty FROM Dolgnosty';
                        $id_dolgnosti = $row['ID_dolgnosty']; //line 85
                        $res = mysql_query($query);
                        while($row = mysql_fetch_assoc($res)){
        <option value="'.$row['ID_dolgnosty'].'"'.($row['ID_dolgnosty']==$id_dolgnosti?' selected':'').'>'.$row['Nazvanie_d'].'</option>;
}
?>
            </select><br>
Выдает ошибку:

Parse error: syntax error, unexpected '' (T_ENCAPSED_AND_WHITESPACE), expecting identifier (T_STRING) or variable (T_VARIABLE) or number (T_NUM_STRING) in W:\domains\itrem\redactsotr2.php on line 85


Возможно не нужно всё в echo прописывать?

Добавлено через 15 минут
Сделала, всё получилось! Спасибо огромное!!! Теперь осталось это всё перезаписывать в таблицу
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.06.2017, 16:17
Помогаю со студенческими работами здесь

PHP. Выпадающий список из БД Firebird
Подскажите готовые примеры вывода выпадающего списка. В бд есть таблица с колонками Фамилия Имя Отчество, так же есть таблица с...

Выпадающий список вариантов из БД. php or ajax?
Доброго дня! Сразу к делу. Есть форма ввода заказов (локальный сайт) с полем &quot;фирма&quot;. В это поле, каждый раз, нужно вводить...

Выпадающий список и запись в БД с использованием PHP
Есть три таблицы &quot;Сотрудники&quot;, &quot;Отделы&quot;, &quot;Должности&quot;. Пытаюсь в таблицу &quot;сотрудников&quot; добавить нового сотрудника.У сотрудника есть...

Выпадающий список php c данными из другой таблицы
Всем привет! Помогите сделать выпадающий список. Много уже просмотрел, но так ничего не получается. Имеется две таблицы: Нужно чтобы...

Связь двух таблиц и выпадающий список php mysql
Помогите начинающму! Есть две таблицы: tab1 id produkt - в эту таблицу добавляются клиенты tab2


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru