Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
fda8a85e
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
fda8a85e
编写于
12月 27, 2021
作者:
H
Hui Li
提交者:
GitHub
12月 27, 2021
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #9360 from taosdata/test/TD-10790-1
[test/TD-10790]<test>(connector):test case for C#stmt
上级
52e568c5
25c324ed
变更
8
展开全部
显示空白变更内容
内联
并排
Showing
8 changed file
with
2063 addition
and
3 deletion
+2063
-3
tests/system-test/3-connectors/c#/TDengineDriver/TDengineDriver.cs
...tem-test/3-connectors/c#/TDengineDriver/TDengineDriver.cs
+405
-0
tests/system-test/3-connectors/c#/TDengineDriver/TDengineDriver.csproj
...test/3-connectors/c#/TDengineDriver/TDengineDriver.csproj
+7
-0
tests/system-test/3-connectors/c#/TDengineDriver/TaosBind.cs
tests/system-test/3-connectors/c#/TDengineDriver/TaosBind.cs
+336
-0
tests/system-test/3-connectors/c#/TDengineDriver/TaosMultiBind.cs
...stem-test/3-connectors/c#/TDengineDriver/TaosMultiBind.cs
+629
-0
tests/system-test/3-connectors/c#/stmtfunction/stmtfunction.cs
.../system-test/3-connectors/c#/stmtfunction/stmtfunction.cs
+668
-0
tests/system-test/3-connectors/c#/stmtfunction/stmtfunction.csproj
...tem-test/3-connectors/c#/stmtfunction/stmtfunction.csproj
+14
-0
tests/system-test/3-connectors/c#/test.sh
tests/system-test/3-connectors/c#/test.sh
+3
-0
tests/test-CI.sh
tests/test-CI.sh
+1
-3
未找到文件。
tests/system-test/3-connectors/c#/TDengineDriver/TDengineDriver.cs
0 → 100644
浏览文件 @
fda8a85e
/*
* Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
*
* This program is free software: you can use, redistribute, and/or modify
* it under the terms of the GNU Affero General Public License, version 3
* or later ("AGPL"), as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
using
System
;
using
System.Collections.Generic
;
using
System.Runtime.InteropServices
;
namespace
TDengineDriver
{
public
enum
TDengineDataType
{
TSDB_DATA_TYPE_NULL
=
0
,
// 1 bytes
TSDB_DATA_TYPE_BOOL
=
1
,
// 1 bytes
TSDB_DATA_TYPE_TINYINT
=
2
,
// 1 bytes
TSDB_DATA_TYPE_SMALLINT
=
3
,
// 2 bytes
TSDB_DATA_TYPE_INT
=
4
,
// 4 bytes
TSDB_DATA_TYPE_BIGINT
=
5
,
// 8 bytes
TSDB_DATA_TYPE_FLOAT
=
6
,
// 4 bytes
TSDB_DATA_TYPE_DOUBLE
=
7
,
// 8 bytes
TSDB_DATA_TYPE_BINARY
=
8
,
// string
TSDB_DATA_TYPE_TIMESTAMP
=
9
,
// 8 bytes
TSDB_DATA_TYPE_NCHAR
=
10
,
// unicode string
TSDB_DATA_TYPE_UTINYINT
=
11
,
// 1 byte
TSDB_DATA_TYPE_USMALLINT
=
12
,
// 2 bytes
TSDB_DATA_TYPE_UINT
=
13
,
// 4 bytes
TSDB_DATA_TYPE_UBIGINT
=
14
,
// 8 bytes
TSDB_DATA_TYPE_JSONTAG
=
15
//4096 bytes
}
public
enum
TDengineInitOption
{
TSDB_OPTION_LOCALE
=
0
,
TSDB_OPTION_CHARSET
=
1
,
TSDB_OPTION_TIMEZONE
=
2
,
TDDB_OPTION_CONFIGDIR
=
3
,
TDDB_OPTION_SHELL_ACTIVITY_TIMER
=
4
}
enum
TaosField
{
STRUCT_SIZE
=
68
,
NAME_LENGTH
=
65
,
TYPE_OFFSET
=
65
,
BYTES_OFFSET
=
66
,
}
public
class
TDengineMeta
{
public
string
name
;
public
short
size
;
public
byte
type
;
public
string
TypeName
()
{
switch
((
TDengineDataType
)
type
)
{
case
TDengineDataType
.
TSDB_DATA_TYPE_BOOL
:
return
"BOOL"
;
case
TDengineDataType
.
TSDB_DATA_TYPE_TINYINT
:
return
"TINYINT"
;
case
TDengineDataType
.
TSDB_DATA_TYPE_SMALLINT
:
return
"SMALLINT"
;
case
TDengineDataType
.
TSDB_DATA_TYPE_INT
:
return
"INT"
;
case
TDengineDataType
.
TSDB_DATA_TYPE_BIGINT
:
return
"BIGINT"
;
case
TDengineDataType
.
TSDB_DATA_TYPE_UTINYINT
:
return
"TINYINT UNSIGNED"
;
case
TDengineDataType
.
TSDB_DATA_TYPE_USMALLINT
:
return
"SMALLINT UNSIGNED"
;
case
TDengineDataType
.
TSDB_DATA_TYPE_UINT
:
return
"INT UNSIGNED"
;
case
TDengineDataType
.
TSDB_DATA_TYPE_UBIGINT
:
return
"BIGINT UNSIGNED"
;
case
TDengineDataType
.
TSDB_DATA_TYPE_FLOAT
:
return
"FLOAT"
;
case
TDengineDataType
.
TSDB_DATA_TYPE_DOUBLE
:
return
"DOUBLE"
;
case
TDengineDataType
.
TSDB_DATA_TYPE_BINARY
:
return
"STRING"
;
case
TDengineDataType
.
TSDB_DATA_TYPE_TIMESTAMP
:
return
"TIMESTAMP"
;
case
TDengineDataType
.
TSDB_DATA_TYPE_NCHAR
:
return
"NCHAR"
;
case
TDengineDataType
.
TSDB_DATA_TYPE_JSONTAG
:
return
"JSON"
;
default
:
return
"undefine"
;
}
}
}
[
StructLayout
(
LayoutKind
.
Sequential
,
CharSet
=
CharSet
.
Ansi
)]
public
struct
TAOS_BIND
{
// column type
public
int
buffer_type
;
// one column value
public
IntPtr
buffer
;
// unused
public
Int32
buffer_length
;
// actual value length in buffer
public
IntPtr
length
;
// indicates the column value is null or not
public
IntPtr
is_null
;
// unused
public
int
is_unsigned
;
// unused
public
IntPtr
error
;
public
Int64
u
;
public
uint
allocated
;
}
[
StructLayout
(
LayoutKind
.
Sequential
)]
public
struct
TAOS_MULTI_BIND
{
// column type
public
int
buffer_type
;
// array, one or more lines column value
public
IntPtr
buffer
;
//length of element in TAOS_MULTI_BIND.buffer (for binary and nchar it is the longest element's length)
public
ulong
buffer_length
;
//array, actual data length for each value
public
IntPtr
length
;
//array, indicates each column value is null or not
public
IntPtr
is_null
;
// line number, or the values number in buffer
public
int
num
;
}
public
class
TDengine
{
public
const
int
TSDB_CODE_SUCCESS
=
0
;
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_init"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
void
Init
();
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_cleanup"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
void
Cleanup
();
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_options"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
void
Options
(
int
option
,
string
value
);
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_connect"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
IntPtr
Connect
(
string
ip
,
string
user
,
string
password
,
string
db
,
short
port
);
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_errstr"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
private
IntPtr
taos_errstr
(
IntPtr
res
);
static
public
string
Error
(
IntPtr
res
)
{
IntPtr
errPtr
=
taos_errstr
(
res
);
return
Marshal
.
PtrToStringAnsi
(
errPtr
);
}
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_errno"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
int
ErrorNo
(
IntPtr
res
);
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_query"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
IntPtr
Query
(
IntPtr
conn
,
string
sqlstr
);
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_affected_rows"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
int
AffectRows
(
IntPtr
res
);
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_field_count"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
int
FieldCount
(
IntPtr
res
);
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_fetch_fields"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
private
IntPtr
taos_fetch_fields
(
IntPtr
res
);
static
public
List
<
TDengineMeta
>
FetchFields
(
IntPtr
res
)
{
// const int fieldSize = 68;
List
<
TDengineMeta
>
metas
=
new
List
<
TDengineMeta
>();
if
(
res
==
IntPtr
.
Zero
)
{
return
metas
;
}
int
fieldCount
=
FieldCount
(
res
);
IntPtr
fieldsPtr
=
taos_fetch_fields
(
res
);
for
(
int
i
=
0
;
i
<
fieldCount
;
++
i
)
{
int
offset
=
i
*
(
int
)
TaosField
.
STRUCT_SIZE
;
TDengineMeta
meta
=
new
TDengineMeta
();
meta
.
name
=
Marshal
.
PtrToStringAnsi
(
fieldsPtr
+
offset
);
meta
.
type
=
Marshal
.
ReadByte
(
fieldsPtr
+
offset
+
(
int
)
TaosField
.
TYPE_OFFSET
);
meta
.
size
=
Marshal
.
ReadInt16
(
fieldsPtr
+
offset
+
(
int
)
TaosField
.
BYTES_OFFSET
);
metas
.
Add
(
meta
);
}
return
metas
;
}
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_fetch_row"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
IntPtr
FetchRows
(
IntPtr
res
);
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_free_result"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
IntPtr
FreeResult
(
IntPtr
res
);
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_close"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
int
Close
(
IntPtr
taos
);
//get precision of restultset
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_result_precision"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
int
ResultPrecision
(
IntPtr
taos
);
//stmt APIs:
/// <summary>
/// init a TAOS_STMT object for later use.
/// </summary>
/// <param name="taos">a valid taos connection</param>
/// <returns>
/// Not NULL returned for success, NULL for failure. And it should be freed with taos_stmt_close.
/// </returns>
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_stmt_init"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
IntPtr
StmtInit
(
IntPtr
taos
);
/// <summary>
/// prepare a sql statement,'sql' should be a valid INSERT/SELECT statement.
/// </summary>
/// <param name="stmt">could be the value returned by 'StmtInit', that may be a valid object or NULL.</param>
/// <param name="sql">sql string,used to bind parameters with</param>
/// <param name="length">no used</param>
/// <returns>0 for success, non-zero for failure.</returns>
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_stmt_prepare"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
int
StmtPrepare
(
IntPtr
stmt
,
string
sql
);
/// <summary>
/// For INSERT only. Used to bind table name as a parmeter for the input stmt object.
/// </summary>
/// <param name="stmt">could be the value returned by 'StmtInit', that may be a valid object or NULL.</param>
/// <param name="name">table name you want to bind</param>
/// <returns>0 for success, non-zero for failure.</returns>
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_stmt_set_tbname"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
int
StmtSetTbname
(
IntPtr
stmt
,
string
name
);
/// <summary>
/// For INSERT only.
/// Set a table name for binding table name as parameter. Only used for binding all tables
/// in one stable, user application must call 'loadTableInfo' API to load all table
/// meta before calling this API. If the table meta is not cached locally, it will return error.
/// </summary>
/// <param name="stmt">could be the value returned by 'StmtInit', that may be a valid object or NULL.</param>
/// <param name="name">table name which is belong to an stable</param>
/// <returns>0 for success, non-zero for failure.</returns>
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_stmt_set_sub_tbname"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
int
StmtSetSubTbname
(
IntPtr
stmt
,
string
name
);
/// <summary>
/// For INSERT only.
/// set a table name for binding table name as parameter and tag values for all tag parameters.
/// </summary>
/// <param name="stmt">could be the value returned by 'StmtInit', that may be a valid object or NULL.</param>
/// <param name="name">use to set table name</param>
/// <param name="tags">
/// is an array contains all tag values,each item in the array represents a tag column's value.
/// the item number and sequence should keep consistence with that in stable tag definition.
/// </param>
/// <returns>0 for success, non-zero for failure.</returns>
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_stmt_set_tbname_tags"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
int
StmtSetTbnameTags
(
IntPtr
stmt
,
string
name
,
TAOS_BIND
[]
tags
);
/// <summary>
/// For both INSERT and SELECT.
/// bind a whole line data.
/// The usage of structure TAOS_BIND is the same with MYSQL_BIND in MySQL.
/// </summary>
/// <param name="stmt">could be the value returned by 'StmtInit', that may be a valid object or NULL.</param>
/// <param name="bind">
/// points to an array contains the whole line data.
/// the item number and sequence should keep consistence with columns in sql statement.
/// </param>
/// <returns>0 for success, non-zero for failure.</returns>
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_stmt_bind_param"
,
CallingConvention
=
CallingConvention
.
Cdecl
,
SetLastError
=
true
)]
static
extern
public
int
StmtBindParam
(
IntPtr
stmt
,
TAOS_BIND
[]
bind
);
/// <summary>
/// bind a single column's data, INTERNAL used and for INSERT only.
/// </summary>
/// <param name="stmt">could be the value returned by 'StmtInit', that may be a valid object or NULL.</param>
/// <param name="bind">points to a column's data which could be the one or more lines. </param>
/// <param name="colIdx">the column's index in prepared sql statement, it starts from 0.</param>
/// <returns>0 for success, non-zero for failure.</returns>
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_stmt_bind_single_param_batch"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
int
StmtBindSingleParamBatch
(
IntPtr
stmt
,
ref
TAOS_MULTI_BIND
bind
,
int
colIdx
);
/// <summary>
/// for INSERT only
/// bind one or multiple lines data. The parameter 'bind'
/// </summary>
/// <param name="stmt">could be the value returned by 'StmtInit', that may be a valid object or NULL.</param>
/// <param name="bind">
/// points to an array contains one or more lines data.Each item in array represents a column's value(s),
/// the item number and sequence should keep consistence with columns in sql statement.
/// </param>
/// <returns>0 for success, non-zero for failure.</returns>
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_stmt_bind_param_batch"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
int
StmtBindParamBatch
(
IntPtr
stmt
,
[
In
,
Out
]
TAOS_MULTI_BIND
[]
bind
);
/// <summary>
/// For INSERT only.
/// add all current bound parameters to batch process. Must be called after each call to
/// StmtBindParam/StmtBindSingleParamBatch, or all columns binds for one or more lines
/// with StmtBindSingleParamBatch. User application can call any bind parameter
/// API again to bind more data lines after calling to this API.
/// </summary>
/// <param name="stmt">could be the value returned by 'StmtInit', that may be a valid object or NULL.</param>
/// <returns>0 for success, non-zero for failure.</returns>
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_stmt_add_batch"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
int
StmtAddBatch
(
IntPtr
stmt
);
/// <summary>
/// actually execute the INSERT/SELECT sql statement.
/// User application can continue to bind new data after calling to this API.
/// </summary>
/// <param name="stmt">could be the value returned by 'StmtInit', that may be a valid object or NULL.</param>
/// <returns></returns>
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_stmt_execute"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
int
StmtExecute
(
IntPtr
stmt
);
/// <summary>
/// For SELECT only,getting the query result. User application should free it with API 'FreeResult' at the end.
/// </summary>
/// <param name="stmt">could be the value returned by 'StmtInit', that may be a valid object or NULL.</param>
/// <returns>Not NULL for success, NULL for failure.</returns>
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_stmt_use_result"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
IntPtr
StmtUseResult
(
IntPtr
stmt
);
/// <summary>
/// close STMT object and free resources.
/// </summary>
/// <param name="stmt">could be the value returned by 'StmtInit', that may be a valid object or NULL.</param>
/// <returns>0 for success, non-zero for failure.</returns>
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_stmt_close"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
int
StmtClose
(
IntPtr
stmt
);
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_load_table_info"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
/// <summary>
/// user application must call this API to load all tables meta,
/// </summary>
/// <param name="taos">taos connection</param>
/// <param name="tableList">tablelist</param>
/// <returns></returns>
static
extern
private
int
LoadTableInfoDll
(
IntPtr
taos
,
string
tableList
);
/// <summary>
/// user application call this API to load all tables meta,this method call the native
/// method LoadTableInfoDll.
/// this method must be called before StmtSetSubTbname(IntPtr stmt, string name);
/// </summary>
/// <param name="taos">taos connection</param>
/// <param name="tableList">tables need to load meta info are form in an array</param>
/// <returns></returns>
static
public
int
LoadTableInfo
(
IntPtr
taos
,
string
[]
tableList
)
{
string
listStr
=
string
.
Join
(
","
,
tableList
);
return
LoadTableInfoDll
(
taos
,
listStr
);
}
/// <summary>
/// get detail error message when got failure for any stmt API call. If not failure, the result
/// returned in this API is unknown.
/// </summary>
/// <param name="stmt">could be the value returned by 'StmtInit', that may be a valid object or NULL.</param>
/// <returns>piont the error message</returns>
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_stmt_errstr"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
private
IntPtr
StmtErrPtr
(
IntPtr
stmt
);
/// <summary>
/// get detail error message when got failure for any stmt API call. If not failure, the result
/// returned in this API is unknown.
/// </summary>
/// <param name="stmt">could be the value returned by 'StmtInit', that may be a valid object or NULL.</param>
/// <returns>error string</returns>
static
public
string
StmtErrorStr
(
IntPtr
stmt
)
{
IntPtr
stmtErrPrt
=
StmtErrPtr
(
stmt
);
return
Marshal
.
PtrToStringAnsi
(
stmtErrPrt
);
}
[
DllImport
(
"taos"
,
EntryPoint
=
"taos_fetch_lengths"
,
CallingConvention
=
CallingConvention
.
Cdecl
)]
static
extern
public
IntPtr
FetchLengths
(
IntPtr
taos
);
}
}
tests/system-test/3-connectors/c#/TDengineDriver/TDengineDriver.csproj
0 → 100644
浏览文件 @
fda8a85e
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFramework>net5.0</TargetFramework>
</PropertyGroup>
</Project>
tests/system-test/3-connectors/c#/TDengineDriver/TaosBind.cs
0 → 100644
浏览文件 @
fda8a85e
using
System
;
using
System.Runtime.InteropServices
;
using
System.Text
;
namespace
TDengineDriver
{
/// <summary>
/// this class used to get an instance of struct of TAO_BIND or TAOS_MULTI_BIND
/// And the instance is corresponding with TDengine data type. For example, calling
/// "bindBinary" will return a TAOS_BIND object that is corresponding with TDengine's
/// binary type.
/// </summary>
public
class
TaosBind
{
public
static
TAOS_BIND
BindBool
(
bool
val
)
{
TAOS_BIND
bind
=
new
TAOS_BIND
();
byte
[]
boolByteArr
=
BitConverter
.
GetBytes
(
val
);
int
boolByteArrSize
=
Marshal
.
SizeOf
(
boolByteArr
[
0
])
*
boolByteArr
.
Length
;
IntPtr
bo
=
Marshal
.
AllocHGlobal
(
1
);
Marshal
.
Copy
(
boolByteArr
,
0
,
bo
,
boolByteArr
.
Length
);
int
length
=
sizeof
(
Boolean
);
IntPtr
lengPtr
=
Marshal
.
AllocHGlobal
(
sizeof
(
int
));
Marshal
.
WriteInt32
(
lengPtr
,
length
);
bind
.
buffer_type
=
(
int
)
TDengineDataType
.
TSDB_DATA_TYPE_BOOL
;
bind
.
buffer
=
bo
;
bind
.
buffer_length
=
length
;
bind
.
length
=
lengPtr
;
bind
.
is_null
=
IntPtr
.
Zero
;
return
bind
;
}
public
static
TAOS_BIND
BindTinyInt
(
sbyte
val
)
{
TAOS_BIND
bind
=
new
TAOS_BIND
();
byte
[]
tinyIntByteArr
=
BitConverter
.
GetBytes
(
val
);
int
tinyIntByteArrSize
=
Marshal
.
SizeOf
(
tinyIntByteArr
[
0
])
*
tinyIntByteArr
.
Length
;
IntPtr
uManageTinyInt
=
Marshal
.
AllocHGlobal
(
tinyIntByteArrSize
);
Marshal
.
Copy
(
tinyIntByteArr
,
0
,
uManageTinyInt
,
tinyIntByteArr
.
Length
);
int
length
=
sizeof
(
sbyte
);
IntPtr
lengPtr
=
Marshal
.
AllocHGlobal
(
sizeof
(
int
));
Marshal
.
WriteInt32
(
lengPtr
,
length
);
bind
.
buffer_type
=
(
int
)
TDengineDataType
.
TSDB_DATA_TYPE_TINYINT
;
bind
.
buffer
=
uManageTinyInt
;
bind
.
buffer_length
=
length
;
bind
.
length
=
lengPtr
;
bind
.
is_null
=
IntPtr
.
Zero
;
return
bind
;
}
public
static
TAOS_BIND
BindSmallInt
(
short
val
)
{
TAOS_BIND
bind
=
new
TAOS_BIND
();
IntPtr
uManageSmallInt
=
Marshal
.
AllocHGlobal
(
sizeof
(
short
));
Marshal
.
WriteInt16
(
uManageSmallInt
,
val
);
int
length
=
sizeof
(
short
);
IntPtr
lengPtr
=
Marshal
.
AllocHGlobal
(
sizeof
(
int
));
Marshal
.
WriteInt32
(
lengPtr
,
length
);
bind
.
buffer_type
=
(
int
)
TDengineDataType
.
TSDB_DATA_TYPE_SMALLINT
;
bind
.
buffer
=
uManageSmallInt
;
bind
.
buffer_length
=
length
;
bind
.
length
=
lengPtr
;
bind
.
is_null
=
IntPtr
.
Zero
;
return
bind
;
}
public
static
TAOS_BIND
BindInt
(
int
val
)
{
TAOS_BIND
bind
=
new
TAOS_BIND
();
IntPtr
uManageInt
=
Marshal
.
AllocHGlobal
(
sizeof
(
int
));
Marshal
.
WriteInt32
(
uManageInt
,
val
);
int
length
=
sizeof
(
int
);
IntPtr
lengPtr
=
Marshal
.
AllocHGlobal
(
sizeof
(
int
));
Marshal
.
WriteInt32
(
lengPtr
,
length
);
bind
.
buffer_type
=
(
int
)
TDengineDataType
.
TSDB_DATA_TYPE_INT
;
bind
.
buffer
=
uManageInt
;
bind
.
buffer_length
=
length
;
bind
.
length
=
lengPtr
;
bind
.
is_null
=
IntPtr
.
Zero
;
return
bind
;
}
public
static
TAOS_BIND
BindBigInt
(
long
val
)
{
TAOS_BIND
bind
=
new
TAOS_BIND
();
IntPtr
uManageBigInt
=
Marshal
.
AllocHGlobal
(
sizeof
(
long
));
Marshal
.
WriteInt64
(
uManageBigInt
,
val
);
int
length
=
sizeof
(
long
);
IntPtr
lengPtr
=
Marshal
.
AllocHGlobal
(
sizeof
(
int
));
Marshal
.
WriteInt32
(
lengPtr
,
length
);
bind
.
buffer_type
=
(
int
)
TDengineDataType
.
TSDB_DATA_TYPE_BIGINT
;
bind
.
buffer
=
uManageBigInt
;
bind
.
buffer_length
=
length
;
bind
.
length
=
lengPtr
;
bind
.
is_null
=
IntPtr
.
Zero
;
return
bind
;
}
public
static
TAOS_BIND
BindUTinyInt
(
byte
val
)
{
TAOS_BIND
bind
=
new
TAOS_BIND
();
IntPtr
uManageTinyInt
=
Marshal
.
AllocHGlobal
(
sizeof
(
byte
));
Marshal
.
WriteByte
(
uManageTinyInt
,
val
);
int
length
=
sizeof
(
byte
);
IntPtr
lengPtr
=
Marshal
.
AllocHGlobal
(
sizeof
(
int
));
Marshal
.
WriteInt32
(
lengPtr
,
length
);
bind
.
buffer_type
=
(
int
)
TDengineDataType
.
TSDB_DATA_TYPE_UTINYINT
;
bind
.
buffer
=
uManageTinyInt
;
bind
.
buffer_length
=
length
;
bind
.
length
=
lengPtr
;
bind
.
is_null
=
IntPtr
.
Zero
;
return
bind
;
}
public
static
TAOS_BIND
BindUSmallInt
(
UInt16
val
)
{
TAOS_BIND
bind
=
new
TAOS_BIND
();
byte
[]
uSmallIntByteArr
=
BitConverter
.
GetBytes
(
val
);
int
usmallSize
=
Marshal
.
SizeOf
(
uSmallIntByteArr
[
0
])
*
uSmallIntByteArr
.
Length
;
IntPtr
uManageUnsignSmallInt
=
Marshal
.
AllocHGlobal
(
usmallSize
);
Marshal
.
Copy
(
uSmallIntByteArr
,
0
,
uManageUnsignSmallInt
,
uSmallIntByteArr
.
Length
);
int
length
=
sizeof
(
UInt16
);
IntPtr
lengPtr
=
Marshal
.
AllocHGlobal
(
sizeof
(
int
));
Marshal
.
WriteInt32
(
lengPtr
,
length
);
bind
.
buffer_type
=
(
int
)
TDengineDataType
.
TSDB_DATA_TYPE_USMALLINT
;
bind
.
buffer
=
uManageUnsignSmallInt
;
bind
.
buffer_length
=
length
;
bind
.
length
=
lengPtr
;
bind
.
is_null
=
IntPtr
.
Zero
;
return
bind
;
}
public
static
TAOS_BIND
BindUInt
(
uint
val
)
{
TAOS_BIND
bind
=
new
TAOS_BIND
();
byte
[]
uManageIntByteArr
=
BitConverter
.
GetBytes
(
val
);
int
usmallSize
=
Marshal
.
SizeOf
(
uManageIntByteArr
[
0
])
*
uManageIntByteArr
.
Length
;
IntPtr
uManageInt
=
Marshal
.
AllocHGlobal
(
usmallSize
);
Marshal
.
Copy
(
uManageIntByteArr
,
0
,
uManageInt
,
uManageIntByteArr
.
Length
);
int
length
=
sizeof
(
uint
);
IntPtr
lengPtr
=
Marshal
.
AllocHGlobal
(
sizeof
(
int
));
Marshal
.
WriteInt32
(
lengPtr
,
length
);
bind
.
buffer_type
=
(
int
)
TDengineDataType
.
TSDB_DATA_TYPE_UINT
;
bind
.
buffer
=
uManageInt
;
bind
.
buffer_length
=
length
;
bind
.
length
=
lengPtr
;
bind
.
is_null
=
IntPtr
.
Zero
;
return
bind
;
}
public
static
TAOS_BIND
BindUBigInt
(
ulong
val
)
{
TAOS_BIND
bind
=
new
TAOS_BIND
();
byte
[]
uManageBigIntByteArr
=
BitConverter
.
GetBytes
(
val
);
int
usmallSize
=
Marshal
.
SizeOf
(
uManageBigIntByteArr
[
0
])
*
uManageBigIntByteArr
.
Length
;
IntPtr
uManageBigInt
=
Marshal
.
AllocHGlobal
(
usmallSize
);
Marshal
.
Copy
(
uManageBigIntByteArr
,
0
,
uManageBigInt
,
uManageBigIntByteArr
.
Length
);
int
length
=
sizeof
(
ulong
);
IntPtr
lengPtr
=
Marshal
.
AllocHGlobal
(
sizeof
(
int
));
Marshal
.
WriteInt32
(
lengPtr
,
length
);
bind
.
buffer_type
=
(
int
)
TDengineDataType
.
TSDB_DATA_TYPE_UBIGINT
;
bind
.
buffer
=
uManageBigInt
;
bind
.
buffer_length
=
length
;
bind
.
length
=
lengPtr
;
bind
.
is_null
=
IntPtr
.
Zero
;
return
bind
;
}
public
static
TAOS_BIND
BindFloat
(
float
val
)
{
TAOS_BIND
bind
=
new
TAOS_BIND
();
byte
[]
floatByteArr
=
BitConverter
.
GetBytes
(
val
);
int
floatByteArrSize
=
Marshal
.
SizeOf
(
floatByteArr
[
0
])
*
floatByteArr
.
Length
;
IntPtr
uManageFloat
=
Marshal
.
AllocHGlobal
(
floatByteArrSize
);
Marshal
.
Copy
(
floatByteArr
,
0
,
uManageFloat
,
floatByteArr
.
Length
);
int
length
=
sizeof
(
float
);
IntPtr
lengPtr
=
Marshal
.
AllocHGlobal
(
sizeof
(
int
));
Marshal
.
WriteInt32
(
lengPtr
,
length
);
bind
.
buffer_type
=
(
int
)
TDengineDataType
.
TSDB_DATA_TYPE_FLOAT
;
bind
.
buffer
=
uManageFloat
;
bind
.
buffer_length
=
length
;
bind
.
length
=
lengPtr
;
bind
.
is_null
=
IntPtr
.
Zero
;
return
bind
;
}
public
static
TAOS_BIND
BindDouble
(
Double
val
)
{
TAOS_BIND
bind
=
new
TAOS_BIND
();
byte
[]
doubleByteArr
=
BitConverter
.
GetBytes
(
val
);
int
doubleByteArrSize
=
Marshal
.
SizeOf
(
doubleByteArr
[
0
])
*
doubleByteArr
.
Length
;
IntPtr
uManageDouble
=
Marshal
.
AllocHGlobal
(
doubleByteArrSize
);
Marshal
.
Copy
(
doubleByteArr
,
0
,
uManageDouble
,
doubleByteArr
.
Length
);
int
length
=
sizeof
(
Double
);
IntPtr
lengPtr
=
Marshal
.
AllocHGlobal
(
sizeof
(
int
));
Marshal
.
WriteInt32
(
lengPtr
,
length
);
bind
.
buffer_type
=
(
int
)
TDengineDataType
.
TSDB_DATA_TYPE_DOUBLE
;
bind
.
buffer
=
uManageDouble
;
bind
.
buffer_length
=
length
;
bind
.
length
=
lengPtr
;
bind
.
is_null
=
IntPtr
.
Zero
;
return
bind
;
}
public
static
TAOS_BIND
BindBinary
(
String
val
)
{
TAOS_BIND
bind
=
new
TAOS_BIND
();
IntPtr
umanageBinary
=
Marshal
.
StringToHGlobalAnsi
(
val
);
var
strToBytes
=
System
.
Text
.
Encoding
.
Default
.
GetBytes
(
val
);
int
leng
=
strToBytes
.
Length
;
IntPtr
lenPtr
=
Marshal
.
AllocHGlobal
(
sizeof
(
ulong
));
Marshal
.
WriteInt64
(
lenPtr
,
leng
);
bind
.
buffer_type
=
(
int
)
TDengineDataType
.
TSDB_DATA_TYPE_BINARY
;
bind
.
buffer
=
umanageBinary
;
bind
.
buffer_length
=
leng
;
bind
.
length
=
lenPtr
;
bind
.
is_null
=
IntPtr
.
Zero
;
return
bind
;
}
public
static
TAOS_BIND
BindNchar
(
String
val
)
{
TAOS_BIND
bind
=
new
TAOS_BIND
();
var
strToBytes
=
System
.
Text
.
Encoding
.
Default
.
GetBytes
(
val
);
IntPtr
umanageNchar
=
(
IntPtr
)
Marshal
.
StringToHGlobalAnsi
(
val
);
int
leng
=
strToBytes
.
Length
;
IntPtr
lenPtr
=
Marshal
.
AllocHGlobal
(
sizeof
(
ulong
));
Marshal
.
WriteInt64
(
lenPtr
,
leng
);
bind
.
buffer_type
=
(
int
)
TDengineDataType
.
TSDB_DATA_TYPE_NCHAR
;
bind
.
buffer
=
umanageNchar
;
bind
.
buffer_length
=
leng
;
bind
.
length
=
lenPtr
;
bind
.
is_null
=
IntPtr
.
Zero
;
return
bind
;
}
public
static
TAOS_BIND
BindNil
()
{
TAOS_BIND
bind
=
new
TAOS_BIND
();
int
isNull
=
1
;
//IntPtr.Size;
IntPtr
lenPtr
=
Marshal
.
AllocHGlobal
(
sizeof
(
int
));
Marshal
.
WriteInt32
(
lenPtr
,
isNull
);
bind
.
buffer_type
=
(
int
)
TDengineDataType
.
TSDB_DATA_TYPE_NULL
;
bind
.
is_null
=
lenPtr
;
return
bind
;
}
public
static
TAOS_BIND
BindTimestamp
(
long
ts
)
{
TAOS_BIND
bind
=
new
TAOS_BIND
();
IntPtr
uManageTs
=
Marshal
.
AllocHGlobal
(
sizeof
(
long
));
Marshal
.
WriteInt64
(
uManageTs
,
ts
);
int
length
=
sizeof
(
long
);
IntPtr
lengPtr
=
Marshal
.
AllocHGlobal
(
4
);
Marshal
.
WriteInt32
(
lengPtr
,
length
);
bind
.
buffer_type
=
(
int
)
TDengineDataType
.
TSDB_DATA_TYPE_TIMESTAMP
;
bind
.
buffer
=
uManageTs
;
bind
.
buffer_length
=
length
;
bind
.
length
=
lengPtr
;
bind
.
is_null
=
IntPtr
.
Zero
;
return
bind
;
}
public
static
void
FreeTaosBind
(
TAOS_BIND
[]
binds
)
{
foreach
(
TAOS_BIND
bind
in
binds
)
{
Marshal
.
FreeHGlobal
(
bind
.
buffer
);
Marshal
.
FreeHGlobal
(
bind
.
length
);
if
(
bind
.
is_null
!=
IntPtr
.
Zero
)
{
// Console.WriteLine(bind.is_null);
Marshal
.
FreeHGlobal
(
bind
.
is_null
);
}
}
}
}
}
\ No newline at end of file
tests/system-test/3-connectors/c#/TDengineDriver/TaosMultiBind.cs
0 → 100644
浏览文件 @
fda8a85e
此差异已折叠。
点击以展开。
tests/system-test/3-connectors/c#/stmtfunction/stmtfunction.cs
0 → 100644
浏览文件 @
fda8a85e
此差异已折叠。
点击以展开。
tests/system-test/3-connectors/c#/stmtfunction/stmtfunction.csproj
0 → 100644
浏览文件 @
fda8a85e
<Project Sdk="Microsoft.NET.Sdk">
<ItemGroup>
<ProjectReference Include="..\TDengineDriver\TDengineDriver.csproj" />
</ItemGroup>
<PropertyGroup>
<OutputType>Exe</OutputType>
<TargetFramework>net5.0</TargetFramework>
<!-- <ImplicitUsings>enable</ImplicitUsings>
<Nullable>enable</Nullable> -->
</PropertyGroup>
</Project>
tests/system-test/3-connectors/c#/test.sh
浏览文件 @
fda8a85e
...
...
@@ -26,6 +26,9 @@ dotnet run --project C#checker/C#checker.csproj
dotnet run
--project
TDengineTest/TDengineTest.csproj
dotnet run
--project
schemaless/schemaless.csproj
cd
${
WKC
}
/tests/system-test/3-connectors/c#/stmtfunction
dotnet run
||
exit
1
cd
${
WKC
}
/tests/examples/C#/taosdemo
dotnet build
-c
Release
tree |
true
...
...
tests/test-CI.sh
浏览文件 @
fda8a85e
...
...
@@ -124,11 +124,9 @@ function runPyCaseOneByOnefq() {
else
echo
$line
if
[[
$line
=
~ ^bash.
*
]]
;
then
# $line > case.log 2>&1 || cat case.log && exit 8
# cat case.log
$line
>
case
.log 2>&1
if
[
$?
-ne
0
]
;
then
cat
case
.log
if
[
$?
-ne
0
]
;
then
exit
8
fi
fi
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录