blob: c0237fbadfab32e5beb127b5295810121e7782c2 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package client
import "github.com/apache/iotdb-client-go/rpc"
const (
TimestampColumnName = "Time"
)
type SessionDataSet struct {
ioTDBRpcDataSet *IoTDBRpcDataSet
}
// Next prepares the next result row for reading,
// returns true on success, or false if there is no next result row or an error
// appened while preparing it.
// consulted Err should be consulted to distinguish between the two cases.
// This is not goroutine safe
func (s *SessionDataSet) Next() (bool, error) {
return s.ioTDBRpcDataSet.next()
}
// GetText returns string value of column value on row.
// This is not goroutine safe
func (s *SessionDataSet) GetText(columnName string) string {
return s.ioTDBRpcDataSet.getText(columnName)
}
func (s *SessionDataSet) GetBool(columnName string) bool {
return s.ioTDBRpcDataSet.getBool(columnName)
}
func (s *SessionDataSet) Scan(dest ...interface{}) error {
return s.ioTDBRpcDataSet.scan(dest...)
}
func (s *SessionDataSet) GetFloat(columnName string) float32 {
return s.ioTDBRpcDataSet.getFloat(columnName)
}
func (s *SessionDataSet) GetDouble(columnName string) float64 {
return s.ioTDBRpcDataSet.getDouble(columnName)
}
func (s *SessionDataSet) GetInt32(columnName string) int32 {
return s.ioTDBRpcDataSet.getInt32(columnName)
}
func (s *SessionDataSet) GetInt64(columnName string) int64 {
return s.ioTDBRpcDataSet.getInt64(columnName)
}
func (s *SessionDataSet) GetTimestamp() int64 {
return s.ioTDBRpcDataSet.GetTimestamp()
}
func (s *SessionDataSet) GetValue(columnName string) interface{} {
return s.ioTDBRpcDataSet.getValue(columnName)
}
func (s *SessionDataSet) GetRowRecord() (*RowRecord, error) {
return s.ioTDBRpcDataSet.getRowRecord()
}
func (s *SessionDataSet) GetColumnCount() int {
return s.ioTDBRpcDataSet.columnCount
}
func (s *SessionDataSet) GetColumnDataType(columnIndex int) TSDataType {
return s.ioTDBRpcDataSet.columnTypeList[columnIndex]
}
func (s *SessionDataSet) GetColumnName(columnIndex int) string {
return s.ioTDBRpcDataSet.columnNameList[columnIndex]
}
func (s *SessionDataSet) GetColumnNames() []string {
return s.ioTDBRpcDataSet.columnNameList
}
func (s *SessionDataSet) IsIgnoreTimeStamp() bool {
return s.ioTDBRpcDataSet.ignoreTimeStamp
}
func (s *SessionDataSet) IsClosed() bool {
return s.ioTDBRpcDataSet.IsClosed()
}
func (s *SessionDataSet) Close() error {
return s.ioTDBRpcDataSet.Close()
}
func NewSessionDataSet(sql string, columnNameList []string, columnTypeList []string,
columnNameIndex map[string]int32,
queryId int64, client *rpc.TSIServiceClient, sessionId int64, queryDataSet *rpc.TSQueryDataSet,
ignoreTimeStamp bool, fetchSize int32, timeoutMs int64) *SessionDataSet {
return &SessionDataSet{
ioTDBRpcDataSet: NewIoTDBRpcDataSet(sql, columnNameList, columnTypeList,
columnNameIndex,
queryId, client, sessionId, queryDataSet,
ignoreTimeStamp, fetchSize, timeoutMs),
}
}