sql: DELETE + INSERT vs UPDATE + INSERT

后端 未结 7 1676
花落未央
花落未央 2021-01-19 02:29

A similar question has been asked, but since it always depends, I\'m asking for my specific situation separately.

I have a web-site page that shows some data that co

相关标签:
7条回答
  • 2021-01-19 03:00

    It partly depends on how the data is accessed. If you have a period of time with no (or very few) users accessing it, then there won't be much impact on the data disappearing (between the DELETE and the completion of the INSERT) for a short while.

    0 讨论(0)
  • 2021-01-19 03:03

    Have you considered using a materialized view (MSSQL calls them indexed views) instead of doing it manually? This could also have other performance benefits as an indexed view gives the query optimizer more choices when its constructing execution plans for other queries that reference the table(s) in the view.

    0 讨论(0)
  • 2021-01-19 03:05

    Although I fully agree with SQLMenace's answer I do would like to point out that MERGE does NOT remove unneeded records ! If you're sure that your new data will be a super-set of the existing data, then MERGE is great, otherwise you'll either need to make sure that you delete any superfluous records later on, or use the TRUNCATE + INSERT method ... (Personally I'm still a fan of the latter as it usually is quite fast, just make sure to drop all indexes/unique constraints upfront and rebuild them one by one. This has the benefit of the INSERT transaction being smaller and the index-adding being done in (smaller) transactions again later on). (**)

    (**: yes, this might be tricky on live system, but then again he already mentioned this was done during some kind of overnight anyway, I'm extrapolating there is no user-access at that time)

    0 讨论(0)
  • 2021-01-19 03:12

    What if some data that was present yesterdays is not anymore? Delete may be safer or you could end up deleting some records anyway.

    And in the end it doesnt really matter which way you go. Unless on the case @kevinw mentioned

    0 讨论(0)
  • 2021-01-19 03:13

    It depends on the size of the table and the recovery model on the database. If you are deleting many hundreds of thousands of records and reinstating them vs updating a small batch of a few hundred and inserting tens of rows, it will add an unnecessary size to your transaction logs. However you could use TRUNCATE to get around this as it won't affect the transaction log.

    Do you have the option of a MERGE/UPSERT? If you're using MS-SQL you can use CROSS APPLY to do something similar if you don't.

    0 讨论(0)
  • 2021-01-19 03:16

    One approach to handling this type of problem is to insert into new table, then do a table Rename. This will insure that all new data is present at the same time.

    0 讨论(0)
提交回复
热议问题