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 generateGeneratedValuesSelectString(ValueInclusion[])
|
Method name: String generateSnapshotSelectString()
|
|||
Number of AST nodes: 9 | Number of AST nodes: 8 | |||
1 | Select select = new Select( getFactory().getDialect() );↵ | 1 | Select select = new Select( getFactory().getDialect() );↵ | |
2 | if ( getFactory().getSettings().isCommentsEnabled() ) {↵ | 2 | if ( getFactory().getSettings().isCommentsEnabled() ) {↵ | |
3 | select.setComment( "get generated state " + getEntityName() );↵ | 3 | select.setComment( "get current state " + getEntityName() );↵ | |
4 | }↵ | 4 | }↵ | |
5 | String[] aliasedIdColumns = StringHelper.qualify( getRootAlias(), getIdentifierColumnNames() );↵ | 5 | String[] aliasedIdColumns = StringHelper.qualify( getRootAlias(), getIdentifierColumnNames() );↵ | |
6 | // Here we render the select column list based on the properties defined as being generated.↵ | 6 | ↵ | |
7 | // For partial component generation, we currently just re-select the whole component↵ | |||
8 | // rather than trying to handle the individual generated portions.↵ | |||
9 | String selectClause = concretePropertySelectFragment( getRootAlias(), inclusions );↵ | |||
10 | selectClause = selectClause.substring( 2↵ | 7 | String selectClause = StringHelper.join( ", ", aliasedIdColumns ) +↵ | |
11 | );↵ | 8 | concretePropertySelectFragment( getRootAlias(), getPropertyUpdateability() );↵ | |
12 | String fromClause = fromTableFragment( getRootAlias() ) +↵ | 9 | String fromClause = fromTableFragment( getRootAlias() ) +↵ | |
13 | fromJoinFragment( getRootAlias(), true, false );↵ | 10 | fromJoinFragment( getRootAlias(), true, false );↵ | |
14 | String whereClause = new StringBuffer()↵ | 11 | String whereClause = new StringBuffer()↵ | |
15 | .append( StringHelper.join( "=? and ", ↵ | 12 | .append( StringHelper.join( "=? and ",↵ | |
16 | aliasedIdColumns ) )↵ | 13 | aliasedIdColumns ) )↵ | |
17 | .append( "=?" )↵ | 14 | .append( "=?" )↵ | |
18 | .append( whereJoinFragment( getRootAlias(), true, false ) )↵ | 15 | .append( whereJoinFragment( getRootAlias(), true, false ) )↵ | |
19 | .toString();↵ | 16 | .toString();↵ | |
17 | /*if ( isVersioned() ) {↵ | |||
18 | where.append(" and ")↵ | |||
19 | .append( getVersionColumnName() )↵ | |||
20 | .append("=?");↵ | |||
21 | }*/↵ | |||
20 | return select.setSelectClause( selectClause )↵ | 22 | return select.setSelectClause( selectClause )↵ | |
21 | .setFromClause( fromClause )↵ | 23 | .setFromClause( fromClause )↵ | |
22 | .setOuterJoins( "", "" )↵ | 24 | .setOuterJoins( "", "" )↵ | |
23 | .setWhereClause( whereClause )↵ | 25 | .setWhereClause( whereClause )↵ | |
24 | .toStatementString(); | 26 |
| |
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.2 |
Clones location | Clones are declared in the same class |
Number of node comparisons | 28 |
Number of mapped statements | 8 |
Number of unmapped statements in the first code fragment | 1 |
Number of unmapped statements in the second code fragment | 0 |
Time elapsed for statement mapping (ms) | 5.3 |
Clone type | Type 3 |
ID | Statement | ID | Statement | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
1 | Select select = new Select(getFactory().getDialect()); | 1 | Select select = new Select(getFactory().getDialect()); | ||||||||||||
2 | if (getFactory().getSettings().isCommentsEnabled()) | 2 | if (getFactory().getSettings().isCommentsEnabled()) | ||||||||||||
3 | select.setComment("get generated state " + getEntityName()); |
| 3 | select.setComment("get current state " + getEntityName()); | |||||||||||
4 | String[] aliasedIdColumns = StringHelper.qualify(getRootAlias(), getIdentifierColumnNames()); | 4 | String[] aliasedIdColumns = StringHelper.qualify(getRootAlias(), getIdentifierColumnNames()); | ||||||||||||
5 | String selectClause = concretePropertySelectFragment(getRootAlias(), inclusions); |
| 5 | String selectClause = StringHelper.join(", ", aliasedIdColumns) + concretePropertySelectFragment(getRootAlias(), getPropertyUpdateability()); | |||||||||||
6 | selectClause = selectClause.substring(2); |
| | ||||||||||||
7 | String fromClause = fromTableFragment(getRootAlias()) + fromJoinFragment(getRootAlias(), true, false); | 6 | String fromClause = fromTableFragment(getRootAlias()) + fromJoinFragment(getRootAlias(), true, false); | ||||||||||||
8 | String whereClause = new StringBuffer().append(StringHelper.join("=? and ", aliasedIdColumns)).append("=?").append(whereJoinFragment(getRootAlias(), true, false)).toString(); | 7 | String whereClause = new StringBuffer().append(StringHelper.join("=? and ", aliasedIdColumns)).append("=?").append(whereJoinFragment(getRootAlias(), true, false)).toString(); | ||||||||||||
9 | return select.setSelectClause(selectClause).setFromClause(fromClause).setOuterJoins("", "").setWhereClause(whereClause).toStatementString(); | 8 | return select.setSelectClause(selectClause).setFromClause(fromClause).setOuterJoins("", "").setWhereClause(whereClause).toStatementString(); |
Row | Violation |
---|---|
1 | Expression StringHelper.join(", ",aliasedIdColumns) + concretePropertySelectFragment(getRootAlias(),getPropertyUpdateability()) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
2 | Unmatched statement selectClause=selectClause.substring(2); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
3 | Clone fragment #1 returns variables selectClause , while Clone fragment #2 returns variables |