| ▲ | DELETEs Are Difficult(notso.boringsql.com) |
| 8 points by radimm 2 days ago | 6 comments |
| |
|
| ▲ | Terr_ 2 days ago | parent | next [-] |
| For many of the most painful deletion questions, the root problem is that when the software was first made the stakeholders/product-org didn't think about use-cases for deleting things. At best, they assume a "do not show" property can be placed onto things, which falls apart when you get to legal issues that compel actual removal. |
| |
| ▲ | buildingcrash7 a day ago | parent [-] | | >software was first made the stakeholders/product-org Practically all building, physical and software is made for a purpose first, the process is mainly an obstacle that needs to be minimized. A piece of software is trying to solve a problem just like a door is. It's driven by economics where the recipients don't want to pay any more than they need to and someone is always willing to undercut you by cutting corners. |
|
|
| ▲ | aurareturn 2 days ago | parent | prev | next [-] |
| DELETE FROM films;
I'm surprised databases makes it so easy to just delete an entire table. I think the command should be DELETE FROM films YES-I-KNOW-WHAT-I-AM-DOING;
|
| |
| ▲ | magicalhippo 2 days ago | parent [-] | | Agreed, I've long been thinking that DELETE should require a WHERE clause. If you really want to just delete everything, just do WHERE 1=1. |
|
|
| ▲ | orionblastar 2 days ago | parent | prev [-] |
| Most databases I used have a Status column we could mark as active, inactive, or deleted. That way, you can see what records were marked as deleted and change them back in case of accidental deletion. Keep record retention with the Date_Modified column so you can use SQL delete to remove those deleted records that are older than a year or so. |
| |
| ▲ | arielcostas 2 days ago | parent [-] | | I do something similar, but instead keep a "date_deleted" column null by default, and the "active" column as a boolean. That way, I kill two birds in one stone by having a dedicated column for last deletion (instead of updating a record that is supposedly deleted) and the status just as a boolean instead of some enum, or integer or string. |
|