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

Как можно одним запросом редактировать предыдущую строку и добавить новый?

08.01.2016, 23:33. Показов 1111. Ответов 17
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как можно одним запросом редактировать предыдущую строку и добавить новый? Если можно на примитивных примерах помагите.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.01.2016, 23:33
Ответы с готовыми решениями:

Как правильно добавить UUID в таблицы одним запросом?
создала я значит таблицы вида CREATE TABLE users ( id UUID NOT NULL PRIMARY KEY, name VARCHAR(32) COLLATE...

Как добавить данные одним запросом в разные таблицы?
Начал делать базу. Чтобы не ошибиться с внесением данных надо пользоваться формами и запросами. Там, где поля - список значений, всё...

Как добавить в таблицу mdb файла Аксесса несколько записей одним запросом?
Собственно вопрос в теме. Искал по инету, но ничего путного не нашел. (хотя, может быть плохо искал и что-то пропустил) Пробовал...

17
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,909
08.01.2016, 23:58
PHP
1
2
3
4
<form>
<input type="text" name="old" value="$value" />
<input type="text" name="new" />
</form>
Значение старого поля подставляете в old. Когда форма приходит на сервер, одно значение редактируете, другое добавляете.
0
0 / 0 / 0
Регистрация: 03.01.2014
Сообщений: 60
09.01.2016, 00:15  [ТС]
Это я знаю, мне нужно конструкция запроса
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,909
09.01.2016, 00:32
mnpartner, упс, неправильно понял вопрос.

А зачем в 1 запросе? Почему 2 запроса нельзя сделать?
0
0 / 0 / 0
Регистрация: 03.01.2014
Сообщений: 60
09.01.2016, 01:00  [ТС]
я пробовал
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
if($_REQUEST["action"] == "add") {
mysql_query("INSERT INTO `send` (
...
                                                        
    ) VALUES (
    
        ...
            
        )") or die(mysql_error());
    
    
 
 
mysql_query("
        UPDATE `send` 
        SET
    ....= .....
    ") or die(mysql_error());
}
но в этом случаи бывают единичные случаи когда исполняется только INSERT INTO , а UPDATE не происходит.
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,909
09.01.2016, 02:05
mnpartner, значит, нужно с этими случаями разбираться, смотреть текст ошибок. Может данные не экранировали перед записью в бд?
0
5 / 5 / 2
Регистрация: 24.08.2014
Сообщений: 34
09.01.2016, 12:32
Цитата Сообщение от mnpartner Посмотреть сообщение
редактировать предыдущую строку и добавить новый
Именно так наверное нельзя. Но можно так:
Code
1
2
INSERT INTO table (a,b,c) VALUES (1,2,3)
ON DUPLICATE KEY UPDATE c=c+1;
То есть наоборот: вставить новую строку, а если ключ дублируется - изменить её.
0
0 / 0 / 0
Регистрация: 03.01.2014
Сообщений: 60
09.01.2016, 14:50  [ТС]
этот вариант мне не подходит, мне не неужно редактировать существующую запись, а редактировать запись у которoго id меньше на один.

Добавлено через 2 минуты
а как экранировать данные?
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,909
09.01.2016, 16:57
mnpartner, mysqli_real_escape_string
0
0 / 0 / 0
Регистрация: 03.01.2014
Сообщений: 60
09.01.2016, 20:45  [ТС]
Сделал вот так, как изменить по вашему замечанию
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
$action = trim($_REQUEST["action"]);
if($action == "add") {
 
$record = trim($_REQUEST["record"]);
$hert_id = trim($_REQUEST["hert_id"]);
$income_status = trim($_REQUEST["income_status"]);
$d_change = trim($_REQUEST["d_change"]);
$ds_in = trim($_REQUEST['ds_in']);
 
$depart_in = trim($_REQUEST['depart_in']);
$subdepart_in = trim($_REQUEST['subdepart_in']);
$hyst_dep = trim($_REQUEST['hyst_dep']);
$doctor_in = trim($_REQUEST['doctor_in']);
 
 
 
 
 
 
mysql_query("INSERT INTO `send` (
    `patient_id`, 
    `hert_id`,
     `income_status`,
    `date_inccome`, 
    `ds_in`,
    `depart_in`,
     `subdepart_in`,
      `hyst_dep`,
    `doctor_in`
                                                        
    ) VALUES (
    
        '{$record}', 
                '{$hert_id}', 
            '{$income_status}', 
            '{$d_change}',
            '{$ds_in}',
            '{$depart_in}',
        '{$subdepart_in}',
        '{$hyst_dep}',
            '{$doctor_in}'
            
            
        )") or die(mysql_error());
    
    
$o_status = trim($_REQUEST["o_status"]);
$bed_day_depart = trim($_REQUEST["bed_day_depart"]);
$depart_out = trim($_REQUEST["depart_out"]);
$d_change = trim($_REQUEST["d_change"]);
$out_id = trim($_REQUEST['out_id']);
 
mysql_query("
        UPDATE `send` 
        SET
    `o_status`='$o_status' ,
    `bed_day_depart`='$bed_day_depart' ,
    `depart_out`='$depart_out' ,
    `o_date`='$d_change'
        WHERE `id`='$out_id'
    ") or die(mysql_error());
 
    
    
    
    
    
 
    header ("Location: patient_view.php?id=".$_REQUEST["id"]."");
 
    
    
    
    
    
    
    
}
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,909
09.01.2016, 21:27
mnpartner, для начала вместо $_REQUEST лучше использовать $_GET или $_POST в зависимости от метода. И перед записью в БД фильтруем данные. Для строковых так:
PHP
1
$record = mysql_real_escape_string(trim($_POST['record']));
Для целых чисел достаточно приведения к типу:
PHP
1
$depart_in = (int) $_POST['depart_in'];
0
0 / 0 / 0
Регистрация: 03.01.2014
Сообщений: 60
10.01.2016, 10:32  [ТС]
Спасибо, все работает если киманда INSERT INTO , а если UPDATE то не работает(данные не вводятся)
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
$o_status = mysql_real_escape_string(trim($_POST['o_status']));
$bed_day_depart = mysql_real_escape_string(trim($_POST['bed_day_depart']));
$depart_out = mysql_real_escape_string(trim($_POST['depart_out']));
$d_change = mysql_real_escape_string(trim($_POST['d_change']));
$out_id = mysql_real_escape_string(trim($_POST['out_id'])); 
    
 
mysql_query("
        UPDATE `send` 
        SET
    `o_status`='$o_status' ,
    `bed_day_depart`='$bed_day_depart' ,
    `depart_out`='$depart_out' ,
    `o_date`='$d_change'
        WHERE `id`='$out_id'
    ") or die(mysql_error());
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,909
10.01.2016, 11:00
Цитата Сообщение от mnpartner Посмотреть сообщение
(данные не вводятся)
= не обновляются?

Выведите запрос целиком:
PHP
1
2
3
4
5
6
7
8
9
10
11
$query = "
        UPDATE `send` 
        SET
    `o_status`='$o_status' ,
    `bed_day_depart`='$bed_day_depart' ,
    `depart_out`='$depart_out' ,
    `o_date`='$d_change'
        WHERE `id`='$out_id'
    ";
echo $query;
// mysql_query($query) or die(mysql_error());
И скопипастите сюда. Может $out_id пустая.
0
0 / 0 / 0
Регистрация: 03.01.2014
Сообщений: 60
10.01.2016, 11:41  [ТС]
Я понял в чем проблема: дело в том, что OUT_ID приходит не из формы, а из предыдущей страницы по ссылке, если я вставляю $out_id = mysql_real_escape_string(trim($_REQUEST['out_id'])); вместо $out_id = mysql_real_escape_string(trim($_POST['out_id'])); ,то все работает

Добавлено через 2 минуты
но сейчас думаю сделать по другому- с помощью ajax сперва редактировать данные, если все ок, то тогда вносить новые
Java
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
var i = 0;
 
function next() {
if (i < length) document.setTimeout('myfunc_1('+i+')', 100);
i = i + 1;
}
      
function myfunc_1(i){
        $.ajax({
                ...
                success: function(result){
                        myfunc_2(i);
                }
        });
}
 
function myfunc_2(i){
        $.ajax({
                ....
                success: function(result){
                        next();
                }
        });
}
 
next();
что Вы думаете об этом?
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,909
10.01.2016, 13:12
mnpartner, если идентификатор передаётся в ссылке, тогда будет не $_POST['out_id'], а $_GET['out_id'].

$_REQUEST содержит данные из массивов $_GET, $_POST, $_COOKIE и др. (в зависимости от настроек сервера). Это может в будущем создать проблемы, когда код разрастётся и появятся одинаковые переменные, скажем $_POST['cart'] и $_COOKIE['cart']. Что в итоге будет лежать в $_REQUEST - зависит от настроек сервера.

Касательно AJAX - зависит от ваших задач.
0
0 / 0 / 0
Регистрация: 03.01.2014
Сообщений: 60
10.01.2016, 15:17  [ТС]
Спасибо за помощ,
0
wq
85 / 78 / 32
Регистрация: 26.11.2015
Сообщений: 481
10.01.2016, 16:19
Цитата Сообщение от mnpartner Посмотреть сообщение
но в этом случаи бывают единичные случаи когда исполняется только INSERT INTO , а UPDATE не происходит.
Цитата Сообщение от mnpartner Посмотреть сообщение
редактировать запись у которoго id меньше на один
а чего тут удивительного? Элементарное нарушение логики программы. Запись id-1 может просто не существовать и это нормальная ситуация в БД. БД не обязана поддерживать непрерывность ряда автоинкрементных ключей. ..переписывайте все..
0
0 / 0 / 0
Регистрация: 03.01.2014
Сообщений: 60
10.01.2016, 22:42  [ТС]
При добавлении нового поля у меня передается ID уже имеющегося поля (предыдущего)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.01.2016, 22:42
Помогаю со студенческими работами здесь

Можно ли сделать такую выборку одним запросом или как их обьеденить?
В продолжении темы https://www.cyberforum.ru/mysql/thread1136099.html. Есть у меня таблицы: Message(id, fromUserId, toUserId,...

Как редактировать поля структуры и как добавить новый элемент в вектор структур?
Отзовитесь, пожалуйста, кто-то. Допустим есть структура struct worker { int exp; const char* name; const...

Добавить несколько строк одним запросом
есть таблица, хочу вставить несколько строк адним запросам, есть код ELT(FIELD( PREPARE вот с помощью этих функций вставить много...

Можно ли обойтись одним запросом
Добрый вечер, помогите дописать sql , и можно ли уложится одним как-то запросом ... SELECT m . * , wd.WORKDATE AS WD_DATE,...

Одним запросом можно получить такое
есть таблица product_id | count | sklad_id нужно получить продукты которых на складах 234, 266, 267 = 0, а на любом другом &gt;0 ...


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

Или воспользуйтесь поиском по форуму:
18
Ответ Создать тему
Новые блоги и статьи
ПЛИС
zxcha1ka_ 27.01.2026
AHDL Разработать программы для синтеза следующих устройств: 1. Параллельного регистра 4-х разрядного с синхронной загрузкой и асинхронным сбросом (обнулением); Пoмoгитe пoжaлyйстa
Загрузка PNG-файла с альфа-каналом с помощью библиотеки SDL3_image на Android
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru