| buildInsertProjection(MergeNotMatchedClause, List, ConnectContext, DataType) |   | 44% |   | 41% | 15 | 19 | 23 | 48 | 0 | 1 |
| executeMergePlan(ConnectContext, StmtExecutor, IcebergExternalTable, LogicalPlan) |  | 0% |  | 0% | 3 | 3 | 23 | 23 | 1 | 1 |
| buildUpdateProjection(MergeMatchedClause, Expression, List, ConnectContext) |   | 69% |   | 78% | 3 | 8 | 5 | 27 | 0 | 1 |
| run(ConnectContext, StmtExecutor) |  | 0% |  | 0% | 2 | 2 | 11 | 11 | 1 | 1 |
| buildDeleteProjection(Expression, List) |  | 0% |  | 0% | 3 | 3 | 11 | 11 | 1 | 1 |
| generateBranchLabel(Expression) |   | 71% |   | 50% | 6 | 9 | 4 | 19 | 0 | 1 |
| getPhysicalMergeSink(NereidsPlanner) |  | 0% |  | 0% | 3 | 3 | 8 | 8 | 1 | 1 |
| buildMergeProjectPlan(ConnectContext, IcebergExternalTable) |   | 83% |   | 66% | 5 | 10 | 5 | 36 | 0 | 1 |
| childIsEmptyRelation(PhysicalSink) |  | 0% |  | 0% | 4 | 4 | 2 | 2 | 1 | 1 |
| buildMergePlan(ConnectContext, IcebergExternalTable) |   | 67% |   | 50% | 2 | 3 | 4 | 13 | 0 | 1 |
| getExplainPlan(ConnectContext) |   | 61% |   | 50% | 1 | 2 | 2 | 8 | 0 | 1 |
| generateFinalProjections(List, List) |   | 94% |   | 87% | 1 | 5 | 1 | 12 | 0 | 1 |
| accept(PlanVisitor, Object) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| IcebergMergeCommand(List, Optional, Optional, LogicalPlan, Expression, List, List) |   | 93% |   | 50% | 1 | 2 | 1 | 15 | 0 | 1 |
| injectRowIdColumn(LogicalPlan, IcebergExternalTable) |   | 55% |   | 50% | 1 | 2 | 1 | 3 | 0 | 1 |
| getRowIdColumn(IcebergExternalTable) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| stmtType() | | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| generateBasePlan() |  | 100% |   | 50% | 1 | 2 | 0 | 6 | 0 | 1 |
| getTargetTable(ConnectContext) |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| getTargetRowIdSlot() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |