Documentation ¶
Overview ¶
Package utils contains helper types and functions that can be used by any relational data source.
Index ¶
- func MakeTestSplit() *api_service_protos.TSplit
- func NewColumnExpression(name string) *api_service_protos.TExpression
- func NewDefaultWhat() *api_service_protos.TSelect_TWhat
- func NewEmptyColumnWhat() *api_service_protos.TSelect_TWhat
- func NewInt32ValueExpression(val int32) *api_service_protos.TExpression
- func NewInt64ValueExpression(val int64) *api_service_protos.TExpression
- func NewNestedValueExpression(val string) *api_service_protos.TExpression
- func NewTextValueExpression(val string) *api_service_protos.TExpression
- func NewUint64ValueExpression(val uint64) *api_service_protos.TExpression
- type Connection
- type ConnectionManager
- type ConnectionManagerBase
- type ConnectionManagerMakeParams
- type ConnectionManagerMock
- type ConnectionMock
- type DataConverter
- type DefaultSchemaProvider
- type QueryArg
- type QueryArgs
- type QueryParams
- type ReadSplitsQuery
- type RowTransformerMock
- type Rows
- type RowsMock
- type SQLFormatter
- type SchemaBuilder
- type SchemaProvider
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func MakeTestSplit ¶ added in v0.1.1
func MakeTestSplit() *api_service_protos.TSplit
func NewColumnExpression ¶ added in v0.1.1
func NewColumnExpression(name string) *api_service_protos.TExpression
func NewDefaultWhat ¶ added in v0.1.1
func NewDefaultWhat() *api_service_protos.TSelect_TWhat
NewDefaultWhat generates default What field with a pair of columns
func NewEmptyColumnWhat ¶ added in v0.4.9
func NewEmptyColumnWhat() *api_service_protos.TSelect_TWhat
NewEmptyColumnWhat generates What field with a one column of type Int32
func NewInt32ValueExpression ¶ added in v0.1.1
func NewInt32ValueExpression(val int32) *api_service_protos.TExpression
func NewInt64ValueExpression ¶ added in v0.5.11
func NewInt64ValueExpression(val int64) *api_service_protos.TExpression
func NewNestedValueExpression ¶ added in v0.5.10
func NewNestedValueExpression(val string) *api_service_protos.TExpression
func NewTextValueExpression ¶ added in v0.1.1
func NewTextValueExpression(val string) *api_service_protos.TExpression
func NewUint64ValueExpression ¶ added in v0.1.1
func NewUint64ValueExpression(val uint64) *api_service_protos.TExpression
Types ¶
type Connection ¶
type Connection interface { // Query runs a query on a specific connection. Query(params *QueryParams) (Rows, error) // For the most of the data sources the database name / table name pair // is strictly defined by the user input. // However, in certain kinds of data sources it's necessary // to override database / table names specified by the user request. From() (database, table string) // Close terminates network connections. Close() error }
type ConnectionManager ¶
type ConnectionManager interface { Make(params *ConnectionManagerMakeParams) ([]Connection, error) Release(ctx context.Context, logger *zap.Logger, cs []Connection) }
type ConnectionManagerBase ¶
type ConnectionManagerBase struct {
QueryLoggerFactory common.QueryLoggerFactory
}
type ConnectionManagerMakeParams ¶ added in v0.6.3
type ConnectionManagerMakeParams struct { Ctx context.Context // mandatory Logger *zap.Logger // mandatory DataSourceInstance *api_common.TGenericDataSourceInstance // mandatory TableName string // mandatory // MaxConnections is the maximum number of connections to make. // Even if there are a plenty of physical instances of a data source, // only requested number of connections will be made. // Zero value means no limit. MaxConnections int // optional }
type ConnectionManagerMock ¶
func (*ConnectionManagerMock) Make ¶
func (m *ConnectionManagerMock) Make( params *ConnectionManagerMakeParams, ) ([]Connection, error)
func (*ConnectionManagerMock) Release ¶
func (m *ConnectionManagerMock) Release(_ context.Context, _ *zap.Logger, cs []Connection)
type ConnectionMock ¶
func (*ConnectionMock) Close ¶
func (m *ConnectionMock) Close() error
func (*ConnectionMock) From ¶ added in v0.6.3
func (m *ConnectionMock) From() (databaseName, tableName string)
func (*ConnectionMock) Query ¶
func (m *ConnectionMock) Query(params *QueryParams) (Rows, error)
type DataConverter ¶ added in v0.1.1
type DataConverter struct{}
DataConverter should be used only from unit tests
func (DataConverter) RowsToColumnBlocks ¶ added in v0.1.1
func (dc DataConverter) RowsToColumnBlocks(input [][]any, rowsPerBlock int) [][][]any
type DefaultSchemaProvider ¶ added in v0.1.0
type DefaultSchemaProvider struct {
// contains filtered or unexported fields
}
func (*DefaultSchemaProvider) GetSchema ¶ added in v0.1.0
func (f *DefaultSchemaProvider) GetSchema( ctx context.Context, logger *zap.Logger, conn Connection, request *api_service_protos.TDescribeTableRequest, ) (*api_service_protos.TSchema, error)
type QueryArgs ¶ added in v0.5.11
type QueryArgs struct {
// contains filtered or unexported fields
}
func (*QueryArgs) AddUntyped ¶ added in v0.5.11
type QueryParams ¶ added in v0.5.11
type ReadSplitsQuery ¶ added in v0.5.11
type ReadSplitsQuery struct { QueryParams What *api_service_protos.TSelect_TWhat }
func MakeReadSplitsQuery ¶ added in v0.5.10
func MakeReadSplitsQuery( ctx context.Context, logger *zap.Logger, formatter SQLFormatter, slct *api_service_protos.TSelect, filtering api_service_protos.TReadSplitsRequest_EFiltering, databaseName, tableName string, ) (*ReadSplitsQuery, error)
type RowTransformerMock ¶
func (*RowTransformerMock) AppendToArrowBuilders ¶
func (t *RowTransformerMock) AppendToArrowBuilders(builder []array.Builder) error
func (*RowTransformerMock) GetAcceptors ¶
func (t *RowTransformerMock) GetAcceptors() []any
func (*RowTransformerMock) SetAcceptors ¶
func (*RowTransformerMock) SetAcceptors([]any)
type Rows ¶
type Rows interface { Close() error Err() error Next() bool NextResultSet() bool Scan(dest ...any) error MakeTransformer(ydbTypes []*Ydb.Type, cc conversion.Collection) (paging.RowTransformer[any], error) }
type RowsMock ¶
func (*RowsMock) MakeTransformer ¶
func (m *RowsMock) MakeTransformer(ydbType []*Ydb.Type, _ conversion.Collection) (paging.RowTransformer[any], error)
func (*RowsMock) NextResultSet ¶ added in v0.2.8
type SQLFormatter ¶
type SQLFormatter interface { // Get placeholder for n'th argument (starting from 0) for prepared statement GetPlaceholder(n int) string // Sanitize names of databases, tables, columns, views, schemas SanitiseIdentifier(ident string) string // Support for high level expression (without subexpressions, they are checked separately) SupportsPushdownExpression(expression *api_service_protos.TExpression) bool // FormatFrom builds a substring containing the literals // that must be placed after FROM (`SELECT ... FROM <this>`). FormatFrom(databaseName, tableName string) string }
type SchemaBuilder ¶ added in v0.1.0
type SchemaBuilder struct {
// contains filtered or unexported fields
}
func NewSchemaBuilder ¶ added in v0.1.0
func NewSchemaBuilder( typeMapper datasource.TypeMapper, typeMappingSettings *api_service_protos.TTypeMappingSettings, ) *SchemaBuilder
func (*SchemaBuilder) AddColumn ¶ added in v0.1.0
func (sb *SchemaBuilder) AddColumn(columnName, columnType string) error
func (*SchemaBuilder) Build ¶ added in v0.1.0
func (sb *SchemaBuilder) Build(logger *zap.Logger) (*api_service_protos.TSchema, error)
type SchemaProvider ¶ added in v0.1.0
type SchemaProvider interface { GetSchema( ctx context.Context, logger *zap.Logger, conn Connection, request *api_service_protos.TDescribeTableRequest, ) (*api_service_protos.TSchema, error) }
func NewDefaultSchemaProvider ¶ added in v0.1.0
func NewDefaultSchemaProvider( typeMapper datasource.TypeMapper, getArgsAndQueryFunc func(request *api_service_protos.TDescribeTableRequest) (string, *QueryArgs), ) SchemaProvider
Click to show internal directories.
Click to hide internal directories.