С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.87/15: Рейтинг темы: голосов - 15, средняя оценка - 4.87
Обитатель
 Аватар для vasvas7775
539 / 317 / 42
Регистрация: 24.12.2010
Сообщений: 795

Ответ в гостевой книге

08.03.2011, 11:51. Показов 3160. Ответов 35
Метки нет (Все метки)

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

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
<?php
<?PHP
 
/* Соединяемся с базой данных */
$hostname = "localhost"; // название/путь сервера, с MySQL
$username = "root"; // имя пользователя (в Denwer`е по умолчанию "root")
$password = ""; // пароль пользователя (в Denwer`е по умолчанию пароль отсутствует, этот параметр можно оставить пустым)
$dbName = "my_base"; // название базы данных
 
/* Создаем соединение */
mysql_connect($hostname, $username, $password) or die ("Не могу создать соединение");
/* Выбираем базу данных. Если произойдет ошибка - вывести ее */
mysql_select_db($dbName) or die (mysql_error());
 
 
//Кодировка
mysql_query("set character_set_client='cp1251'");
mysql_query ("set character_set_results='cp1251'");
mysql_query ("set collation_connection='cp1251_general_ci'");
?>
 
/* Таблица MySQL, в которой будут храниться данные */
$table = "gostivaay_ckniga";
 
 
/* Составляем запрос для вставки информации в таблицу
name...date - название конкретных полей в базе;
- в этих переменных содержатся данные, полученные из формы */
$query = "INSERT INTO $table SET GCotvet='".$_POST["otvet"]."' ";
 
 
mysql_query($query) or die(mysql_error());
 
/* Закрываем соединение */
 
 
/* Делаем Автопереход на страницу гостивой книги */
echo ("<meta  http-equiv='Refresh' content='0; url=/gostivaay_ckniga/admin_My_safe/gostivaay_ckniga_admin.php'>");
 
?>
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.03.2011, 11:51
Ответы с готовыми решениями:

Дублируются страницы в гостевой книге
Всем привет! Возникла проблема. Есть гостевая книга. Находится тестовая по урлу http://shocart.ru/test/. Суть проблемы такова: При...

refresh в гостевой книге
Здравствуйте! пишу гостевую книгу (php+mysql). Возникла проблема при добавлении записи. При отправке все в порядке, на экран выводится, в...

ошибка в гостевой книге
всем здрасте! Сделал форму обратной связи. Выдает такая ошибка Deprecated: Function eregi() is deprecated in...

35
 Аватар для __PION__
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
08.03.2011, 12:23
Цитата Сообщение от vasvas7775 Посмотреть сообщение
не могу понять как надо написать обработчик, чтобы от в таблице, создавал не новую строчку, а добавлял ответ в ту строчку, в которой я пишу ответ.
чесно, тож не могу понять что конкретно хочешь. но думаю речь идет о UPDATE

здесь не открыт тег пхп <?php
Цитата Сообщение от vasvas7775 Посмотреть сообщение
/* Таблица MySQL, в которой будут храниться данные */ $table = "gostivaay_ckniga"; /* Составляем запрос для вставки информации в таблицу name...date - название конкретных полей в базе; - в этих переменных содержатся данные, полученные из формы */ $query = "INSERT INTO $table SET GCotvet='".$_POST["otvet"]."' "; mysql_query($query) or die(mysql_error()); /* Закрываем соединение */ /* Делаем Автопереход на страницу гостивой книги */ echo ("<meta http-equiv='Refresh' content='0; url=/gostivaay_ckniga/admin_My_safe/gostivaay_ckniga_admin.php'>"); ?>
0
Обитатель
 Аватар для vasvas7775
539 / 317 / 42
Регистрация: 24.12.2010
Сообщений: 795
08.03.2011, 12:40  [ТС]
Дело в том, что в гостевой книге, когда заходишь как admin, под каждым сообщением появляется textarea для ответа, и кнопка сохранить. По нажатию сохранить, сообщение должно сохраниться в БД, в туже строчку, в которой находится у меня сообщение.
Не получается с обрабодчиком. не знаю как его написать, что бы ответ он добавлял в БД в ту же строчку, к самому сообщению у которого я пишу...
0
 Аватар для __PION__
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
08.03.2011, 13:10
Цитата Сообщение от vasvas7775 Посмотреть сообщение
$query = "INSERT INTO $table SET GCotvet='".$_POST["otvet"]."' ";
что делает SET в операции INSERT ? это только в UPDATE'е.
Смари, я вижу такие пути, раз у тя под каждым сообщением выводится форма, то они должны быть как бы уникальны, чтобы они знали что к какому именно сообщению они относятся. Для этого им можно дать имена (или id) (в цикле) = их id в БД.
Или у тя в админке будет сначала просто список сообщений (как ссылки ведущие на редактирование), при этом у тя открывается это сообщение и одна форма, а параметром, указывающим какое в данный момент обрабатывается сообщение будет массив $_GET
0
Обитатель
 Аватар для vasvas7775
539 / 317 / 42
Регистрация: 24.12.2010
Сообщений: 795
08.03.2011, 13:19  [ТС]
Цитата Сообщение от Love_and_Peace Посмотреть сообщение
под каждым сообщением выводится форма, то они должны быть как бы уникальны, чтобы они знали что к какому именно сообщению они относятся. Для этого им можно дать имена (или id) (в цикле)
суть дела в том что и id и name я дал, НО так как форма находится прямо на странице вывода из БД. Тоесть я ее прописал сразу под выводом сообщения. То она и кланируется под каждым сообщением с одинаковым id и name. так что я даже не представляю как ее привязать к определенному сообщению.
0
 Аватар для __PION__
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
08.03.2011, 13:22
Цитата Сообщение от vasvas7775 Посмотреть сообщение
То она и кланируется под каждым сообщением с одинаковым id и name. так что я даже не представляю как ее привязать к определенному сообщению.
да, так и предполагал.
в цикле не пробовал? можно на твой вывод посмотреть?
0
Обитатель
 Аватар для vasvas7775
539 / 317 / 42
Регистрация: 24.12.2010
Сообщений: 795
08.03.2011, 13:29  [ТС]
Страница вывода из БД для админа:
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
<?PHP
 
/* Соединяемся с базой данных */
$hostname = "localhost"; // название/путь сервера, с MySQL
$username = "root"; // имя пользователя (в Denwer`е по умолчанию "root")
$password = ""; // пароль пользователя (в Denwer`е по умолчанию пароль отсутствует, этот параметр можно оставить пустым)
$dbName = "my_base"; // название базы данных
 
/* Создаем соединение */
mysql_connect($hostname, $username, $password) or die ("Не могу создать соединение");
/* Выбираем базу данных. Если произойдет ошибка - вывести ее */
mysql_select_db($dbName) or die (mysql_error());
 
 
//Кодировка
mysql_query("set character_set_client='cp1251'");
mysql_query ("set character_set_results='cp1251'");
mysql_query ("set collation_connection='cp1251_general_ci'");
 
 
 
/* Таблица MySQL, в которой хранятся данные */
$table = "gostivaay_ckniga"; // название таблицы
 
 
/* Если была нажата ссылка удаления, удаляем запись */
 if (isset($_GET['del'])) {
   $del = intval($_GET['del']);
   $query = "delete from $table where (id='$del')";
   /* Выполняем запрос. Если произойдет ошибка - вывести ее. */
   mysql_query($query) or die(mysql_error());
 }
 
 
/* Составляем запрос для извлечения данных из полей таблицы "gostivaay_ckniga",
Выводим все данные, что бы последнее сообщение стояло первым в самом верху. */
$page = ( isset($_GET['page']) ? intval($_GET['page']) : 1 );
$query = "SELECT id, stamp, GCkname, GCkemail, GCkICQ, GCkURL, GCktext, GCotvet FROM $table ORDER BY id DESC LIMIT ".( ($page - 1)*10 ).",10";
/* Выполняем запрос. Если произойдет ошибка - вывести ее. */
$res = mysql_query($query) or die(mysql_error());
 
 
 
