-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbatch.go
39 lines (33 loc) · 1.02 KB
/
batch.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
package pgxxray
import (
"context"
"github.com/aws/aws-xray-sdk-go/xray"
"github.com/jackc/pgx/v5"
)
func (t *PGXTracer) TraceBatchStart(ctx context.Context, conn *pgx.Conn, data pgx.TraceBatchStartData) context.Context {
if t.traceEnabled[BatchTraceType] {
var seg *xray.Segment
ctx, seg = t.beginSubsegment(ctx, conn.Config(), "BATCH")
seg.AddMetadata("sql_batch_length", data.Batch.Len())
}
return ctx
}
func (t *PGXTracer) TraceBatchQuery(ctx context.Context, conn *pgx.Conn, data pgx.TraceBatchQueryData) {
if t.traceEnabled[BatchTraceType] {
seg := t.tryGetSegment(ctx)
if seg != nil {
addSegmentMetadataString(seg, "sql", data.SQL)
addSegmentMetadataArray(seg, "sql_args", data.Args)
seg.AddMetadata("sql_rows_affected", data.CommandTag.RowsAffected())
seg.Close(data.Err)
}
}
}
func (t *PGXTracer) TraceBatchEnd(ctx context.Context, conn *pgx.Conn, data pgx.TraceBatchEndData) {
if t.traceEnabled[BatchTraceType] {
seg := t.tryGetSegment(ctx)
if seg != nil {
seg.Close(data.Err)
}
}
}