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

Как добавить данные из формы в таблицу на той же странице в новую строчку

10.10.2018, 17:47. Показов 1668. Ответов 4
Метки нет (Все метки)

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

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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
$name_input=0;
    echo "<table>";
    echo    "<tr>";
    
        while (($col1 = mysql_fetch_row($name_column)) !== false  ) //Вывод названия cтобцов в шапку формы
            {
                if($col1[3]!=="PRI"){
                    echo "<th>" .$col1[0]. "</th>";
                }
            }
    
    echo    "</tr>";
    
    echo    "<tr>";
    
    echo "<form method='POST' name='myform'>";      
        $name_column=mysql_query("SHOW COLUMNS  FROM price");
        
        while (($col1 = mysql_fetch_row($name_column)) !== false){   //Вывод формы
            if($col1[3]!=="PRI"){ //Исключаем стобец ID (он автоматический)
                {
                    if($col1[1]=="varchar(300)"){
                        echo  "<th><input name='".$name_input."'type='text'/></th>";
                     
                    }
                    if($col1[1]=="double"){
                        echo  "<th><input name='".$name_input."' type='number' step='0.01'/></th>";
                    }
                    
                    $name_input++;
                }
            }   
        }
    echo    "</tr>";
    echo    "</table>";
    echo    "</br>";
    echo "<input name='add' type='submit' value='Добавить'>";
    echo    "<input name='b2' type='reset' value='Очистить'>";
    echo    "<input name='b2' type='reset' value='Cохранить в БД'>";
    echo "</form>";
    echo    "</br>";
    $name_column=mysql_query("SHOW COLUMNS  FROM price");
    echo "<table border='1'>";
    echo    "<tr>";
    
        while (($col1 = mysql_fetch_row($name_column)) !== false  ) //Вывод названия cтобцов в шапку таблицы
            {
                if($col1[3]!=="PRI"){
                    echo "<th>" .$col1[0]. "</th>";
                }
            }
    echo    "</tr>";
             if(!empty($_POST['0'])){
                echo "<tr>";
                    for ($i=0; $i<$name_input; $i++)
                    {
                        echo "<td>".$_POST[$i]."</td>";     
                        
                    }
                    echo "</tr>";
                }   
    echo "</table>";
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.10.2018, 17:47
Ответы с готовыми решениями:

Как перенести данные о пользователе на новую строчку
Доброго времени суток! Как сделать, чтобы данные о пользователе ( имя, почта и сообщение ) были на разных строчках, когда приходят на...

PHPExcel: Данные из формы добавить в новую строку файла
Помогите, у меня есть форма, из которой данные должны добавиться в уже существующий файл в новую строку, как это осуществить?

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

4
133 / 118 / 34
Регистрация: 04.04.2018
Сообщений: 593
10.10.2018, 22:51
Moriarti222222, напишите нормально код, PHP к PHP, HTML к HTMl, вывод приличный сделайте. Данные в переменную собираете
PHP
1
.=
и выводите. Мне лень такой хлам разбирать, уже устал с этими echo. Не уже ли самому не приятно когда код понятен что к чему идет. Зачем так себя мучить и других. Перепишите, помогу или напишу как хотите. Не ленитесь
1
0 / 0 / 0
Регистрация: 29.10.2017
Сообщений: 2
11.10.2018, 11:37  [ТС]
Спасибо за Ваш ответ. Вот сделала, как вы посоветовали, и, правда, так гораздо понятнее.
Но так и не придумала, как решить исходную задачу.
Возможно ли только в этом коде ее решить? Если да, то каким образом?
Или проще создать запросом новую временную таблицу в БД, которая будет хранить передаваемые данные с формы и отображать их на странице в виде таблицы?
HTML5
1
2
3
4
5
<html>
 
<head> <title> Добавление данных  таблицу </title> </head>
 
<body>
PHP
1
2
3
4
5
6
<?php
    mysql_connect("localhost", "root") or die ("Невозможно подключиться к серверу"); // установление соединения с сервером
    mysql_query('set character set results="utm8"'); // тип кодировки
    // подключение к базе данных:
    mysql_select_db("bd_price") or die("Нет такой таблицы!");
    ?>
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
<nav>
        <a href="index.php" > Отобразить таблицу </a>
        <a href="new.php"> Добавить новые данные </a>
        <a href="edit.php"> Редактировать таблицу</a>
    </nav>
 
    <H2>Добавление новых данных:</H2>
        <!---ВЫВОД ФОРМЫ --->
    
    <table> 
        <tr>
        <!---вывод названия столбцов в шапку формы --->
PHP
1
2
3
4
5
6
7
8
9
10
11
<?php
    
    $name_column=mysql_query("SHOW COLUMNS  FROM price");
    $name_input=0;  
        while (($col1 = mysql_fetch_row($name_column)) !== false  ) //Вывод названия cтоблцов в шапку формы
            {
                if($col1[3]!=="PRI"){
                    echo "<th>" .$col1[0]. "</th>";
                }
            }
?>
HTML5
1
2
3
4
</tr>
        
        <!---вывод формы --->
        <tr>
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<?php   
                echo "<form method='POST' name='myform'>";      
                $name_column=mysql_query("SHOW COLUMNS  FROM price");
        
                while (($col1 = mysql_fetch_row($name_column)) !== false){   //Вывод формы
                    if($col1[3]!=="PRI"){ //Исключаем столбец ID (он автоматический)
                        if($col1[1]=="varchar(300)"){
                        echo  "<th><input name='".$name_input."'type='text'/></th>"; 
                        }
                        if($col1[1]=="double"){
                        echo  "<th><input name='".$name_input."' type='number' step='0.01'/></th>";
                        }
                        $name_input++;
                    }
                }   
                
        ?>
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
</tr>
    </table>
    <br>
        <input name="add" type="submit" value="Добавить">
        <input name="b2" type="reset" value="Очистить">
        <input name="" type="" value="Cохранить в БД">
    </form>
    
    <br>
    
    <!--- Создание таблицы--->
    <table border='1'>
        <tr>
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<?php
                $name_column=mysql_query("SHOW COLUMNS  FROM price");
                    while (($col1 = mysql_fetch_row($name_column)) !== false  ){ //Вывод названия cтобцов в шапку таблицы
                        if($col1[3]!=="PRI"){
                        echo "<th>" .$col1[0]. "</th>";
                        }   
                    }
            ?>
        </tr>
        <tr>
            <?php
                if(!empty($_POST['0'])){
                    for ($i=0; $i<$name_input; $i++){
                        echo "<td>".$_POST[$i]."</td>";     
                    }
                    echo "</tr>";
                }   
            ?>
HTML5
1
2
3
4
5
</table>
    
</body>
 
</html>
0
133 / 118 / 34
Регистрация: 04.04.2018
Сообщений: 593
11.10.2018, 12:46
Moriarti222222, Вы не так немного сделали. Сначала идет PHP код, а потом HTML.
Вы хотите реализовать вывод данных после того как их отправили? Тут как вариант - это записывать и выводить, с перезагрузкой страницы. Или же с помощью ajax так же записывать и выводить данные. Можно конечно не записывать, а просто выводить, но их не будет в MySQL. Напишите как необходимо. Напишу код. И код поправьте, читать сложно.
0
767 / 323 / 157
Регистрация: 26.05.2016
Сообщений: 2,127
15.10.2018, 16:08
Цитата Сообщение от Moriarti222222 Посмотреть сообщение
Вот мой код, но он лишь обновляет данные в первой строке, а нужно чтобы каждый раз создавал новую.
вместо UPDATE
https://yandex.ru/search/?text... l&lr=10335
нужно INSERT
https://yandex.ru/search/?text... l&lr=10335
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
15.10.2018, 16:08
Помогаю со студенческими работами здесь

Добавить новую строчку ListBox
Не могу добавить новую строчку ListBox Вот код: Form2-&gt;Edit1-&gt;Text = ComboBox1-&gt;Text; if (ListBox1-&gt;ItemIndex&gt;=0) ...

Как добавить новую таблицу в access через delphi
Как можно добавить/создать новую таблицу в Access через delpi. В зависимости от выбранного пункта одной таблицы, в DbGrid открывается...

Как добавить в новую таблицу полученные массивы колонок?
Добрый день! Помогите, не могу найти решение. Опишу проблему: Приложение считывает из файла Excel данные в таблицу dt. Далее мне...

ASP.NET C# Как добавить новую запись в таблицу из SQL
Вопрос в теме. Допустим есть таблица с несколькими столбцами. Как добавить новую запись в эту таблицу? P.S. C отображением данных из...

Как добавить на рамку формы новую кнопку?
Как добавить на рамку формы новую кнопку


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! в-строка - входное арифметическое выражение в инфиксной(обычной). . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru