| buildInsertProjection(MergeNotMatchedClause, List, ConnectContext, DataType) |   | 44% |   | 41% | 15 | 19 | 23 | 48 | 0 | 1 |
| buildUpdateProjection(MergeMatchedClause, Expression, List, ConnectContext) |   | 69% |   | 78% | 3 | 8 | 5 | 27 | 0 | 1 |
| getExplainPlan(ConnectContext) |  | 0% |  | 0% | 2 | 2 | 8 | 8 | 1 | 1 |
| generateBranchLabel(Expression) |   | 82% |   | 68% | 4 | 9 | 3 | 19 | 0 | 1 |
| getRowIdColumn(IcebergExternalTable) |  | 0% |  | 0% | 4 | 4 | 7 | 7 | 1 | 1 |
| buildMergeProjectPlan(ConnectContext, IcebergExternalTable) |   | 87% |   | 72% | 4 | 10 | 4 | 36 | 0 | 1 |
| hasRowIdProject(List) |  | 0% |  | 0% | 4 | 4 | 6 | 6 | 1 | 1 |
| findRowIdSlot(List) |  | 0% |  | 0% | 3 | 3 | 5 | 5 | 1 | 1 |
| buildMergePlan(ConnectContext, IcebergExternalTable) |   | 67% |   | 50% | 2 | 3 | 4 | 13 | 0 | 1 |
| run(ConnectContext, StmtExecutor) |   | 66% |   | 50% | 1 | 2 | 2 | 11 | 0 | 1 |
| getPhysicalMergeSink(NereidsPlanner) |   | 69% |   | 50% | 2 | 3 | 2 | 8 | 0 | 1 |
| injectRowIdColumn(LogicalPlan, IcebergExternalTable) |   | 35% |   | 50% | 1 | 2 | 1 | 3 | 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 |
| hasRowIdSlot(List) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| executeMergePlan(ConnectContext, StmtExecutor, IcebergExternalTable, LogicalPlan) |   | 97% |   | 50% | 2 | 3 | 1 | 23 | 0 | 1 |
| childIsEmptyRelation(PhysicalSink) |  | 88% |   | 50% | 3 | 4 | 0 | 2 | 0 | 1 |
| stmtType() | | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| lambda$hasUnboundPlan$0(TreeNode) |  | 90% |   | 50% | 2 | 3 | 0 | 1 | 0 | 1 |
| buildDeleteProjection(Expression, List) |  | 100% |  | 100% | 0 | 3 | 0 | 11 | 0 | 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 |
| hasUnboundPlan(Plan) |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |