Форум программистов, компьютерный форум, киберфорум
Python: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 Аватар для Enifan
1845 / 1187 / 501
Регистрация: 14.10.2018
Сообщений: 3,204

Python sqlite3. Узнать результат UPSERT (вставка или замена)

02.02.2025, 14:22. Показов 1769. Ответов 4

Студворк — интернет-сервис помощи студентам
Вопрос в топике - как узнать результат действия UPSERT (вставка или замена)? Допустим код
Python
1
2
3
4
5
6
7
8
def upsert_users(_id, name, surname):
cursor.execute(f'''INSERT INTO Chats (id, name, surname) 
    VALUES (?, ?, ?)
    ON CONFLICT (id) DO UPDATE SET
    name=excluded.name,
    surname=excluded.surname,''',
                   [_id, name, surname])
connect.commit()
В инете находил ответ по Postgres, но это не то что мне нужно
Еще есть информация по методу sqlite3_set_last_insert_rowid(), но не пойму куда его вставлять...
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
02.02.2025, 14:22
Ответы с готовыми решениями:

UPSERT, замена по полям из Дампа
Доброе время суток! Есть дамп базы с данными для двух отдельных таблиц `Buildings` и `BusinessBuilding` Хочу объединить их в одну...

Вставка или замена, однинм запросом
К примеру есть таблица с полями id(уникальный),name(text), cout(int). мне нужно, что бы одним запросом можно было: либо добавить id, name и...

SQLite3 - вставка данных в ДБ
У меня есть парсер, который собирает информацию и сохраняет её в ДБ. База данных работает на sqlite3. Так вот, я не знаю как вставить...

4
963 / 718 / 276
Регистрация: 10.12.2016
Сообщений: 1,761
03.02.2025, 14:34
Лучший ответ Сообщение было отмечено Enifan как решение

Решение

запрос по id сделать ?
SQL
1
SELECT FROM TABLE WHERE id=
1
 Аватар для kazak
3599 / 2741 / 354
Регистрация: 11.03.2009
Сообщений: 6,298
03.02.2025, 23:20
Лучший ответ Сообщение было отмечено Enifan как решение

Решение

Если верить Ынтырнету,
Python
1
2
3
4
5
6
7
cursor.execute(f'''INSERT INTO Chats (id, name, surname) 
    VALUES (?, ?, ?)
    ON CONFLICT (id) DO UPDATE SET
    name=excluded.name,
    surname=excluded.surname,''',
                   [_id, name, surname])
res = cursor.execute("select last_insert_rowid()").fetchone()[0]
Если в первом execute'е была вставка, второй вернет ненулевое значение, в случае апдейта вернется 0
1
 Аватар для Enifan
1845 / 1187 / 501
Регистрация: 14.10.2018
Сообщений: 3,204
06.02.2025, 16:18  [ТС]
Цитата Сообщение от kazak Посмотреть сообщение
select last_insert_rowid()
Получается это отдельный запрос, а я то думал что он идет совместно с другим запросом... Спасибо буду знать.
Отсюда возникает еще один вопрос: к БД происходит много запросов из разных мест. Возможно ли что произойдет какой то запрос, который будет между UPSERT и last_insert_rowid(), и в итоге будет неверный результат?
0
963 / 718 / 276
Регистрация: 10.12.2016
Сообщений: 1,761
07.02.2025, 19:18
Цитата Сообщение от Enifan Посмотреть сообщение
Возможно ли что произойдет какой то запрос, который будет между UPSERT и last_insert_rowid(), и в итоге будет неверный результат?
транзакцию включить
https://aglamov.biz/jazyki-pro... nyh-urok-9
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.02.2025, 19:18
Помогаю со студенческими работами здесь

Вставка списка в ячейку sqlite3
Здравствуйте. Необходимо любым способом вставить список в ячейку. Желательно при помощи декодирования, а не строки, которую потом...

Как узнать строку из которой берется результат функции ВПР или VLOOKUP?
Как узнать строку из которой берется результат функции ВПР или VLOOKUP (в VBA). Спасибо заранее.

Есть ли в C++ замена in Python или как его заменить
Задание: НАЧАЛО ПОКА нашлось (32) заменить (32, 6) КОНЕЦ ПОКА КОНЕЦ Исходная строка содержит 8 двоек и некоторое...

Python, Sqlite3
Сразу извинюсь я не опытный в этом деле. Делаю одну вещь которая должна грузить из .html документов определенный текст в bdSqlite3. ...

Python sqlite3
Всем добрый вечер. Собственно такая вот проблема. Есть VPS CENTOS 6, на нем стандартом стоит python 2.6.6. Для моего проекта на django это...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
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. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru