2014-01-11 00:11:47 +01:00
/*
2014-03-27 16:43:36 +01:00
* Copyright ( c ) 2013 - 2014 , Roland Bock
2014-01-11 00:11:47 +01:00
* All rights reserved .
*
* Redistribution and use in source and binary forms , with or without modification ,
* are permitted provided that the following conditions are met :
*
* * Redistributions of source code must retain the above copyright notice ,
* this list of conditions and the following disclaimer .
* * Redistributions in binary form must reproduce the above copyright notice ,
* this list of conditions and the following disclaimer in the documentation
* and / or other materials provided with the distribution .
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS " AS IS " AND
* ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT LIMITED TO , THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED .
* IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT ,
* INDIRECT , INCIDENTAL , SPECIAL , EXEMPLARY , OR CONSEQUENTIAL DAMAGES ( INCLUDING ,
* BUT NOT LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES ; LOSS OF USE ,
* DATA , OR PROFITS ; OR BUSINESS INTERRUPTION ) HOWEVER CAUSED AND ON ANY THEORY OF
* LIABILITY , WHETHER IN CONTRACT , STRICT LIABILITY , OR TORT ( INCLUDING NEGLIGENCE
* OR OTHERWISE ) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE , EVEN IF ADVISED
* OF THE POSSIBILITY OF SUCH DAMAGE .
*/
2014-01-28 20:53:22 +01:00
# include "Sample.h"
2014-01-11 00:11:47 +01:00
# include "MockDb.h"
2014-01-18 15:50:16 +01:00
# include <sqlpp11/alias_provider.h>
2014-01-13 23:05:48 +01:00
# include <sqlpp11/insert.h>
2014-01-15 08:24:42 +01:00
# include <sqlpp11/select.h>
2014-01-15 07:22:54 +01:00
# include <sqlpp11/update.h>
2014-01-15 08:24:42 +01:00
# include <sqlpp11/remove.h>
2014-01-13 21:00:20 +01:00
# include <sqlpp11/functions.h>
2014-01-11 00:11:47 +01:00
# include <iostream>
2014-02-21 07:24:07 +01:00
MockDb db = { } ;
MockDb : : _serializer_context_t printer ;
2014-01-18 15:50:16 +01:00
SQLPP_ALIAS_PROVIDER ( kaesekuchen ) ;
2014-01-11 00:11:47 +01:00
int main ( )
{
2014-01-28 20:53:22 +01:00
test : : TabFoo f ;
test : : TabBar t ;
2014-01-11 00:11:47 +01:00
2014-02-21 06:02:49 +01:00
serialize ( insert_into ( t ) . columns ( t . beta , t . gamma ) , printer ) . str ( ) ;
2014-02-08 21:06:23 +01:00
{
auto i = insert_into ( t ) . columns ( t . gamma , t . beta ) ;
i . add_values ( t . gamma = true , t . beta = " cheesecake " ) ;
2014-02-21 06:02:49 +01:00
serialize ( i , printer ) . str ( ) ;
2014-02-08 21:06:23 +01:00
i . add_values ( t . gamma = false , t . beta = sqlpp : : tvin ( " coffee " ) ) ;
i . add_values ( t . gamma = false , t . beta = sqlpp : : tvin ( std : : string ( ) ) ) ;
2014-02-21 06:02:49 +01:00
serialize ( i , printer ) . str ( ) ;
2014-02-08 21:06:23 +01:00
i . add_values ( t . gamma = sqlpp : : default_value , t . beta = sqlpp : : null ) ;
2014-02-21 06:02:49 +01:00
serialize ( i , printer ) . str ( ) ;
2014-02-08 21:06:23 +01:00
}
2014-01-26 15:09:30 +01:00
2014-02-21 06:02:49 +01:00
serialize ( t . alpha = sqlpp : : null , printer ) . str ( ) ;
serialize ( t . alpha = sqlpp : : default_value , printer ) . str ( ) ;
serialize ( t . alpha , printer ) . str ( ) ;
serialize ( - t . alpha , printer ) . str ( ) ;
serialize ( + t . alpha , printer ) . str ( ) ;
serialize ( - ( t . alpha + 7 ) , printer ) . str ( ) ;
serialize ( t . alpha = 0 , printer ) . str ( ) ;
serialize ( t . alpha = sqlpp : : tvin ( 0 ) , printer ) . str ( ) ;
serialize ( t . alpha = = 0 , printer ) . str ( ) ;
serialize ( t . alpha = = sqlpp : : tvin ( 0 ) , printer ) . str ( ) ;
serialize ( t . alpha ! = 0 , printer ) . str ( ) ;
serialize ( t . gamma ! = sqlpp : : tvin ( false ) , printer ) . str ( ) ;
serialize ( t . alpha = = 7 , printer ) . str ( ) ;
serialize ( t . beta + " kaesekuchen " , printer ) . str ( ) ;
serialize ( sqlpp : : select ( ) , printer ) . str ( ) ;
serialize ( sqlpp : : select ( ) . flags ( sqlpp : : distinct ) , printer ) . str ( ) ;
serialize ( select ( t . alpha , t . beta ) . flags ( sqlpp : : distinct ) , printer ) . str ( ) ;
serialize ( select ( t . alpha , t . beta ) , printer ) . str ( ) ;
serialize ( select ( t . alpha , t . beta ) . from ( t ) , printer ) . str ( ) ;
serialize ( select ( t . alpha , t . beta ) . from ( t ) . where ( t . alpha = = 3 ) , printer ) . str ( ) ;
serialize ( select ( t . alpha , t . beta ) . from ( t ) . where ( t . alpha = = 3 ) . group_by ( t . gamma ) , printer ) . str ( ) ;
serialize ( select ( t . alpha , t . beta ) . from ( t ) . where ( t . alpha = = 3 ) . group_by ( t . gamma ) . having ( t . beta . like ( " %kuchen " ) ) , printer ) . str ( ) ;
serialize ( select ( t . alpha , t . beta ) . from ( t ) . where ( t . alpha = = 3 ) . group_by ( t . gamma ) . having ( t . beta . like ( " %kuchen " ) ) . order_by ( t . beta . asc ( ) ) , printer ) . str ( ) ;
serialize ( select ( t . alpha , t . beta ) . from ( t ) . where ( t . alpha = = 3 ) . group_by ( t . gamma ) . having ( t . beta . like ( " %kuchen " ) ) . order_by ( t . beta . asc ( ) ) . limit ( 17 ) . offset ( 3 ) , printer ) . str ( ) ;
serialize ( parameter ( sqlpp : : bigint ( ) , t . alpha ) , printer ) . str ( ) ;
serialize ( parameter ( t . alpha ) , printer ) . str ( ) ;
serialize ( t . alpha = = parameter ( t . alpha ) , printer ) . str ( ) ;
serialize ( t . alpha = = parameter ( t . alpha ) and ( t . beta + " gimmick " ) . like ( parameter ( t . beta ) ) , printer ) . str ( ) ;
serialize ( insert_into ( t ) , printer ) . str ( ) ;
serialize ( insert_into ( f ) . default_values ( ) , printer ) . str ( ) ;
serialize ( insert_into ( t ) . set ( t . gamma = true ) , printer ) . str ( ) ;
//serialize(insert_into(t).set(t.gamma = sqlpp::tvin(false)), printer).str(); cannot test this since gamma cannot be null and a static assert is thrown
serialize ( update ( t ) , printer ) . str ( ) ;
serialize ( update ( t ) . set ( t . gamma = true ) , printer ) . str ( ) ;
serialize ( update ( t ) . set ( t . gamma = true ) . where ( t . beta . in ( " kaesekuchen " , " cheesecake " ) ) , printer ) . str ( ) ;
serialize ( remove_from ( t ) , printer ) . str ( ) ;
serialize ( remove_from ( t ) . using_ ( t ) , printer ) . str ( ) ;
serialize ( remove_from ( t ) . where ( t . alpha = = sqlpp : : tvin ( 0 ) ) , printer ) . str ( ) ;
serialize ( remove_from ( t ) . using_ ( t ) . where ( t . alpha = = sqlpp : : tvin ( 0 ) ) , printer ) . str ( ) ;
2014-01-15 08:24:42 +01:00
2014-01-15 19:42:14 +01:00
// functions
2014-02-21 07:24:07 +01:00
sqlpp : : serialize ( sqlpp : : value ( 7 ) , printer ) . str ( ) ; // FIXME: Maybe the vendor namespace is not a good idea? argument lives in namespace vendor
2014-02-21 06:02:49 +01:00
serialize ( sqlpp : : verbatim < sqlpp : : detail : : integral > ( " irgendwas integrales " ) , printer ) . str ( ) ;
serialize ( sqlpp : : value_list ( std : : vector < int > ( { 1 , 2 , 3 , 4 , 5 , 6 , 8 } ) ) , printer ) . str ( ) ;
serialize ( exists ( select ( t . alpha ) . from ( t ) ) , printer ) . str ( ) ;
serialize ( any ( select ( t . alpha ) . from ( t ) ) , printer ) . str ( ) ;
serialize ( some ( select ( t . alpha ) . from ( t ) ) , printer ) . str ( ) ;
serialize ( count ( t . alpha ) , printer ) . str ( ) ;
serialize ( min ( t . alpha ) , printer ) . str ( ) ;
serialize ( max ( t . alpha ) , printer ) . str ( ) ;
serialize ( avg ( t . alpha ) , printer ) . str ( ) ;
serialize ( sum ( t . alpha ) , printer ) . str ( ) ;
serialize ( sqlpp : : verbatim_table ( " whatever " ) , printer ) . str ( ) ;
2014-01-15 19:42:14 +01:00
2014-01-17 09:56:35 +01:00
// alias
2014-02-21 06:02:49 +01:00
serialize ( t . as ( t . alpha ) , printer ) . str ( ) ;
serialize ( t . as ( t . alpha ) . beta , printer ) . str ( ) ;
2014-01-15 19:42:14 +01:00
2014-01-17 09:56:35 +01:00
// select alias
2014-02-21 06:02:49 +01:00
serialize ( select ( t . alpha ) . from ( t ) . where ( t . beta > " kaesekuchen " ) . as ( t . gamma ) , printer ) . str ( ) ;
2014-01-17 09:56:35 +01:00
2014-02-21 06:02:49 +01:00
serialize ( t . alpha . is_null ( ) , printer ) . str ( ) ;
2014-01-16 22:31:43 +01:00
2014-01-17 09:56:35 +01:00
// join
2014-02-21 06:02:49 +01:00
serialize ( t . inner_join ( t . as ( t . alpha ) ) . on ( t . beta = = t . as ( t . alpha ) . beta ) , printer ) . str ( ) ;
2014-01-17 09:56:35 +01:00
// multi_column
2014-02-21 06:02:49 +01:00
serialize ( multi_column ( t . alpha , ( t . beta + " cake " ) . as ( t . gamma ) ) . as ( t . alpha ) , printer ) . str ( ) ;
serialize ( multi_column ( all_of ( t ) ) . as ( t ) , printer ) . str ( ) ;
serialize ( all_of ( t ) . as ( t ) , printer ) . str ( ) ;
2014-01-17 09:56:35 +01:00
// dynamic select
2014-02-08 16:29:21 +01:00
{
2014-04-21 11:49:26 +02:00
auto s = dynamic_select ( db ) . dynamic_flags ( ) . dynamic_columns ( ) . from ( t ) ;
2014-02-08 16:29:21 +01:00
s . add_column ( t . beta ) ;
s . add_column ( t . gamma ) ;
2014-02-21 06:02:49 +01:00
serialize ( s , printer ) . str ( ) ;
2014-02-08 16:29:21 +01:00
}
{
2014-04-21 11:49:26 +02:00
auto s = dynamic_select ( db ) . dynamic_flags ( ) . dynamic_columns ( ) . from ( t ) ;
2014-02-08 16:29:21 +01:00
s . add_flag ( sqlpp : : distinct ) ;
s . add_column ( t . beta ) ;
s . add_column ( t . gamma ) ;
2014-02-21 06:02:49 +01:00
serialize ( s , printer ) . str ( ) ;
2014-02-08 16:29:21 +01:00
}
{
2014-04-21 11:49:26 +02:00
auto s = dynamic_select ( db ) . dynamic_flags ( sqlpp : : distinct ) . dynamic_columns ( t . alpha ) . extra_tables ( t ) ; // Would fail to run()
2014-02-08 16:29:21 +01:00
s . add_flag ( sqlpp : : all ) ;
s . add_column ( t . beta ) ;
s . add_column ( t . gamma ) ;
2014-02-21 06:02:49 +01:00
serialize ( s , printer ) . str ( ) ;
2014-02-08 16:29:21 +01:00
}
2014-01-17 09:56:35 +01:00
2014-01-21 23:42:27 +01:00
// distinct aggregate
2014-02-21 06:02:49 +01:00
serialize ( count ( sqlpp : : distinct , t . alpha % 7 ) , printer ) . str ( ) ;
serialize ( avg ( sqlpp : : distinct , t . alpha - 7 ) , printer ) . str ( ) ;
serialize ( sum ( sqlpp : : distinct , t . alpha + 7 ) , printer ) . str ( ) ;
serialize ( select ( all_of ( t ) ) . from ( t ) . where ( true ) , printer ) . str ( ) ;
serialize ( select ( all_of ( t ) ) . from ( t ) . where ( false ) , printer ) . str ( ) ;
2014-02-08 22:24:05 +01:00
2014-01-11 00:11:47 +01:00
return 0 ;
}