#include using namespace Upp; #define MODEL #define SCHEMADIALECT #include #include #include SQLID(PH_SEQ) SQLID(CASTKA) SQLID(PH_POLOZKA) SQLID(DATUM) SQLID(PLAT_DTM) SQLID(PLAT_DTM_SEQ) SQLID(SEQ_POPLATEK) SQLID(PRIPAD_SEQ) SQLID(TXT) SQLID(KATASTR_SEQ) SQLID(ADRESA) SQLID(ADRESA_SEQ) SQLID(PAR_ADRESA_SEQ) SQLID(KONTO) SQLID(ROK) SQLID(OBDOBI) SQLID(KONTO_CON) SQLID(B) SQLID(C) SQLID(OBEXPBI) void Exp0(int dialect, const char *dialectn, const char *sqlexp, SqlStatement x) { LOG("\tTEST(" << dialectn << ",\n\t\t" << sqlexp << ",\n\t\t" << AsCString(x.Get(dialect)) << ");"); } void Exp(const char *sqlexp, SqlStatement x) { Exp0(MY_SQL, "MY_SQL", sqlexp, x); Exp0(SQLITE3, "SQLITE3", sqlexp, x); Exp0(ORACLE, "ORACLE", sqlexp, x); Exp0(MSSQL, "MSSQL", sqlexp, x); Exp0(PGSQL, "PGSQL", sqlexp, x); Exp0(FIREBIRD, "FIREBIRD", sqlexp, x); Exp0(DB2, "DB2", sqlexp, x); LOG("// ---------------------------------"); } #define EXP(x) Exp(#x, x) void Test(int dialect, const char *dialectn, SqlStatement s, const char *q) { LOG("---------------------"); LOG("Dialect " << dialectn); LOG("Etalon " << q); LOG("Compiled " << s.Get(dialect)); ASSERT(s.Get(dialect) == q); } #define TEST(dialect, s, e) Test(dialect, #dialect, s, e) CONSOLE_APP_MAIN { Date date = Date(2011, 12, 31); EXP(Select(A, B).From(TABLE1, TABLE2).OrderBy(B, C)); EXP(Select(A, B).From(TABLE1, TABLE2).Where(A == 10).OrderBy(B, C)); EXP(Select(A, B).From(SqlSet(TABLE1, TABLE2)).Where(A == 10).OrderBy(SqlSet(B, C))); EXP(Select(PH_SEQ, SqlSum(CASTKA)).From(PH_POLOZKA).Where(DATUM <= date).GroupBy(PH_SEQ).Having(C == B)); EXP(Insert(TABLE1)(A, 1)(B, 2)); EXP(Insert(PLAT_DTM) (PLAT_DTM_SEQ, NextVal(SEQ_POPLATEK)) (PRIPAD_SEQ, 1111) (DATUM) (CASTKA) (TXT) .From(PLAT_DTM).Where(PRIPAD_SEQ == 2222)); EXP(Select(KATASTR_SEQ).From(ADRESA) .StartWith(PAR_ADRESA_SEQ == 1111) .ConnectBy(Prior(ADRESA_SEQ) == PAR_ADRESA_SEQ) | Select(KATASTR_SEQ).From(ADRESA) .StartWith(ADRESA_SEQ == 2222) .ConnectBy(Prior(PAR_ADRESA_SEQ) == ADRESA_SEQ)); EXP(SqlUpdate(KONTO)(ROK, 1111)(OBEXPBI, 2222).Where(KONTO_CON == 3333)); EXP(Select(23 * (ROK + 1)).From(TABLE1)); EXP(Select(COLUMN1).From(TABLE1) | Select(COLUMN2).From(TABLE2)); EXP(Select(COLUMN1).From(TABLE1) & Select(COLUMN2).From(TABLE2)); EXP(Select(COLUMN1).From(TABLE1) - Select(COLUMN2).From(TABLE2)); EXP(Select(COL).From(TABLE1)); EXP(Select(COL.Of(TABLE1)).From(TABLE1)); EXP(Select(COL.As(A)).From(TABLE1)); EXP(Select(COL&A).From(TABLE1)); EXP(Select(COL[3]).From(TABLE1)); EXP(Select(COLUMN1 % COLUMN2).From(TABLE1)); EXP(Select(COLUMN1 | COLUMN2).From(TABLE1)); EXP(Select(SqlFunc("any_fn", COL, 2)).From(TABLE1)); EXP(Select(Distinct(COL)).From(TABLE1)); EXP(Select(Distinct(SqlSet(COLUMN1, COLUMN2))).From(TABLE1)); EXP(Select(All(COL)).From(TABLE1)); EXP(Select(Count(COL)).From(TABLE1)); EXP(Select(SqlAll()).From(TABLE1)); EXP(Select(SqlCountRows()).From(TABLE1)); EXP(Select(COL).From(TABLE1).OrderBy(Descending(COL))); EXP(Select(SqlMax(COL)).From(TABLE1)); EXP(Select(SqlMin(COL)).From(TABLE1)); EXP(Select(SqlSum(COL)).From(TABLE1)); EXP(Select(Avg(COL)).From(TABLE1)); EXP(Select(Stddev(COL)).From(TABLE1)); EXP(Select(Variance(COL)).From(TABLE1)); EXP(Select(Greatest(COLUMN1, COLUMN2)).From(TABLE1)); EXP(Select(Least(COLUMN1, COLUMN2)).From(TABLE1)); EXP(Select(Upper(COL)).From(TABLE1)); EXP(Select(Lower(COL)).From(TABLE1)); EXP(Select(Substr(COL, 1)).From(TABLE1)); EXP(Select(Substr(COL, 2, 1)).From(TABLE1)); EXP(Select(Instr(COL, "hello")).From(TABLE1)); EXP(Select(SqlNvl(COLUMN1, COLUMN2)).From(TABLE1)); EXP(Select(NextVal(SEQ)).Get()); EXP(Select(CurrVal(SEQ)).Get()); EXP(Select(SqlArg()).From(TABLE1)); EXP(Select(COL).From(TABLE1).Where(COL / 2 > 1 && COLUMN1 == "A" || COLUMN2 == Date(2006, 1, 1))); EXP(Select(COL).From(TABLE1).Where(!(COL == 1))); EXP(Select(COL).From(TABLE1).Where((COLUMN1 == 1) - (COLUMN2 == 1))); EXP(Select(COL).From(TABLE1).Where(IsNull(COLUMN1))); EXP(Select(COL).From(TABLE1).Where(NotNull(COLUMN1))); EXP(Select(COL).From(TABLE1).Where(Like(COLUMN1, Wild("A*")))); EXP(Select(COL).From(TABLE1).Where(NotLike(COLUMN1, Wild("A*")))); EXP(Select(COL).From(TABLE1).Where(In(COL, Select(COL).From(TABLE1)))); EXP(Select(COL).From(TABLE1).Where(COL == Select(COL).From(TABLE1))); EXP(Select(COL).From(TABLE1).Where(COL == Select(COL).From(TABLE1).AsValue())); EXP(Select(COL).From(TABLE1).Where(NotIn(COL, Select(COL).From(TABLE1)))); EXP(Select(COL).From(TABLE1).Where(COL != Select(COL).From(TABLE1))); EXP(Select(COL).From(TABLE1).Where(Exists(Select(COL).From(TABLE1)))); EXP(Select(COL).From(TABLE1).Where(NotExists(Select(COL).From(TABLE1)))); EXP(Select(COL).From(TABLE1).Where(COL == (Select(COLUMN1).From(TABLE1) | Select(COLUMN2).From(TABLE2)))); EXP(Select(COL).From(TABLE1).Where(COL == (Select(COLUMN1).From(TABLE1) & Select(COLUMN2).From(TABLE2)))); EXP(Select(COL).From(TABLE1).Where(COL == (Select(COLUMN1).From(TABLE1) - Select(COLUMN2).From(TABLE2)))); EXP(Select(COL).From(TABLE1).Where(COL == 0).GroupBy(COL).Having(COL == 0).OrderBy(Descending(COL))); EXP(Select(COL, Count(Select(SqlAll()).From(TABLE1))).From(TABLE1).Where(COL == 0).GroupBy(COL) .Having(COL == 0).OrderBy(Descending(COL))); EXP(Select(COL).From(TABLE1).Limit(100)); EXP(Select(COL).From(TABLE1).Limit(100, 10)); EXP(Select(COL).From(TABLE1).Offset(20)); EXP(Select(25 * 34).Get()); EXP(Select(COL).From(TABLE1).Hint("hint")); EXP(Select(COL).From(TABLE1).InnerJoin(TABLE1).On(COL.Of(TABLE1) == COLUMN1.Of(TABLE1))); EXP(Select(COL).From(TABLE1).LeftJoin(TABLE1).On(COL.Of(TABLE1) == COLUMN1.Of(TABLE1))); EXP(Select(COL).From(TABLE1).RightJoin(TABLE1).On(COL.Of(TABLE1) == COLUMN1.Of(TABLE1))); EXP(Select(COL).From(TABLE1).FullJoin(TABLE1).On(COL.Of(TABLE1) == COLUMN1.Of(TABLE1))); EXP(Delete(TABLE1).Where(COL < 0)); EXP(Insert(TABLE1)(COLUMN1, 12)(COLUMN2, "hello")(COL, Date(2007, 1, 1))); EXP(Insert(TABLE1)(COLUMN1, 12)(COLUMN2)(COL).From(TABLE1).Where(COL >= 0)); EXP(Update(TABLE1)(COLUMN1, 13)(COLUMN2, "world").Where(COL > Date(2007, 1, 1))); EXP(Insert(TABLE1)(COL, Select(COLUMN1).From(TABLE1).Where(COLUMN2 == 21).AsValue())); EXP(Select(COL).From(Select(COL).From(TABLE1))); EXP(Select(COL).From(Select(COL).From(TABLE1).AsTable(TABLE2))); EXP(Select(COL).From(TABLE1).LeftJoin(Select(COL).From(TABLE1)).On(COL.Of(TABLE1) == COLUMN1.Of(TABLE1))); EXP(Select(COL).From(TABLE1).LeftJoin(Select(COL).From(TABLE1).AsTable(TABLE2)).On(COL.Of(TABLE1) == COLUMN1.Of(TABLE1))); EXP(Select(TABLE1(COL, COLUMN1)).From(TABLE1)); EXP(Select(ID(ID, NAME, LASTNAME)).From(TABLE1).LeftJoinRef(TABLE2).Where(BDATE == Date(2011, 12, 9))); EXP(Select(ID(ID, NAME, LASTNAME)).From(TABLE1).LeftJoinRef(TABLE2).On(IsNull(BDATE)).Where(BDATE == Date(2011, 12, 9))); // ========================================================================= LOG("\n\n\n========================================================================="); #include "Test.i" LOG("OK"); }