/* Заменяем символы на смайлы */
include($_SERVER["DOCUMENT_ROOT"]."/bd/smail.php");
 
 
$f = "&nbsp;";
$f2 = ":";
/* Выводим данные из таблицы */
?>
 
 
<?
echo ("
<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">
<html>
<head>
    <meta http-equiv=\"Content-Type\" content=\"text/html; charset=windows-1251\" />
    <title>Гостевая книга</title>
<style>
<!--
 
h3 { font-size: 18px; text-align: center; color:#8B8B8B;}
 
#blocks {position:relative; margin-top:25px; left:50%; margin-left:-350px; width:700px; background-color:;}
  #Panel_vida { width:700px; height:20px;}
  #blocks2 {width:100%; background-color:;}
    #name_4 { float:left; height:30px; width:100%; background-color:;}
      #mail { float:left; margin-left:6px; margin-top:8px;}
      #tab {position:relative;}
     #sw_4 { width:700px; height:10px; background-color:;}
       #sw_4_img { position:absolute; margin-left:40px; margin-top:-3px; width:50px; height:10px;}
    #nomer_4 { width:700px; height:10px; text-align:right;  background-color:#F0EFBD; padding-right:10px;
               border-left:solid 1px #9A9A9A; border-right:solid 1px #9A9A9A;}
    #text_4 { width:700px; height:20px; background-color:#F0EFBD; padding-left:10px; padding-right:10px;
              border-left:solid 1px #9A9A9A; border-right:solid 1px #9A9A9A;}
    #data_4 { width:700px; height:10px; text-align:right; background-color:#F0EFBD; padding-right:10px;
              border-left:solid 1px #9A9A9A; border-right:solid 1px #9A9A9A;}
 
    #№ { font-size:9px; color:#0000CC;}
    #№2 { font-size:13px; color:#0000CC;}
    #№2-1 { font-size:11px; color:#990000;}
    #num_id  { font-size:9px; color:#990000;}
    #text_name_1 { float:left; font-size:23px; color:#000000; text-align:left; padding-left:15px; margin-top:6px; display:block;}
    #text_name_2 { float:left; font-size:12px; color:#000000; padding-left:5px; margin-top:15px; display:block; background-color:;}
    #text_name_3 { float:left; font-size:12px; color:#000000; padding-left:15px; margin-top:15px; display:block;}
    #text_name_4 { float:left; font-size:12px; color:#000000; padding-left:15px; margin-top:15px; display:block;}
    #text_name_5 { font-size:15px; color:#000000; padding-left:5px;}
 
    #zacr_bloc1 { height:4px; background-color:;}
    #zacr_bloc2 { height:4px; background-color:;}
 
    .d3 {display: block; height: 1px; background:#F0EFBD; overflow: hidden;}
    .d1, .d2, .d4, .d5 {
    display: block;
    height: 1px;
    background:#F0EFBD;
    overflow: hidden;
   }
   .d1 {  margin: 0 4px; border-left:solid 1px #9A9A9A; border-right:solid 1px #9A9A9A;  border-top:solid 1px #9A9A9A;}
   .d5 {  margin: 0 4px; border-left:solid 1px #9A9A9A; border-right:solid 1px #9A9A9A;  border-bottom:solid 1px #9A9A9A;}
   .d2 {  margin: 0 3px; border-left:solid 1px #9A9A9A; border-right:solid 1px #9A9A9A;}
   .d3 {  margin: 0 2px; border-left:solid 1px #9A9A9A; border-right:solid 1px #9A9A9A;}
   .d4 {  margin: 0 0px; border-left:solid 2px #9A9A9A; border-right:solid 2px #9A9A9A;}
 
   #navigaciay { font-size:14px; margin-top:15px; background-color:; text-align:center;}
 
   #del {text-decoration:none; Font-size:14px; color:#0000CC;}
   #del:hover { color:red;}
 
#scr-otvet { width:700px; background-color:#F0EFBD; padding-left:10px; padding-right:10px;  font-size:16px;
              border-left:solid 1px #9A9A9A; border-right:solid 1px #9A9A9A; font-weight: bold; /*жирность текста*/}
#scr-otvet-slovo { font-size:20px; color:#820000;}
#scr { width:700px; height:40px; background-color:#F0EFBD; padding-left:10px; padding-right:10px;
              border-left:solid 1px #9A9A9A; border-right:solid 1px #9A9A9A;}
#scr-text {
  width:670px;
  height:25px;
  border:solid 1px #0000CC;
  resize:none;
  font-size:15px;}
#scr-Enter { width:50px; height:20px;}
-->
</style>
 
 
</head>
<body>
 
<h3>Гостевая книга.</h3>
");
 
/* Цикл вывода данных из базы конкретных полей */
while ($row = mysql_fetch_array($res)) {
 
echo "<table cellspacing=\"0\" cellpadding=\"0\" id=\"blocks\">";
  echo "<tr>";
    echo "<td id=\"Panel_vida\">";
    echo "<table cellspacing=\"0\" cellpadding=\"0\" id=\"blocks2\">";
      echo "<tr>";
          echo "<td id=\"name_4\">". "<b>". "<font id=\"text_name_1\">". $row['GCkname']. "</font>". "</b>".
          "<img  id=\"mail\" src=\"/images/kartinka_ckniga/mail.gif\">". "</img>".
          "<font id=\"text_name_2\">". $row['GCkemail']. "</font>".
          "<font id=\"text_name_3\">". $row['GCkICQ']. "</font>".
          "<font id=\"text_name_4\">". $row['GCkURL']. "</font>". "</td>";
      echo "</tr>";
    echo "</table>";
    echo "</td>";
  echo "</tr>";
    echo "<tr>";
    echo "<td colspan=\"4\" id=\"sw_4\">". "<img  id=\"sw_4_img\" src=\"/images/kartinka_ckniga/strelka.jpg\">". "</img>". "</td>";
  echo "</tr>";
    echo "<tr>";
    echo "<td colspan=\"4\" id=\"zacr_bloc1\">". "<span class=\"d1\">". "</span>". "<span class=\"d2\">". "</span>".
    "<span class=\"d3\">". "</span>". "<span class=\"d4\">". "</span>". "</td>";
  echo "</tr>";
  echo "<tr>";
    echo "<td colspan=\"4\" id=\"nomer_4\">". "<font id=\"\">".. "</font>". $f. "<font id=\"num_id\">". $row['id']. "</font>". "</td>";
  echo "</tr>";
  echo "<tr>";
    echo "<td colspan=\"4\" id=\"text_4\">". "<font id=\"text_name_5\">".strtr($row['GCktext'], $var_array)."</font>". "</td>";
  echo "</tr>";
  echo "<tr>";
     echo "<td colspan=\"4\" id=\"data_4\">". "<b>". "<font id=\"№2\">". Добавленно.$f2.$f.$f."</font>". "</b>".
          "<font id=\"№2-1\">". $row['stamp']. "</font>". "</td>";
  echo "</tr>";
     echo "<tr>";
     echo "<td colspan=\"4\" id=\"scr-otvet\">". strtr($row['GCotvet'], $var_array)."</td>";
     echo "</tr>";
?>
<form action="otvet_admin.php"  method="post" name="test_form2">
   <tr>
   <td id="scr">
     <textarea maxlength="4000" id="scr-text" name="otvet" rows=""><div id="scr-otvet-slovo"><b>admin: </b></div></textarea>
   </td>
   </tr>
<?
    echo "<tr>";
    echo "<td colspan=\"4\" id=\"data_4\">";
?>
          <div style="float:left; padding-left:10px;">
          <input id="scr-Enter" type="reset" value="Del" />
          <input id="scr-Enter" type="submit" class="buttons" value="Ok" />
          </div>
</form>
<?
          echo "<a onClick=\"showhide('red');\" href=\"#\">".олол."</a>". $f.$f;
          echo "<a href=\"/gostivaay_ckniga/admin_My_safe/update_data.php\"><b>перейти</b></a>". $f.$f;
          echo "<a id=\"del\" name=\"del\" href=\"gostivaay_ckniga_admin.php?del=".$row["id"]."\"><b>Удалить</b></a>";
    echo "</td>";
  echo "</tr>";
  echo "<tr>";
    echo "<td colspan=\"4\" id=\"zacr_bloc2\">". "<span class=\"d4\">". "</span>". "<span class=\"d3\">". "</span>".
    "<span class=\"d2\">". "</span>". "<span class=\"d5\">". "</span>". "</td>";
  echo "</tr>";
echo "</table>";
}
 
        /* Постраничный вывод из базы данных */
        echo "<div id=\"navigaciay\">Страницы:";
        $Query = mysql_query('SELECT COUNT(*) as `count` FROM `'.$table.'`');//Выбираем общее число новостей
        $count = mysql_fetch_array($Query);
        $last = ( $count['count']%10 == 0 ? 0 : 1 ) + intval($count['count']/10);
        for ( $i = 1; $i <= $last; $i++ ) {
                echo ' <a href="?page='.$i.'">'.$i.'</a> ';//Выводим ссылки на остальные страницы
        }
        echo "</div>"; // - Конец -  Постраничный вывод из базы данных
 
 
 
/* Закрываем соединение */
mysql_close();
?>
чуть стили не забыл...
0
 Аватар для __PION__
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
08.03.2011, 13:37
Цитата Сообщение от vasvas7775 Посмотреть сообщение
<textarea maxlength="4000" id="scr-text" name="otvet" rows="">
вот здесь попробуй заменить это id="scr-text" - на id="<?=$row['имя_поля_id']?>"
или для name="otvet"
1
Обитатель
 Аватар для vasvas7775
539 / 317 / 42
Регистрация: 24.12.2010
Сообщений: 795
08.03.2011, 13:42  [ТС]
так?
PHP
1
<textarea maxlength="4000" id="<?=$row['id']?>" name="<?=$row['otvet']?>" rows="">
Или как?????
0
 Аватар для __PION__
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
08.03.2011, 13:48
одно из 2-х:
так
<textarea maxlength="4000" id="<?=$row['id']?>" name="otvet" rows="">
или так
<textarea maxlength="4000" id="scr-text" name="<?=$row['id']?>" rows="">

Добавлено через 2 минуты
а когда хочешь ввести изменения в сообщение (т.е., запрос INSERT), там обязательно добавляешь - ... WHERE id = $row['id'] ...

Добавлено через 52 секунды
есть код где вносишь изменения? (запрос с INSERT'ом)
0
Обитатель
 Аватар для vasvas7775
539 / 317 / 42
Регистрация: 24.12.2010
Сообщений: 795
08.03.2011, 13:55  [ТС]
Love_and_Peace в обработчике, изменил INSERT на UPDATE.
а в форме вывода
PHP
1
<textarea maxlength="4000" id="scr-text" name="otvet" rows="">
PHP
1
<textarea maxlength="4000" id="scr-text" name="<?=$row['id']?>" rows="">
При отправке сообщения пишет:
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'INTO gostivaay_ckniga SET GCotvet=''' at line 1
0
 Аватар для __PION__
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
08.03.2011, 14:06
UPDATE - перепишет все что было в сообщении, а те надо добавить, значит INSERT
так попробуй что ли
PHP
1
2
$otv = $_POST["otvet"];
$query = "INSERT INTO $table (GCotvet) VALUE ($otv)";
0
Обитатель
 Аватар для vasvas7775
539 / 317 / 42
Регистрация: 24.12.2010
Сообщений: 795
08.03.2011, 14:10  [ТС]
Цитата Сообщение от Love_and_Peace Посмотреть сообщение
UPDATE - перепишет все что было в сообщении, а те надо добавить, значит INSERT
так попробуй что ли
PHP
1
2
$otv = $_POST["otvet"];
$query = "INSERT INTO $table (GCotvet) VALUE ($otv)";
теперь пишет:
Column count doesn't match value count at row 1
0
 Аватар для __PION__
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
08.03.2011, 14:20
чет запутался...
здесь $query = "INSERT INTO $table (GCotvet) VALUE ($otv)";
поле GCotvet - имеет тип не integer, значит в кавычки надо занести
и поменяй названия переменных обращения к БД
PHP
1
2
$query_2 = "INSERT INTO $table (GCotvet) VALUE ('$otv')";
mysql_query($query_2) or die(mysql_error());
после обращения выведи на экран само обращение, посмори что выдает
PHP
1
2
3
$query_2 = "INSERT INTO $table (GCotvet) VALUE ('$otv')";
echo $query_2;
mysql_query($query_2) or die(mysql_error());
0
Обитатель
 Аватар для vasvas7775
539 / 317 / 42
Регистрация: 24.12.2010
Сообщений: 795
08.03.2011, 14:30  [ТС]
если в обработчике прописать:
PHP
1
2
$otv = $_POST["otvet"];
$query = "INSERT INTO $table (GCotvet) VALUE ($otv)"
а в форме вывода, в textarea:
PHP
1
<textarea maxlength="4000" class="scr-text" id="<?=$row['id']?>" name="otvet" rows=""></textarea>
То при нажатии кнопки сохранить, пишет:
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '
admin:
)' at line 1



Добавлено через 8 минут
прописал в обработчике:
PHP
1
2
3
$query_2 = "INSERT INTO $table (GCotvet) VALUE ('$otv')";
echo $query_2;
mysql_query($query_2) or die(mysql_error());
В форме
PHP
1
<textarea maxlength="4000" class="scr-text" id="<?=$row['id']?>" name="otvet" rows=""><div id="scr-otvet-slovo"><b>admin: </b></div></textarea>
при сохранении, выдает ошибку но сразу перезагружает страницу, и добавляет вместо ответа две новых строчки с сообщением.
0
 Аватар для __PION__
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
08.03.2011, 14:38
блин, совсем запутался ))
может этот <?=$row['id']?> передать в кнопку -
<input id="scr-Enter" type="submit" class="buttons" value="Ok" />

вот эта строчка должна была вернуть вид запроса, напр., - INSERT INTO $table (GCotvet) VALUE ('$otv'), но с ошибкой, если таковая имеется
Цитата Сообщение от vasvas7775 Посмотреть сообщение
echo $query_2;
напиши здесь все ошибки которая после echo $query_2; она выдает
0
Обитатель
 Аватар для vasvas7775
539 / 317 / 42
Регистрация: 24.12.2010
Сообщений: 795
08.03.2011, 14:53  [ТС]
пишет вот это
INSERT INTO gostivaay_ckniga (GCotvet) VALUE ('
admin:
'), но с ошибкой, если таковая имеетсяYou have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'но с ошибкой, если таковая имеется' at line 1
0
 Аватар для __PION__
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
08.03.2011, 15:13
аа.. кажется понял ))
вот дурень...
это оставь как было
<textarea maxlength="4000" id="<?=$row['id']?>" name="<?=$row['otvet']?>" rows="">,
т.е это <?=$row['id']?> - убери
а между тегами <textarea maxlength="4000" id="старое_значение" name="старое_значение" rows=""></textarea> напиши $row['otvet']
PHP
1
<textarea maxlength="4000" id="старое_значение"  name="старое_значение" rows="">$row['otvet']</textarea>
у тя таким образом все формы должны появится заполненными (можно это подкоректировать, чтобы напр., текст появлялся по нажатию по ссылке (на jquery напр.)).
а запрос будет уже с UPDATE'ом
PHP
1
$query = "UPDATE $table SET GCotvet='".$_POST["otvet"]."' ";
0
Обитатель
 Аватар для vasvas7775
539 / 317 / 42
Регистрация: 24.12.2010
Сообщений: 795
08.03.2011, 15:34  [ТС]
Сделал так:
В форме вывода, прописал:
PHP
1
<textarea maxlength="4000" id="scr-text"  name="otvet" rows=""><?=$row['otvet']?></textarea>
Обработчик, выглядит так:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<?php
  include ($_SERVER["DOCUMENT_ROOT"]."/bd/podcluchenie.php");
 
/* Таблица MySQL, в которой будут храниться данные */
$table = "gostivaay_ckniga";
 
 
/* Составляем запрос для вставки информации в таблицу*/
$query = "UPDATE $table SET GCotvet='".$_POST["otvet"]."' ";
 
mysql_query($query) or die(mysql_error());
 
/* Закрываем соединение */
 
 
/* Делаем Автопереход на страницу гостивой книги */
echo ("<meta  http-equiv='Refresh' content='0; url=/gostivaay_ckniga/admin_My_safe/gostivaay_ckniga_admin.php'>");
 
?>
После того, ка написал ответ, нажимаю кнопку сохранить, ответ сохраняется не только в строчку, с сообщением где писал ответ, но и во всех остальных сообщениях, в полях ответ.
0
 Аватар для __PION__
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
08.03.2011, 16:27
подожди,эт должно помочь
может те скрытое поле передавать со значением $row["id"]

это добавь в форму
<input type=hidden name="hidden" value="<?=$row['id']?>">

а так измени запрос
$query = "UPDATE $table SET GCotvet='".$_POST["otvet"]."' WHERE id = '".$_POST["hidden"]."' ";

Добавлено через 41 минуту
неужели получилось??? ))
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.03.2011, 16:27
Помогаю со студенческими работами здесь

Проблемы с кодировкой в гостевой книге
У меня в гостевой книге очень интересная проблемка. Текст сообщения выводится каракулями, хотя все остальные поля показываются нормально,...

Не разбиват на страницы в гостевой книге
Хотел написать гостевую книгу, используя в качестве базы данных Access. Все получилось, но реализовать разбиение на страницы так и не...

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

Сделать ссылку на почту в гостевой книге
Доброго времени суток! Такая вещь : пользователь вводит данные, они помещаются в файл, потом считываются с файла - выводясь на экран....

Вывод ВСЕХ записей в гостевой книге.
Всем привет! Начал писать свою гостевую книгу (писать это сильно сказано-я только начинаю изусать PHP) и столкнулся с множеством...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru