У меня есть feinstaub MySQL Table с колонками (create_at, PM 2.5, PM 10, entry_id) c4 уникален.И у меня есть dataFrame панд с одинаковыми именами столбцов.В этом кадре данных новые значения и уже существующие значения сравниваются с таблицей SQL.Я использую эту строку для отправки фрейма данных на сервер sql.
df.to_sql("Feinstaub", con=engine, if_exists="append", index=False)
Это сработало только тогда, когда в фрейме данных нет дублирующихся значений.Если есть некоторые дубликаты.ценит это работа до сих пор.Я нашел это решение: Pandas to_sql () для обновления уникальных значений в БД?
with engine.begin() as cn:
sql = """INSERT INTO myFinalTable (Col1, Col2, Col3, ...)
SELECT t.Col1, t.Col2, t.Col3, ...
FROM myTempTable t
WHERE NOT EXISTS
(SELECT 1 FROM myFinalTable f
WHERE t.MatchColumn1 = f.MatchColumn1
AND t.MatchColumn2 = f.MatchColumn2)"""
cn.execute(sql)
Я в конечном итоге с этим:
df.to_sql("temp_feinstaub_wohnzimmer", con=engine, if_exists="replace", index=False)
with engine.begin() as cn:
sql = """INSERT INTO feinstaub (created_at, 'PM 2.5' , 'PM 10', entry_id)
SELECT t.Column1, t.Column2, t.Column3 ,t.Column4
FROM temp_feinstaub_wohnzimmer t
WHERE NOT EXISTS
(SELECT 1 FROM feinstaub f
WHERE t.MatchColumn1 = f.MatchColumn1
AND t.MatchColumn2 = f.MatchColumn2
AND t.MatchColumn3 = f.MatchColumn3
AND t.MatchColumn4 = f.MatchColumn4)"""
cn.execute(sql)
Это поднялоSQL синтаксическая ошибка.Я также пытаюсь переименовать f.MatchColumn, но все еще выдает ошибку синтаксиса sql?
РЕДАКТИРОВАТЬ: Я сейчас использую этот код, и он работает с обратными галочками, спасибо!Но возникла еще одна ошибка;)
#Send the Data to SQL database
df.to_sql("temp_feinstaub_wohnzimmer", con=engine, if_exists="replace", index=False)
with engine.begin() as cn:
sql = """INSERT INTO feinstaub (created_at, `PM 2.5` , `PM 10`, entry_id)
SELECT t.created_at, t.`PM 2.5`, t.`PM 10` ,t.entry_id
FROM temp_feinstaub_wohnzimmer t
WHERE NOT EXISTS
(SELECT 1 FROM feinstaub f
WHERE t.created_at = f.created_at
AND t.`PM 2.5` = f.`PM 2.5`
AND t.`PM 10` = f.`PM 10`
AND t.entry_id = f.entry_id)"""
cn.execute(sql)
и теперь я получаю следующую ошибку:
sqlalchemy.exc.IntegrityError: (_mysql_exceptions.IntegrityError) (1062, "Duplicate entry '3825' for key 'entry_id'") [SQL: 'INSERT INTO feinstaub_wohnzimmer (created_at, `PM 2.5` , `PM 10`, entry_id)\n SELECT t.created_at, t.`PM 2.5`, t.`PM 10` ,t.entry_id\n FROM temp_feinstaub_wohnzimmer t\n WHERE NOT EXISTS\n (SELECT 1 FROM feinstaub_wohnzimmer f\n WHERE t.created_at = f.created_at\n AND t.`PM 2.5` = f.`PM 2.5`\n AND t.`PM 10` = f.`PM 10`\n AND t.entry_id = f.entry_id)']