Условно при множественной вставке

У меня есть много записей, которые мне нужно вставить в уже массивную таблицу (в таблице несколько миллионов строк, и я вставляю несколько тысяч строк за раз).

В настоящее время используется простой синтаксис:

INSERT INTO my_table (name, email) VALUES ('test','test@gmail.com'),('test2','test2@gmail.com')

Эти запросы выполняются пакетами по 1 тысяче строк за раз.

По независящим от меня причинам я не могу объявить email уникальным столбцом (в таблице уже есть дубликаты).

Как я могу добавить условие к каждому запросу INSERT, где мы пропускаем вставки email, когда это значение найдено в базе данных?

Итак, скажем, в приведенном выше запросе мы обнаруживаем, что у нас уже есть строка с электронной почтой test@gmail.com. Я хотел бы пропустить эту строку, но все же вставить другую строку (test2@gmail.com).

Я изо всех сил пытаюсь найти синтаксис, который работает.

Использование SQL Server и pydb.

Заранее благодарю за любую помощь! :D

3 метода стилизации элементов HTML
3 метода стилизации элементов HTML
Когда дело доходит до применения какого-либо стиля к нашему HTML, существует три подхода: встроенный, внутренний и внешний. Предпочтительным обычно...
Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
1
0
34
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Этот запрос должен работать

INSERT INTO my_table (name, email) 
SELECT name, email
FROM (VALUES ('test','test@gmail.com'),('test2','test2@gmail.com')) AS Vals(name, email)
WHERE NOT EXISTS (SELECT 1 FROM my_table x WHERE x.email = Vals.email)

Индекс в столбце электронной почты сделает это настолько быстрым, насколько это возможно, но все равно будет медленнее, чем обычная вставка.

Другие вопросы по теме