[TD-4944]:c# connector nanosecond support (#7041)
* [TD-4944]:c# connector nanosecond support * [TD-4944]:c# connector nanosecond support * [TD-4944]:c# connector nanosecond support fix indent
This commit is contained in:
parent
61fb774237
commit
8ad7443822
|
@ -163,5 +163,8 @@ namespace TDengineDriver
|
||||||
|
|
||||||
[DllImport("taos", EntryPoint = "taos_close", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_close", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern public int Close(IntPtr taos);
|
static extern public int Close(IntPtr taos);
|
||||||
|
//get precision£¬in parameter restultset
|
||||||
|
[DllImport("taos", EntryPoint = "taos_result_precision", CallingConvention = CallingConvention.Cdecl)]
|
||||||
|
static extern public int ResultPrecision(IntPtr taos);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,7 +33,7 @@ namespace TDengineDriver
|
||||||
//sql parameters
|
//sql parameters
|
||||||
private string dbName;
|
private string dbName;
|
||||||
private string tbName;
|
private string tbName;
|
||||||
|
private string precision;
|
||||||
|
|
||||||
private bool isInsertData;
|
private bool isInsertData;
|
||||||
private bool isQueryData;
|
private bool isQueryData;
|
||||||
|
@ -61,9 +61,9 @@ namespace TDengineDriver
|
||||||
tester.checkInsert();
|
tester.checkInsert();
|
||||||
tester.checkSelect();
|
tester.checkSelect();
|
||||||
tester.checkDropTable();
|
tester.checkDropTable();
|
||||||
|
tester.dropDatabase();
|
||||||
tester.CloseConnection();
|
tester.CloseConnection();
|
||||||
|
tester.cleanup();
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -156,7 +156,9 @@ namespace TDengineDriver
|
||||||
Console.WriteLine("{0:G}{1:G}{2:G}", indent, indent, "How many rows to insert, default is 100");
|
Console.WriteLine("{0:G}{1:G}{2:G}", indent, indent, "How many rows to insert, default is 100");
|
||||||
Console.WriteLine("{0:G}{1:G}", indent, "-c");
|
Console.WriteLine("{0:G}{1:G}", indent, "-c");
|
||||||
Console.WriteLine("{0:G}{1:G}{2:G}", indent, indent, "Configuration directory");
|
Console.WriteLine("{0:G}{1:G}{2:G}", indent, indent, "Configuration directory");
|
||||||
|
//
|
||||||
|
Console.WriteLine("{0:G}{1:G}", indent, "-ps");
|
||||||
|
Console.WriteLine("{0:G}{1:G}{2:G}", indent, indent, "Configurate db precision,default millisecond");
|
||||||
ExitProgram();
|
ExitProgram();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -168,9 +170,9 @@ namespace TDengineDriver
|
||||||
host = this.GetArgumentAsString(argv, "-h", "127.0.0.1");
|
host = this.GetArgumentAsString(argv, "-h", "127.0.0.1");
|
||||||
user = this.GetArgumentAsString(argv, "-u", "root");
|
user = this.GetArgumentAsString(argv, "-u", "root");
|
||||||
password = this.GetArgumentAsString(argv, "-p", "taosdata");
|
password = this.GetArgumentAsString(argv, "-p", "taosdata");
|
||||||
dbName = this.GetArgumentAsString(argv, "-db", "test");
|
dbName = this.GetArgumentAsString(argv, "-d", "test");
|
||||||
tbName = this.GetArgumentAsString(argv, "-s", "weather");
|
tbName = this.GetArgumentAsString(argv, "-s", "weather");
|
||||||
|
precision = this.GetArgumentAsString(argv, "-ps", "ms");
|
||||||
isInsertData = this.GetArgumentAsLong(argv, "-w", 0, 1, 1) != 0;
|
isInsertData = this.GetArgumentAsLong(argv, "-w", 0, 1, 1) != 0;
|
||||||
isQueryData = this.GetArgumentAsLong(argv, "-r", 0, 1, 1) != 0;
|
isQueryData = this.GetArgumentAsLong(argv, "-r", 0, 1, 1) != 0;
|
||||||
tableCount = this.GetArgumentAsLong(argv, "-n", 1, 10000, 10);
|
tableCount = this.GetArgumentAsLong(argv, "-n", 1, 10000, 10);
|
||||||
|
@ -183,6 +185,7 @@ namespace TDengineDriver
|
||||||
{
|
{
|
||||||
TDengine.Options((int)TDengineInitOption.TDDB_OPTION_CONFIGDIR, this.configDir);
|
TDengine.Options((int)TDengineInitOption.TDDB_OPTION_CONFIGDIR, this.configDir);
|
||||||
TDengine.Options((int)TDengineInitOption.TDDB_OPTION_SHELL_ACTIVITY_TIMER, "60");
|
TDengine.Options((int)TDengineInitOption.TDDB_OPTION_SHELL_ACTIVITY_TIMER, "60");
|
||||||
|
Console.WriteLine("init...");
|
||||||
TDengine.Init();
|
TDengine.Init();
|
||||||
Console.WriteLine("get connection starting...");
|
Console.WriteLine("get connection starting...");
|
||||||
}
|
}
|
||||||
|
@ -204,7 +207,7 @@ namespace TDengineDriver
|
||||||
public void createDatabase()
|
public void createDatabase()
|
||||||
{
|
{
|
||||||
StringBuilder sql = new StringBuilder();
|
StringBuilder sql = new StringBuilder();
|
||||||
sql.Append("create database if not exists ").Append(this.dbName);
|
sql.Append("create database if not exists ").Append(this.dbName).Append(" precision '").Append(this.precision).Append("'");
|
||||||
execute(sql.ToString());
|
execute(sql.ToString());
|
||||||
}
|
}
|
||||||
public void useDatabase()
|
public void useDatabase()
|
||||||
|
@ -216,8 +219,8 @@ namespace TDengineDriver
|
||||||
public void checkSelect()
|
public void checkSelect()
|
||||||
{
|
{
|
||||||
StringBuilder sql = new StringBuilder();
|
StringBuilder sql = new StringBuilder();
|
||||||
sql.Append("select * from test.weather");
|
sql.Append("select * from ").Append(this.dbName).Append(".").Append(this.tbName);
|
||||||
execute(sql.ToString());
|
ExecuteQuery(sql.ToString());
|
||||||
}
|
}
|
||||||
public void createTable()
|
public void createTable()
|
||||||
{
|
{
|
||||||
|
@ -228,7 +231,7 @@ namespace TDengineDriver
|
||||||
public void checkInsert()
|
public void checkInsert()
|
||||||
{
|
{
|
||||||
StringBuilder sql = new StringBuilder();
|
StringBuilder sql = new StringBuilder();
|
||||||
sql.Append("insert into test.weather (ts, temperature, humidity) values(now, 20.5, 34)");
|
sql.Append("insert into ").Append(this.dbName).Append(".").Append(this.tbName).Append("(ts, temperature, humidity) values(now, 20.5, 34)");
|
||||||
execute(sql.ToString());
|
execute(sql.ToString());
|
||||||
}
|
}
|
||||||
public void checkDropTable()
|
public void checkDropTable()
|
||||||
|
@ -237,6 +240,12 @@ namespace TDengineDriver
|
||||||
sql.Append("drop table if exists ").Append(this.dbName).Append(".").Append(this.tbName).Append("");
|
sql.Append("drop table if exists ").Append(this.dbName).Append(".").Append(this.tbName).Append("");
|
||||||
execute(sql.ToString());
|
execute(sql.ToString());
|
||||||
}
|
}
|
||||||
|
public void dropDatabase()
|
||||||
|
{
|
||||||
|
StringBuilder sql = new StringBuilder();
|
||||||
|
sql.Append("drop database if exists ").Append(this.dbName);
|
||||||
|
execute(sql.ToString());
|
||||||
|
}
|
||||||
public void execute(string sql)
|
public void execute(string sql)
|
||||||
{
|
{
|
||||||
DateTime dt1 = DateTime.Now;
|
DateTime dt1 = DateTime.Now;
|
||||||
|
@ -266,6 +275,7 @@ namespace TDengineDriver
|
||||||
DateTime dt1 = DateTime.Now;
|
DateTime dt1 = DateTime.Now;
|
||||||
long queryRows = 0;
|
long queryRows = 0;
|
||||||
IntPtr res = TDengine.Query(conn, sql);
|
IntPtr res = TDengine.Query(conn, sql);
|
||||||
|
getPrecision(res);
|
||||||
if ((res == IntPtr.Zero) || (TDengine.ErrorNo(res) != 0))
|
if ((res == IntPtr.Zero) || (TDengine.ErrorNo(res) != 0))
|
||||||
{
|
{
|
||||||
Console.Write(sql.ToString() + " failure, ");
|
Console.Write(sql.ToString() + " failure, ");
|
||||||
|
@ -379,8 +389,31 @@ namespace TDengineDriver
|
||||||
|
|
||||||
static void ExitProgram()
|
static void ExitProgram()
|
||||||
{
|
{
|
||||||
TDengine.Cleanup();
|
|
||||||
System.Environment.Exit(0);
|
System.Environment.Exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void cleanup()
|
||||||
|
{
|
||||||
|
Console.WriteLine("clean up...");
|
||||||
|
System.Environment.Exit(0);
|
||||||
|
}
|
||||||
|
// method to get db precision
|
||||||
|
public void getPrecision(IntPtr res)
|
||||||
|
{
|
||||||
|
int psc=TDengine.ResultPrecision(res);
|
||||||
|
switch(psc)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
Console.WriteLine("db:[{0:G}]'s precision is {1:G}",this.dbName,"millisecond");
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
Console.WriteLine("db:[{0:G}]'s precision is {1:G}",this.dbName,"microsecond");
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
Console.WriteLine("db:[{0:G}]'s precision is {1:G}",this.dbName,"nanosecond");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,7 +19,8 @@ using System.Runtime.InteropServices;
|
||||||
|
|
||||||
namespace TDengineDriver
|
namespace TDengineDriver
|
||||||
{
|
{
|
||||||
enum TDengineDataType {
|
enum TDengineDataType
|
||||||
|
{
|
||||||
TSDB_DATA_TYPE_NULL = 0, // 1 bytes
|
TSDB_DATA_TYPE_NULL = 0, // 1 bytes
|
||||||
TSDB_DATA_TYPE_BOOL = 1, // 1 bytes
|
TSDB_DATA_TYPE_BOOL = 1, // 1 bytes
|
||||||
TSDB_DATA_TYPE_TINYINT = 2, // 1 bytes
|
TSDB_DATA_TYPE_TINYINT = 2, // 1 bytes
|
||||||
|
@ -30,7 +31,11 @@ namespace TDengineDriver
|
||||||
TSDB_DATA_TYPE_DOUBLE = 7, // 8 bytes
|
TSDB_DATA_TYPE_DOUBLE = 7, // 8 bytes
|
||||||
TSDB_DATA_TYPE_BINARY = 8, // string
|
TSDB_DATA_TYPE_BINARY = 8, // string
|
||||||
TSDB_DATA_TYPE_TIMESTAMP = 9,// 8 bytes
|
TSDB_DATA_TYPE_TIMESTAMP = 9,// 8 bytes
|
||||||
TSDB_DATA_TYPE_NCHAR = 10 // unicode string
|
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
|
||||||
}
|
}
|
||||||
|
|
||||||
enum TDengineInitOption
|
enum TDengineInitOption
|
||||||
|
@ -52,15 +57,23 @@ namespace TDengineDriver
|
||||||
switch ((TDengineDataType)type)
|
switch ((TDengineDataType)type)
|
||||||
{
|
{
|
||||||
case TDengineDataType.TSDB_DATA_TYPE_BOOL:
|
case TDengineDataType.TSDB_DATA_TYPE_BOOL:
|
||||||
return "BOOLEAN";
|
return "BOOL";
|
||||||
case TDengineDataType.TSDB_DATA_TYPE_TINYINT:
|
case TDengineDataType.TSDB_DATA_TYPE_TINYINT:
|
||||||
return "BYTE";
|
return "TINYINT";
|
||||||
case TDengineDataType.TSDB_DATA_TYPE_SMALLINT:
|
case TDengineDataType.TSDB_DATA_TYPE_SMALLINT:
|
||||||
return "SHORT";
|
return "SMALLINT";
|
||||||
case TDengineDataType.TSDB_DATA_TYPE_INT:
|
case TDengineDataType.TSDB_DATA_TYPE_INT:
|
||||||
return "INT";
|
return "INT";
|
||||||
case TDengineDataType.TSDB_DATA_TYPE_BIGINT:
|
case TDengineDataType.TSDB_DATA_TYPE_BIGINT:
|
||||||
return "LONG";
|
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:
|
case TDengineDataType.TSDB_DATA_TYPE_FLOAT:
|
||||||
return "FLOAT";
|
return "FLOAT";
|
||||||
case TDengineDataType.TSDB_DATA_TYPE_DOUBLE:
|
case TDengineDataType.TSDB_DATA_TYPE_DOUBLE:
|
||||||
|
@ -81,19 +94,19 @@ namespace TDengineDriver
|
||||||
{
|
{
|
||||||
public const int TSDB_CODE_SUCCESS = 0;
|
public const int TSDB_CODE_SUCCESS = 0;
|
||||||
|
|
||||||
[DllImport("taos.dll", EntryPoint = "taos_init", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_init", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern public void Init();
|
static extern public void Init();
|
||||||
|
|
||||||
[DllImport("taos.dll", EntryPoint = "taos_cleanup", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_cleanup", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern public void Cleanup();
|
static extern public void Cleanup();
|
||||||
|
|
||||||
[DllImport("taos.dll", EntryPoint = "taos_options", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_options", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern public void Options(int option, string value);
|
static extern public void Options(int option, string value);
|
||||||
|
|
||||||
[DllImport("taos.dll", EntryPoint = "taos_connect", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_connect", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern public IntPtr Connect(string ip, string user, string password, string db, short port);
|
static extern public IntPtr Connect(string ip, string user, string password, string db, short port);
|
||||||
|
|
||||||
[DllImport("taos.dll", EntryPoint = "taos_errstr", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_errstr", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern private IntPtr taos_errstr(IntPtr res);
|
static extern private IntPtr taos_errstr(IntPtr res);
|
||||||
static public string Error(IntPtr res)
|
static public string Error(IntPtr res)
|
||||||
{
|
{
|
||||||
|
@ -101,19 +114,19 @@ namespace TDengineDriver
|
||||||
return Marshal.PtrToStringAnsi(errPtr);
|
return Marshal.PtrToStringAnsi(errPtr);
|
||||||
}
|
}
|
||||||
|
|
||||||
[DllImport("taos.dll", EntryPoint = "taos_errno", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_errno", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern public int ErrorNo(IntPtr res);
|
static extern public int ErrorNo(IntPtr res);
|
||||||
|
|
||||||
[DllImport("taos.dll", EntryPoint = "taos_query", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_query", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern public IntPtr Query(IntPtr conn, string sqlstr);
|
static extern public IntPtr Query(IntPtr conn, string sqlstr);
|
||||||
|
|
||||||
[DllImport("taos.dll", EntryPoint = "taos_affected_rows", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_affected_rows", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern public int AffectRows(IntPtr res);
|
static extern public int AffectRows(IntPtr res);
|
||||||
|
|
||||||
[DllImport("taos.dll", EntryPoint = "taos_field_count", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_field_count", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern public int FieldCount(IntPtr res);
|
static extern public int FieldCount(IntPtr res);
|
||||||
|
|
||||||
[DllImport("taos.dll", EntryPoint = "taos_fetch_fields", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_fetch_fields", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern private IntPtr taos_fetch_fields(IntPtr res);
|
static extern private IntPtr taos_fetch_fields(IntPtr res);
|
||||||
static public List<TDengineMeta> FetchFields(IntPtr res)
|
static public List<TDengineMeta> FetchFields(IntPtr res)
|
||||||
{
|
{
|
||||||
|
@ -142,13 +155,17 @@ namespace TDengineDriver
|
||||||
return metas;
|
return metas;
|
||||||
}
|
}
|
||||||
|
|
||||||
[DllImport("taos.dll", EntryPoint = "taos_fetch_row", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_fetch_row", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern public IntPtr FetchRows(IntPtr res);
|
static extern public IntPtr FetchRows(IntPtr res);
|
||||||
|
|
||||||
[DllImport("taos.dll", EntryPoint = "taos_free_result", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_free_result", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern public IntPtr FreeResult(IntPtr res);
|
static extern public IntPtr FreeResult(IntPtr res);
|
||||||
|
|
||||||
[DllImport("taos.dll", EntryPoint = "taos_close", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_close", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern public int Close(IntPtr taos);
|
static extern public int Close(IntPtr taos);
|
||||||
|
|
||||||
|
//get precision£¬in parameter restultset
|
||||||
|
[DllImport("taos", EntryPoint = "taos_result_precision", CallingConvention = CallingConvention.Cdecl)]
|
||||||
|
static extern public int ResultPrecision(IntPtr taos);
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -163,5 +163,9 @@ namespace TDengineDriver
|
||||||
|
|
||||||
[DllImport("taos", EntryPoint = "taos_close", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_close", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern public int Close(IntPtr taos);
|
static extern public int Close(IntPtr taos);
|
||||||
|
|
||||||
|
//get precision£¬in parameter restultset
|
||||||
|
[DllImport("taos", EntryPoint = "taos_result_precision", CallingConvention = CallingConvention.Cdecl)]
|
||||||
|
static extern public int ResultPrecision(IntPtr taos);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -163,5 +163,8 @@ namespace TDengineDriver
|
||||||
|
|
||||||
[DllImport("taos", EntryPoint = "taos_close", CallingConvention = CallingConvention.Cdecl)]
|
[DllImport("taos", EntryPoint = "taos_close", CallingConvention = CallingConvention.Cdecl)]
|
||||||
static extern public int Close(IntPtr taos);
|
static extern public int Close(IntPtr taos);
|
||||||
|
//get precision£¬in parameter restultset
|
||||||
|
[DllImport("taos", EntryPoint = "taos_result_precision", CallingConvention = CallingConvention.Cdecl)]
|
||||||
|
static extern public int ResultPrecision(IntPtr taos);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue