| Openbravo Issue Tracking System - Openbravo ERP | 
| View Issue Details | 
| 
 | 
| ID | Project | Category | View Status | Date Submitted | Last Update | 
| 0011770 | Openbravo ERP | Y. DBSourceManager | public | 2009-12-11 17:53 | 2010-02-15 11:00 | 
| 
 | 
| Reporter | marvintm |  | 
| Assigned To | marvintm |  | 
| Priority | immediate | Severity | major | Reproducibility | have not tried | 
| Status | closed | Resolution | fixed |  | 
| Platform |  | OS | 5 | OS Version |  | 
| Product Version |  |  | 
| Target Version | 2.50MP10 | Fixed in Version | 2.40MP12 |  | 
| Merge Request Status |  | 
| Review Assigned To |  | 
| OBNetwork customer | No | 
| Web browser |  | 
| Modules | Core | 
| Support ticket |  | 
| Regression level |  | 
| Regression date |  | 
| Regression introduced in release |  | 
| Regression introduced by commit |  | 
| Triggers an Emergency Pack | No | 
| 
 | 
| Summary | 0011770: Remove invalid rows process uses incorrect NOT IN syntax, which could lead to data loss | 
| Description | In update.database, there is a process which removes rows of tables with an on delete cascade foreign key, which point to a non-existing row of another table. 
 This process creates sql statements which have the form:
 
 DELETE FROM table1 WHERE column1 NOT IN (SELECT column2 FROM table2);
 
 This sql statement is correct except in the case that the column can be nullable. If this happens (that is, if there is at least one row in table1 whose value in column1 is null), and the table2 is empty, then all the rows in table1 will be deleted.
 | 
| Steps To Reproduce | - Make sure you have at least one M_PRODUCT entry with M_ATTRIBUTESET_ID null. - Delete all entries in M_ATTRIBUTESET table
 - Run update.database. This will delete all M_PRODUCT entries.
 | 
| Proposed Solution | DBSourceManager needs to be changed. The syntax should probably use NOT EXISTS instead of NOT IN. | 
| Additional Information |  | 
| Tags | No tags attached. | 
| Relationships | | blocks | defect | 0011749 | 2.50MP10 | closed | marvintm | Remove invalid rows process uses incorrect NOT IN syntax, which could lead to data loss | 
 | 
| Attached Files |  | 
| 
 | 
| Issue History | 
| Date Modified | Username | Field | Change | 
| 2009-12-14 18:42 | marvintm | Type | defect => backport | 
| 2009-12-14 18:42 | marvintm | fix_in_branch | => 2.40 | 
| 2009-12-14 20:04 | hgbot | Checkin |  | 
| 2009-12-14 20:04 | hgbot | Note Added: 0022774 |  | 
| 2009-12-14 20:04 | hgbot | Status | scheduled => resolved | 
| 2009-12-14 20:04 | hgbot | Resolution | open => fixed | 
| 2009-12-14 20:04 | hgbot | Fixed in SCM revision | => http://code.openbravo.com/erp/stable/2.40/rev/08e2964c295b9973fcefe988e4996904104c4c95 [^] | 
| 2009-12-15 09:12 | hgbot | Checkin |  | 
| 2009-12-15 09:12 | hgbot | Note Added: 0022807 |  | 
| 2009-12-15 09:12 | hgbot | Fixed in SCM revision | http://code.openbravo.com/erp/stable/2.40/rev/08e2964c295b9973fcefe988e4996904104c4c95 [^] => http://code.openbravo.com/erp/stable/2.40/rev/ba7d8f535917b597322261438a38e458b76b2a71 [^] | 
| 2010-02-15 11:00 | psarobe | Status | resolved => closed | 
| 2010-02-15 11:00 | psarobe | Fixed in Version | => 2.40MP12 |