2004-04-14 10:53:21 +02:00
|
|
|
/* Copyright (C) 2003 MySQL AB
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
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. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
|
|
|
|
|
|
|
#ifndef NDB_SQL_UTIL_HPP
|
|
|
|
#define NDB_SQL_UTIL_HPP
|
|
|
|
|
2004-07-27 10:31:10 +02:00
|
|
|
#include <ndb_global.h>
|
2004-06-10 12:04:30 +02:00
|
|
|
#include <kernel/ndb_limits.h>
|
2004-04-14 10:53:21 +02:00
|
|
|
|
2005-01-07 11:55:20 +01:00
|
|
|
struct charset_info_st;
|
|
|
|
typedef struct charset_info_st CHARSET_INFO;
|
|
|
|
|
2004-04-14 10:53:21 +02:00
|
|
|
class NdbSqlUtil {
|
|
|
|
public:
|
|
|
|
/**
|
2004-12-12 18:37:36 +01:00
|
|
|
* Compare attribute values. Returns -1, 0, +1 for less, equal,
|
|
|
|
* greater, respectively. Parameters are pointers to values and their
|
|
|
|
* lengths in bytes. The lengths can differ.
|
2004-09-17 14:09:21 +02:00
|
|
|
*
|
2004-12-12 18:37:36 +01:00
|
|
|
* First value is a full value but second value can be partial. If
|
|
|
|
* the partial value is not enough to determine the result, CmpUnknown
|
|
|
|
* will be returned. A shorter second value is not necessarily
|
|
|
|
* partial. Partial values are allowed only for types where prefix
|
2005-02-17 17:12:36 +01:00
|
|
|
* comparison is possible (basically, binary strings).
|
2004-12-12 18:37:36 +01:00
|
|
|
*
|
|
|
|
* First parameter is a pointer to type specific extra info. Char
|
|
|
|
* types receive CHARSET_INFO in it.
|
|
|
|
*
|
|
|
|
* If a value cannot be parsed, it compares like NULL i.e. less than
|
|
|
|
* any valid value.
|
2004-04-14 10:53:21 +02:00
|
|
|
*/
|
2004-12-12 18:37:36 +01:00
|
|
|
typedef int Cmp(const void* info, const void* p1, unsigned n1, const void* p2, unsigned n2, bool full);
|
2004-04-14 10:53:21 +02:00
|
|
|
|
2005-02-17 17:12:36 +01:00
|
|
|
/**
|
2006-05-05 00:53:34 +02:00
|
|
|
* Prototype for "like" comparison. Defined for string types. First
|
|
|
|
* argument can be fixed or var* type, second argument is fixed.
|
|
|
|
* Returns 0 on match, +1 on no match, and -1 on bad data.
|
2005-02-17 17:12:36 +01:00
|
|
|
*
|
|
|
|
* Uses default special chars ( \ % _ ).
|
|
|
|
*/
|
|
|
|
typedef int Like(const void* info, const void* p1, unsigned n1, const void* p2, unsigned n2);
|
|
|
|
|
2004-04-14 10:53:21 +02:00
|
|
|
enum CmpResult {
|
|
|
|
CmpLess = -1,
|
|
|
|
CmpEqual = 0,
|
|
|
|
CmpGreater = 1,
|
2004-08-27 13:57:51 +02:00
|
|
|
CmpUnknown = 2 // insufficient partial data
|
2004-04-14 10:53:21 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
struct Type {
|
|
|
|
enum Enum {
|
ndb: wl-1442 mysql vs ndb datatypes: prepare
ndb/include/Makefile.am:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/kernel/AttributeDescriptor.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/kernel/signaldata/DictTabInfo.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/ndb_constants.h:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/ndb_types.h:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/ndbapi/NdbDictionary.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/util/NdbSqlUtil.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/common/debugger/signaldata/DictTabInfo.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/blocks/dbdict/Dbdict.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/blocks/dbtup/DbtupExecQuery.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/blocks/dbtup/DbtupMeta.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/blocks/dbtux/DbtuxMeta.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/blocks/ndbcntr/NdbcntrMain.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/vm/MetaData.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/ndbapi/Ndb.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/ndbapi/NdbDictionaryImpl.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/ndbapi/NdbDictionaryImpl.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/ndbapi/NdbScanOperation.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
2004-12-26 22:40:42 +01:00
|
|
|
Undefined = NDB_TYPE_UNDEFINED,
|
|
|
|
Tinyint = NDB_TYPE_TINYINT,
|
|
|
|
Tinyunsigned = NDB_TYPE_TINYUNSIGNED,
|
|
|
|
Smallint = NDB_TYPE_SMALLINT,
|
|
|
|
Smallunsigned = NDB_TYPE_SMALLUNSIGNED,
|
|
|
|
Mediumint = NDB_TYPE_MEDIUMINT,
|
|
|
|
Mediumunsigned = NDB_TYPE_MEDIUMUNSIGNED,
|
|
|
|
Int = NDB_TYPE_INT,
|
|
|
|
Unsigned = NDB_TYPE_UNSIGNED,
|
|
|
|
Bigint = NDB_TYPE_BIGINT,
|
|
|
|
Bigunsigned = NDB_TYPE_BIGUNSIGNED,
|
|
|
|
Float = NDB_TYPE_FLOAT,
|
|
|
|
Double = NDB_TYPE_DOUBLE,
|
2005-02-16 13:14:21 +01:00
|
|
|
Olddecimal = NDB_TYPE_OLDDECIMAL,
|
ndb: wl-1442 mysql vs ndb datatypes: prepare
ndb/include/Makefile.am:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/kernel/AttributeDescriptor.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/kernel/signaldata/DictTabInfo.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/ndb_constants.h:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/ndb_types.h:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/ndbapi/NdbDictionary.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/util/NdbSqlUtil.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/common/debugger/signaldata/DictTabInfo.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/blocks/dbdict/Dbdict.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/blocks/dbtup/DbtupExecQuery.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/blocks/dbtup/DbtupMeta.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/blocks/dbtux/DbtuxMeta.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/blocks/ndbcntr/NdbcntrMain.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/vm/MetaData.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/ndbapi/Ndb.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/ndbapi/NdbDictionaryImpl.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/ndbapi/NdbDictionaryImpl.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/ndbapi/NdbScanOperation.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
2004-12-26 22:40:42 +01:00
|
|
|
Char = NDB_TYPE_CHAR,
|
|
|
|
Varchar = NDB_TYPE_VARCHAR,
|
|
|
|
Binary = NDB_TYPE_BINARY,
|
|
|
|
Varbinary = NDB_TYPE_VARBINARY,
|
|
|
|
Datetime = NDB_TYPE_DATETIME,
|
2005-01-08 23:24:25 +01:00
|
|
|
Date = NDB_TYPE_DATE,
|
ndb: wl-1442 mysql vs ndb datatypes: prepare
ndb/include/Makefile.am:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/kernel/AttributeDescriptor.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/kernel/signaldata/DictTabInfo.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/ndb_constants.h:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/ndb_types.h:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/ndbapi/NdbDictionary.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/include/util/NdbSqlUtil.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/common/debugger/signaldata/DictTabInfo.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/blocks/dbdict/Dbdict.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/blocks/dbtup/DbtupExecQuery.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/blocks/dbtup/DbtupMeta.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/blocks/dbtux/DbtuxMeta.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/blocks/ndbcntr/NdbcntrMain.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/kernel/vm/MetaData.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/ndbapi/Ndb.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/ndbapi/NdbDictionaryImpl.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/ndbapi/NdbDictionaryImpl.hpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
ndb/src/ndbapi/NdbScanOperation.cpp:
unify api/kernel types
deprecate 2-bit AttributeType, use 5-bit AttributeExtType
upgradable from 4.1 via nr/sr/backup
2004-12-26 22:40:42 +01:00
|
|
|
Blob = NDB_TYPE_BLOB,
|
|
|
|
Text = NDB_TYPE_TEXT,
|
2005-01-09 01:14:11 +01:00
|
|
|
Bit = NDB_TYPE_BIT,
|
2005-02-26 16:56:39 +01:00
|
|
|
Longvarchar = NDB_TYPE_LONGVARCHAR,
|
|
|
|
Longvarbinary = NDB_TYPE_LONGVARBINARY,
|
2005-01-27 18:41:23 +01:00
|
|
|
Time = NDB_TYPE_TIME,
|
|
|
|
Year = NDB_TYPE_YEAR,
|
2005-02-16 13:14:21 +01:00
|
|
|
Timestamp = NDB_TYPE_TIMESTAMP,
|
2005-02-16 21:19:42 +01:00
|
|
|
Olddecimalunsigned = NDB_TYPE_OLDDECIMALUNSIGNED,
|
|
|
|
Decimal = NDB_TYPE_DECIMAL,
|
|
|
|
Decimalunsigned = NDB_TYPE_DECIMALUNSIGNED
|
2004-04-14 10:53:21 +02:00
|
|
|
};
|
2005-01-07 11:55:20 +01:00
|
|
|
Enum m_typeId; // redundant
|
2004-08-27 13:57:51 +02:00
|
|
|
Cmp* m_cmp; // comparison method
|
2005-02-17 17:12:36 +01:00
|
|
|
Like* m_like; // "like" comparison method
|
2004-04-14 10:53:21 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get type by id. Can return the Undefined type.
|
|
|
|
*/
|
2004-08-27 13:57:51 +02:00
|
|
|
static const Type& getType(Uint32 typeId);
|
2004-04-14 10:53:21 +02:00
|
|
|
|
2004-09-16 12:57:15 +02:00
|
|
|
/**
|
2005-01-07 11:55:20 +01:00
|
|
|
* Get the normalized type used in hashing and key comparisons.
|
2005-02-17 17:12:36 +01:00
|
|
|
* Maps all string types to Binary. This includes Var* strings
|
|
|
|
* because strxfrm result is padded to fixed (maximum) length.
|
2004-09-16 12:57:15 +02:00
|
|
|
*/
|
|
|
|
static const Type& getTypeBinary(Uint32 typeId);
|
|
|
|
|
2004-09-15 17:44:13 +02:00
|
|
|
/**
|
|
|
|
* Check character set.
|
|
|
|
*/
|
2006-04-20 12:06:22 +02:00
|
|
|
static uint check_column_for_pk(Uint32 typeId, const void* info);
|
|
|
|
static uint check_column_for_hash_index(Uint32 typeId, const void* info);
|
|
|
|
static uint check_column_for_ordered_index(Uint32 typeId, const void* info);
|
2005-01-07 11:55:20 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get number of length bytes and length from variable length string.
|
|
|
|
* Returns false on error (invalid data). For other types returns
|
|
|
|
* zero length bytes and the fixed attribute length.
|
|
|
|
*/
|
|
|
|
static bool get_var_length(Uint32 typeId, const void* p, unsigned attrlen, Uint32& lb, Uint32& len);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Temporary workaround for bug#7284.
|
|
|
|
*/
|
|
|
|
static int strnxfrm_bug7284(CHARSET_INFO* cs, unsigned char* dst, unsigned dstLen, const unsigned char*src, unsigned srcLen);
|
2004-09-15 17:44:13 +02:00
|
|
|
|
2005-02-16 12:45:59 +01:00
|
|
|
/**
|
|
|
|
* Compare decimal numbers.
|
|
|
|
*/
|
|
|
|
static int cmp_olddecimal(const uchar* s1, const uchar* s2, unsigned n);
|
|
|
|
|
2004-04-14 10:53:21 +02:00
|
|
|
private:
|
|
|
|
/**
|
|
|
|
* List of all types. Must match Type::Enum.
|
|
|
|
*/
|
|
|
|
static const Type m_typeList[];
|
|
|
|
/**
|
|
|
|
* Comparison methods.
|
|
|
|
*/
|
|
|
|
static Cmp cmpTinyint;
|
|
|
|
static Cmp cmpTinyunsigned;
|
|
|
|
static Cmp cmpSmallint;
|
|
|
|
static Cmp cmpSmallunsigned;
|
|
|
|
static Cmp cmpMediumint;
|
|
|
|
static Cmp cmpMediumunsigned;
|
|
|
|
static Cmp cmpInt;
|
|
|
|
static Cmp cmpUnsigned;
|
|
|
|
static Cmp cmpBigint;
|
|
|
|
static Cmp cmpBigunsigned;
|
|
|
|
static Cmp cmpFloat;
|
|
|
|
static Cmp cmpDouble;
|
2005-02-16 12:45:59 +01:00
|
|
|
static Cmp cmpOlddecimal;
|
2004-04-14 10:53:21 +02:00
|
|
|
static Cmp cmpChar;
|
|
|
|
static Cmp cmpVarchar;
|
|
|
|
static Cmp cmpBinary;
|
|
|
|
static Cmp cmpVarbinary;
|
|
|
|
static Cmp cmpDatetime;
|
2005-01-08 16:57:51 +01:00
|
|
|
static Cmp cmpDate;
|
2004-06-10 12:04:30 +02:00
|
|
|
static Cmp cmpBlob;
|
2004-07-22 12:33:14 +02:00
|
|
|
static Cmp cmpText;
|
2005-01-07 11:55:20 +01:00
|
|
|
static Cmp cmpBit;
|
|
|
|
static Cmp cmpLongvarchar;
|
|
|
|
static Cmp cmpLongvarbinary;
|
2005-01-08 19:28:44 +01:00
|
|
|
static Cmp cmpTime;
|
2005-01-27 17:33:35 +01:00
|
|
|
static Cmp cmpYear;
|
|
|
|
static Cmp cmpTimestamp;
|
2005-02-16 12:45:59 +01:00
|
|
|
static Cmp cmpOlddecimalunsigned;
|
2005-02-16 21:19:42 +01:00
|
|
|
static Cmp cmpDecimal;
|
|
|
|
static Cmp cmpDecimalunsigned;
|
2005-02-17 17:12:36 +01:00
|
|
|
//
|
|
|
|
static Like likeChar;
|
2005-02-21 10:44:37 +01:00
|
|
|
static Like likeBinary;
|
2005-02-17 17:12:36 +01:00
|
|
|
static Like likeVarchar;
|
2005-02-21 10:44:37 +01:00
|
|
|
static Like likeVarbinary;
|
2005-02-17 17:12:36 +01:00
|
|
|
static Like likeLongvarchar;
|
2005-02-21 10:44:37 +01:00
|
|
|
static Like likeLongvarbinary;
|
2004-04-14 10:53:21 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|