File path: /hibernate-distribution-3.3.2.GA/project/core/src/main/java/org/hibernate/persister/entity/AbstractEntityPersister.java | File path: /hibernate-distribution-3.3.2.GA/project/core/src/main/java/org/hibernate/persister/entity/AbstractEntityPersister.java | |||
Method name: String generateUpdateString(boolean[], int, Object[], boolean)
|
Method name: String[] generateSQLDeletStrings(Object[])
|
|||
Number of AST nodes: 6 | Number of AST nodes: 6 | |||
1 | String[] propertyColumnNames = getPropertyColumnNames( i );↵ | 1 | String[] propertyColumnNames = getPropertyColumnNames( i );↵ | |
2 | boolean[] propertyNullness = types[i].toColumnNullness( oldFields[i], getFactory() );↵ | 2 | boolean[] propertyNullness = types[i].toColumnNullness( loadedState[i], getFactory() );↵ | |
3 | for ( int k=0; k<propertyNullness.length; k++ ) {↵ | 3 | for ( int k = 0; k < propertyNullness.length; k++ ) {↵ | |
4 | if ( propertyNullness[k] ) {↵ | 4 | if ( propertyNullness[k] ) {↵ | |
5 | update.addWhereColumn( propertyColumnNames[k] );↵ | 5 | delete.addWhereFragment( propertyColumnNames[k] + " = ?" );↵ | |
6 | }↵ | 6 | }↵ | |
7 | else {↵ | 7 | else {↵ | |
8 | update.addWhereColumn( propertyColumnNames[k], " is null" );↵ | 8 | delete.addWhereFragment( propertyColumnNames[k] + " is null" );↵ | |
9 | }↵ | 9 | }↵ | |
10 | } | 10 |
| |
See real code fragment | See real code fragment |
Number of common nesting structure subtrees | 1 |
Number of refactorable cases | 0 |
Number of non-refactorable cases | 1 |
Time elapsed for finding largest common nesting structure subtrees (ms) | 0.5 |
Clones location | Clones are declared in the same class |
Number of node comparisons | 17 |
Number of mapped statements | 4 |
Number of unmapped statements in the first code fragment | 2 |
Number of unmapped statements in the second code fragment | 2 |
Time elapsed for statement mapping (ms) | 8.6 |
Clone type | Type 2 |
ID | Statement | ID | Statement | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
21 | String[] propertyColumnNames = getPropertyColumnNames(i); | 11 | String[] propertyColumnNames = getPropertyColumnNames(i); | |||||||||||
22 | boolean[] propertyNullness = types[i].toColumnNullness(oldFields[i], getFactory()); |
| 12 | boolean[] propertyNullness = types[i].toColumnNullness(loadedState[i], getFactory()); | ||||||||||
23 | for (int k = 0; k < propertyNullness.length; k++) | 13 | for (int k = 0; k < propertyNullness.length; k++) | |||||||||||
24 | if (propertyNullness[k]) | 14 | if (propertyNullness[k]) | |||||||||||
|
| 15 | delete.addWhereFragment(propertyColumnNames[k] + " = ?"); | |||||||||||
25 | update.addWhereColumn(propertyColumnNames[k]); |
| | |||||||||||
else | | |||||||||||||
|
| 16 | delete.addWhereFragment(propertyColumnNames[k] + " is null"); | |||||||||||
26 | update.addWhereColumn(propertyColumnNames[k], " is null"); |
| |
Row | Violation |
---|---|
1 | Unmatched statement delete.addWhereFragment(propertyColumnNames[k] + " = ?"); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
2 | Unmatched statement update.addWhereColumn(propertyColumnNames[k]); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
3 | Unmatched statement delete.addWhereFragment(propertyColumnNames[k] + " is null"); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
4 | Unmatched statement update.addWhereColumn(propertyColumnNames[k]," is null"); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
5 | Clone fragment #1 returns variables propertyColumnNames, k , while Clone fragment #2 returns variables propertyColumnNames, k |