2015-03-08 02:15:53 +00:00
|
|
|
/*************************************************************************
|
|
|
|
* *
|
|
|
|
* YAP Prolog *
|
|
|
|
* *
|
|
|
|
* Yap Prolog was developed at NCCUP - Universidade do Porto *
|
|
|
|
* *
|
|
|
|
* Copyright L.Damas, V.S.Costa and Universidade do Porto 1985-1997 *
|
|
|
|
* *
|
|
|
|
**************************************************************************
|
|
|
|
* *
|
|
|
|
* File: myddas.yap *
|
|
|
|
* Last rev: *
|
|
|
|
* mods: *
|
|
|
|
* comments: Global predicates for the MyDDAS Interface *
|
|
|
|
* *
|
|
|
|
*************************************************************************/
|
|
|
|
|
2016-07-31 16:02:06 +01:00
|
|
|
//:- load_foreign_files([myddas], [], init_myddas).
|
|
|
|
|
|
|
|
/* Initialize MYDDAS GLOBAL STRUCTURES */
|
|
|
|
:- c_db_initialize_myddas.
|
|
|
|
|
2014-09-11 20:06:57 +01:00
|
|
|
#ifdef DEBUG
|
|
|
|
:- yap_flag(single_var_warnings,on).
|
|
|
|
#endif
|
|
|
|
|
|
|
|
:- module(myddas,[
|
2015-03-08 02:15:53 +00:00
|
|
|
db_open/5,
|
|
|
|
db_open/4,
|
2016-07-31 16:02:06 +01:00
|
|
|
db_open/1,
|
|
|
|
db_open/0,
|
2015-03-08 02:15:53 +00:00
|
|
|
db_close/1,
|
|
|
|
db_close/0,
|
|
|
|
|
|
|
|
db_verbose/1,
|
|
|
|
db_module/1,
|
|
|
|
db_is_database_predicate/3,
|
|
|
|
#ifdef MYDDAS_STATS
|
|
|
|
db_stats/1,
|
|
|
|
db_stats/2,
|
|
|
|
db_stats_time/2,
|
|
|
|
#endif
|
|
|
|
db_sql/2,
|
|
|
|
db_sql/3,
|
|
|
|
db_sql_select/3,
|
|
|
|
db_prolog_select/2,
|
|
|
|
db_prolog_select/3,
|
|
|
|
db_prolog_select_multi/3,
|
|
|
|
db_command/2,
|
|
|
|
db_assert/2,
|
|
|
|
db_assert/1,
|
|
|
|
db_create_table/3,
|
|
|
|
db_export_view/4,
|
|
|
|
db_update/2,
|
|
|
|
|
|
|
|
db_get_attributes_types/2,
|
|
|
|
db_get_attributes_types/3,
|
|
|
|
db_number_of_fields/2,
|
|
|
|
db_number_of_fields/3,
|
|
|
|
|
|
|
|
db_multi_queries_number/2,
|
|
|
|
|
|
|
|
% myddas_top_level.ypp
|
|
|
|
#ifdef MYDDAS_TOP_LEVEL
|
|
|
|
db_top_level/4,
|
|
|
|
db_top_level/5,
|
|
|
|
db_datalog_select/3,
|
|
|
|
#endif
|
|
|
|
% myddas_assert_predicates.ypp
|
|
|
|
db_import/2,
|
|
|
|
db_import/3,
|
|
|
|
db_view/2,
|
|
|
|
db_view/3,
|
|
|
|
db_insert/2,
|
|
|
|
db_insert/3,
|
|
|
|
db_abolish/2,
|
|
|
|
db_listing/0,
|
|
|
|
db_listing/1
|
|
|
|
#ifdef MYDDAS_MYSQL
|
|
|
|
% myddas_mysql.ypp
|
|
|
|
,
|
|
|
|
db_my_result_set/1,
|
|
|
|
db_datalog_describe/1,
|
|
|
|
db_datalog_describe/2,
|
|
|
|
db_describe/3,
|
|
|
|
db_describe/2,
|
|
|
|
db_datalog_show_tables/1,
|
|
|
|
db_datalog_show_tables/0,
|
|
|
|
db_show_tables/2,
|
|
|
|
db_show_tables/1,
|
|
|
|
db_show_database/2,
|
|
|
|
db_show_databases/2,
|
|
|
|
db_show_databases/1,
|
|
|
|
db_change_database/2,
|
|
|
|
db_call_procedure/4,
|
|
|
|
db_call_procedure/3,
|
|
|
|
db_my_sql_mode/1,
|
|
|
|
db_my_sql_mode/2,
|
|
|
|
db_sql_mode/1,
|
|
|
|
db_sql_mode/2
|
|
|
|
#endif
|
|
|
|
]).
|
2014-09-11 20:06:57 +01:00
|
|
|
|
|
|
|
|
2014-07-27 01:14:15 +01:00
|
|
|
|
2014-11-02 12:10:32 +00:00
|
|
|
%% @}
|
|
|
|
|
2006-05-31 15:35:05 +01:00
|
|
|
#ifdef MYDDAS_TOP_LEVEL
|
2006-02-05 02:19:15 +00:00
|
|
|
:- use_module(myddas_top_level,[
|
2015-03-08 02:15:53 +00:00
|
|
|
db_top_level/4,
|
|
|
|
db_top_level/5,
|
|
|
|
db_datalog_select/3
|
|
|
|
]).
|
2006-04-30 11:11:25 +01:00
|
|
|
#endif
|
2006-02-05 02:19:15 +00:00
|
|
|
|
2005-12-19 13:41:15 +00:00
|
|
|
:- use_module(myddas_assert_predicates,[
|
2015-03-08 02:15:53 +00:00
|
|
|
db_import/2,
|
|
|
|
db_import/3,
|
|
|
|
db_view/2,
|
|
|
|
db_view/3,
|
|
|
|
db_insert/2,
|
|
|
|
db_insert/3,
|
|
|
|
db_abolish/2,
|
|
|
|
db_listing/0,
|
|
|
|
db_listing/1
|
|
|
|
]).
|
2005-12-19 13:41:15 +00:00
|
|
|
|
2006-04-30 11:11:25 +01:00
|
|
|
#ifdef MYDDAS_MYSQL
|
2005-12-19 13:41:15 +00:00
|
|
|
:- use_module(myddas_mysql,[
|
2017-10-18 17:02:27 +01:00
|
|
|
db_my_result_set/1,
|
|
|
|
db_datalog_describe/1,
|
2015-03-08 02:15:53 +00:00
|
|
|
db_datalog_describe/2,
|
|
|
|
db_describe/3,
|
|
|
|
db_describe/2,
|
|
|
|
db_datalog_show_tables/1,
|
|
|
|
db_datalog_show_tables/0,
|
|
|
|
db_show_tables/2,
|
|
|
|
db_show_tables/1,
|
|
|
|
db_show_database/2,
|
|
|
|
db_show_databases/2,
|
|
|
|
db_show_databases/1,
|
|
|
|
db_change_database/2,
|
|
|
|
db_call_procedure/4,
|
|
|
|
db_call_procedure/3,
|
|
|
|
db_my_sql_mode/1,
|
|
|
|
db_my_sql_mode/2,
|
|
|
|
db_sql_mode/1,
|
|
|
|
db_sql_mode/2
|
2017-10-18 17:02:27 +01:00
|
|
|
]).
|
2006-04-30 11:11:25 +01:00
|
|
|
#endif /* MYDDAS_MYSQL */
|
2016-07-31 16:02:06 +01:00
|
|
|
:- use_module(myddas_sqlite3,[
|
2017-10-18 17:02:27 +01:00
|
|
|
% myddas_mysql.ypp
|
|
|
|
c_sqlite3_connect/4,
|
|
|
|
c_sqlite3_disconnect/1,
|
|
|
|
c_sqlite3_query/5,
|
|
|
|
sqlite3_result_set/1,
|
|
|
|
c_sqlite3_number_of_fields/3
|
|
|
|
]).
|
2016-07-31 16:02:06 +01:00
|
|
|
|
2005-12-19 13:41:15 +00:00
|
|
|
|
|
|
|
:- use_module(myddas_util_predicates,[
|
2015-03-08 02:15:53 +00:00
|
|
|
'$prolog2sql'/3,
|
|
|
|
'$create_multi_query'/3,
|
|
|
|
'$get_multi_results'/4,
|
|
|
|
'$process_sql_goal'/4,
|
|
|
|
'$process_fields'/3,
|
|
|
|
'$get_values_for_insert'/3,
|
|
|
|
'$make_atom'/2,
|
|
|
|
'$write_or_not'/1,
|
|
|
|
'$abolish_all'/1,
|
|
|
|
'$make_a_list'/2,
|
|
|
|
'$get_table_name'/2,
|
|
|
|
'$get_values_for_update'/4,
|
|
|
|
'$extract_args'/4,
|
|
|
|
#ifdef MYDDAS_STATS
|
|
|
|
'$make_stats_list'/2,
|
|
|
|
#endif
|
|
|
|
'$lenght'/2
|
|
|
|
]).
|
2005-12-19 13:41:15 +00:00
|
|
|
|
|
|
|
:- use_module(myddas_errors,[
|
2015-03-08 02:15:53 +00:00
|
|
|
'$error_checks'/1
|
|
|
|
]).
|
2005-12-19 13:41:15 +00:00
|
|
|
|
|
|
|
:- use_module(myddas_prolog2sql,[
|
2015-03-08 02:15:53 +00:00
|
|
|
translate/3,
|
|
|
|
queries_atom/2
|
|
|
|
]).
|
2005-12-19 13:41:15 +00:00
|
|
|
|
2017-10-18 17:02:27 +01:00
|
|
|
:- use_module(library(lists),[
|
|
|
|
append/3
|
|
|
|
]).
|
2015-03-04 09:59:42 +00:00
|
|
|
|
2006-01-09 13:38:02 +00:00
|
|
|
|
2005-12-19 13:41:15 +00:00
|
|
|
|
2014-01-24 19:59:42 +00:00
|
|
|
|
2005-12-19 13:41:15 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_open/5
|
|
|
|
% db_open/4
|
|
|
|
%
|
2015-03-04 09:59:42 +00:00
|
|
|
|
2015-03-08 02:15:53 +00:00
|
|
|
|
2015-02-16 11:44:37 +00:00
|
|
|
|
2016-07-31 16:02:06 +01:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
% db_open/5
|
|
|
|
% db_open/4
|
|
|
|
%
|
|
|
|
db_open(Interface,HostDb,User,Password):-
|
|
|
|
db_open(Interface,myddas,HostDb,User,Password).
|
|
|
|
|
|
|
|
#ifdef MYDDAS_MYSQL
|
|
|
|
db_open(mysql,Connection,Host/Db/Port/Socket,User,Password) :- !,
|
|
|
|
'$error_checks'(db_open(mysql,Connection,Host/Db/Port/Socket,User,Password)),
|
|
|
|
c_db_my_connect(Host,User,Password,Db,Port,Socket,Con),
|
|
|
|
set_value(Connection,Con).
|
|
|
|
db_open(mysql,Connection,Host/Db/Port,User,Password) :-
|
|
|
|
integer(Port),!,
|
|
|
|
db_open(mysql,Connection,Host/Db/Port/_,User,Password). % Var to be NULL, the default socket
|
|
|
|
db_open(mysql,Connection,Host/Db/Socket,User,Password) :- !,
|
|
|
|
db_open(mysql,Connection,Host/Db/0/Socket,User,Password). % 0 is default port
|
|
|
|
db_open(mysql,Connection,Host/Db,User,Password) :-
|
|
|
|
db_open(mysql,Connection,Host/Db/0/_,User,Password). % 0 is default port and Var to be NULL, the default socket
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef MYDDAS_POSTGRES
|
|
|
|
db_open(postgres,Connection,Host/Db/Port/Socket,User,Password) :- !,
|
|
|
|
'$error_checks'(db_open(postgres,Connection,Host/Db/Port/Socket,User,Password)),
|
|
|
|
c_db_my_connect(Host,User,Password,Db,Port,Socket,Con),
|
|
|
|
set_value(Connection,Con).
|
|
|
|
db_open(postgres,Connection,Host/Db/Port,User,Password) :-
|
|
|
|
integer(Port),!,
|
|
|
|
db_open(postgres,Connection,Host/Db/Port/_,User,Password). % Var to be NULL, the default socket
|
|
|
|
db_open(postgres,Connection,Host/Db/Socket,User,Password) :- !,
|
|
|
|
db_open(postgres,Connection,Host/Db/0/Socket,User,Password). % 0 is default port
|
|
|
|
db_open(postgres,Connection,Host/Db,User,Password) :-
|
|
|
|
db_open(postgres,Connection,Host/Db/0/_,User,Password). % 0 is default port and Var to be NULL, the default socket
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef MYDDAS_ODBC
|
|
|
|
db_open(odbc,Connection,ODBCEntry,User,Password) :-
|
|
|
|
'$error_checks'(db_open(odbc,Connection,ODBCEntry,User,Password)),
|
|
|
|
c_odbc_connect(ODBCEntry,User,Password,Con),
|
|
|
|
set_value(Connection,Con).
|
|
|
|
#endif
|
2016-11-16 23:17:33 +00:00
|
|
|
db_open(sqlite3,Connection,File,User,Password) :-
|
2016-07-31 16:02:06 +01:00
|
|
|
'$error_checks'(db_open(sqlite3,Connection,File,User,Password)),
|
|
|
|
c_sqlite3_connect(File,User,Password,Con),
|
|
|
|
set_value(Connection,Con).
|
2005-12-19 13:41:15 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_close/1
|
|
|
|
% db_close/0
|
|
|
|
%
|
2006-02-10 23:42:19 +00:00
|
|
|
db_close:-
|
2015-03-08 02:15:53 +00:00
|
|
|
db_close(myddas).
|
|
|
|
db_close(Protocol):-
|
|
|
|
'$error_checks'(db_close(Protocol)),
|
|
|
|
get_value(Protocol,Con),
|
|
|
|
'$abolish_all'(Con).
|
|
|
|
db_close(Protocol) :-
|
|
|
|
'$error_checks'(db_close(Protocol)),
|
|
|
|
get_value(Protocol,Con),
|
|
|
|
c_db_connection_type(Con,ConType),
|
|
|
|
( ConType == mysql ->
|
|
|
|
c_db_my_disconnect(Con)
|
|
|
|
;ConType == postgres ->
|
|
|
|
c_postgres_disconnect(Con)
|
|
|
|
;ConType == sqlite3 ->
|
|
|
|
c_sqlite3_disconnect(Con)
|
|
|
|
;
|
2016-07-31 16:02:06 +01:00
|
|
|
c_odbc_disconnect(Con)
|
2015-03-08 02:15:53 +00:00
|
|
|
),
|
|
|
|
set_value(Protocol,[]). % "deletes" atom
|
2005-12-19 13:41:15 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
2005-11-22 11:25:59 +00:00
|
|
|
|
2006-04-30 11:11:25 +01:00
|
|
|
|
2005-11-22 11:25:59 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_verbose/1
|
|
|
|
%
|
|
|
|
%
|
2005-11-22 11:25:59 +00:00
|
|
|
db_verbose(X):-
|
2015-03-08 02:15:53 +00:00
|
|
|
var(X),!,
|
|
|
|
get_value(db_verbose,X).
|
2006-01-25 20:40:21 +00:00
|
|
|
db_verbose(N):-!,
|
2015-03-08 02:15:53 +00:00
|
|
|
set_value(db_verbose,N).
|
|
|
|
%default value
|
2006-01-25 20:40:21 +00:00
|
|
|
:- set_value(db_verbose,0).
|
|
|
|
:- set_value(db_verbose_filename,myddas_queries).
|
2005-11-22 11:25:59 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
|
|
|
|
2005-12-19 13:41:15 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_module/1
|
|
|
|
%
|
|
|
|
%
|
2005-12-19 13:41:15 +00:00
|
|
|
db_module(X):-
|
2015-03-08 02:15:53 +00:00
|
|
|
var(X),!,
|
|
|
|
get_value(db_module,X).
|
2005-12-19 13:41:15 +00:00
|
|
|
db_module(ModuleName):-
|
2015-03-08 02:15:53 +00:00
|
|
|
set_value(db_module,ModuleName).
|
|
|
|
% default value
|
2005-12-19 13:41:15 +00:00
|
|
|
:- db_module(user).
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
2005-11-22 11:25:59 +00:00
|
|
|
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_is_database_predicate(+,+,+)
|
|
|
|
%
|
|
|
|
%
|
2006-03-03 14:14:54 +00:00
|
|
|
db_is_database_predicate(Module,PredName,Arity):-
|
2015-03-08 02:15:53 +00:00
|
|
|
'$error_checks'(db_is_database_predicate(PredName,Arity,Module)),
|
|
|
|
c_db_check_if_exists_pred(PredName,Arity,Module).
|
2005-11-22 11:25:59 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
2006-05-03 19:02:29 +01:00
|
|
|
#ifdef MYDDAS_STATS
|
2006-01-10 15:37:21 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_stats(+,-)
|
|
|
|
%
|
|
|
|
%
|
2006-05-03 19:02:29 +01:00
|
|
|
db_stats(List):-
|
2015-03-08 02:15:53 +00:00
|
|
|
db_stats(myddas,List).
|
|
|
|
|
|
|
|
db_stats(Protocol,List):-
|
|
|
|
'$error_checks'(db_stats(Protocol,List)),
|
|
|
|
NumberOfStats = 10,
|
|
|
|
'$make_a_list'(NumberOfStats,ListX1),
|
|
|
|
( var(Protocol) ->
|
|
|
|
c_db_stats(0,ListX1)
|
|
|
|
;
|
|
|
|
get_value(Protocol,Conn),
|
|
|
|
c_db_stats(Conn,ListX1)
|
|
|
|
),
|
|
|
|
'$make_stats_list'(ListX1,List).
|
2006-05-03 19:02:29 +01:00
|
|
|
|
2006-05-22 17:45:07 +01:00
|
|
|
#ifdef DEBUG
|
2006-05-03 19:02:29 +01:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_stats_time(+,-)
|
|
|
|
% Reference is C pointer (memory reference)
|
|
|
|
%
|
2006-05-03 19:02:29 +01:00
|
|
|
db_stats_time(Reference,Time):-
|
2015-03-08 02:15:53 +00:00
|
|
|
'$error_checks'(db_stats_time(Reference,Time)),
|
|
|
|
c_db_stats_time(Reference,Time).
|
2015-02-14 11:35:07 +00:00
|
|
|
|
2005-12-19 13:41:15 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2006-05-22 17:45:07 +01:00
|
|
|
#endif /* DEBUG */
|
2005-12-19 13:41:15 +00:00
|
|
|
|
2006-05-22 17:45:07 +01:00
|
|
|
#endif /* MYDDAS_STATS */
|
2005-12-19 13:41:15 +00:00
|
|
|
|
2006-02-10 23:42:19 +00:00
|
|
|
|
2005-12-19 13:41:15 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_sql(+,+,-)
|
|
|
|
%
|
|
|
|
%
|
2006-03-03 14:14:54 +00:00
|
|
|
|
2015-03-08 02:15:53 +00:00
|
|
|
%compatibility
|
|
|
|
db_sql_select(Protocol,SQL,LA):-
|
|
|
|
db_sql(Protocol,SQL,LA).
|
2006-03-03 14:14:54 +00:00
|
|
|
|
2006-02-10 23:42:19 +00:00
|
|
|
db_sql(SQL,LA):-
|
2015-03-08 02:15:53 +00:00
|
|
|
db_sql(myddas,SQL,LA).
|
2006-02-10 23:42:19 +00:00
|
|
|
db_sql(Connection,SQL,LA):-
|
2015-03-08 02:15:53 +00:00
|
|
|
'$error_checks'(db_sql(Connection,SQL,LA)),
|
|
|
|
get_value(Connection,Con),
|
|
|
|
c_db_connection_type(Con,ConType),
|
|
|
|
'$write_or_not'(SQL),
|
|
|
|
( ConType == mysql ->
|
|
|
|
db_my_result_set(Mode),
|
|
|
|
c_db_my_query(SQL,ResultSet,Con,Mode,Arity)
|
|
|
|
;ConType == postgres ->
|
|
|
|
postgres_result_set(Mode),
|
|
|
|
c_postgres_query(SQL,ResultSet,Con,Mode,Arity)
|
|
|
|
;ConType == sqlite3 ->
|
|
|
|
sqlite3_result_set(Mode),
|
|
|
|
c_sqlite3_query(SQL,ResultSet,Con,Mode,Arity)
|
|
|
|
;
|
2016-07-31 16:02:06 +01:00
|
|
|
c_odbc_number_of_fields_in_query(SQL,Con,Arity)
|
2015-03-08 02:15:53 +00:00
|
|
|
),
|
|
|
|
'$make_a_list'(Arity,LA),
|
|
|
|
( ConType == mysql ->
|
|
|
|
!,c_db_my_row(ResultSet,Arity,LA)
|
|
|
|
;
|
|
|
|
'$make_a_list'(Arity,BindList),
|
2016-07-31 16:02:06 +01:00
|
|
|
c_odbc_query(SQL,ResultSet,Arity,BindList,Con),!,
|
|
|
|
c_odbc_row(ResultSet,BindList,LA)
|
2015-03-08 02:15:53 +00:00
|
|
|
).
|
2005-12-19 13:41:15 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
2006-01-10 15:37:21 +00:00
|
|
|
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_prolog_select(+,+,+)
|
|
|
|
%
|
|
|
|
%
|
2006-04-30 11:11:25 +01:00
|
|
|
db_prolog_select(LA,DbGoal):-
|
2015-03-08 02:15:53 +00:00
|
|
|
db_prolog_select(myddas,LA,DbGoal).
|
2006-01-11 23:15:52 +00:00
|
|
|
db_prolog_select(Connection,LA,DbGoal):-
|
2015-02-14 11:35:07 +00:00
|
|
|
|
2015-03-08 02:15:53 +00:00
|
|
|
'$lenght'(LA,Arity),
|
|
|
|
Name=viewname,
|
|
|
|
functor(ViewName,Name,Arity),
|
|
|
|
% build arg list for viewname/Arity
|
|
|
|
ViewName=..[Name|LA],
|
|
|
|
|
|
|
|
'$prolog2sql'(ViewName,DbGoal,SQL),
|
|
|
|
|
|
|
|
get_value(Connection,Con),
|
|
|
|
c_db_connection_type(Con,ConType),
|
|
|
|
'$write_or_not'(SQL),
|
|
|
|
( ConType == mysql ->
|
|
|
|
db_my_result_set(Mode),
|
|
|
|
c_db_my_query(SQL,ResultSet,Con,Mode,_),
|
|
|
|
!,c_db_my_row(ResultSet,Arity,LA)
|
2016-07-31 16:02:06 +01:00
|
|
|
; ConType == postgres ->
|
|
|
|
postgres_result_set(Mode),
|
|
|
|
c_postgres_query(SQL,ResultSet,Con,Mode,_),
|
|
|
|
!,c_postgres_row(ResultSet,Arity,LA)
|
|
|
|
; ConType == odbc ->
|
|
|
|
odbc_result_set(Mode),
|
|
|
|
c_odbc_query(SQL,ResultSet,Con,Mode,_),
|
|
|
|
!,c_odbc_row(ResultSet,Arity,LA)
|
|
|
|
; ConType == sqlite3 ->
|
|
|
|
sqlite3_result_set(Mode),
|
|
|
|
c_sqlite3_query(SQL,ResultSet,Con,Mode,_),
|
|
|
|
!,c_sqlite3_row(ResultSet,Arity,LA)
|
2015-03-08 02:15:53 +00:00
|
|
|
;
|
|
|
|
true
|
|
|
|
).
|
2015-02-14 11:35:07 +00:00
|
|
|
|
2006-01-10 15:37:21 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
|
|
|
|
2006-01-25 20:40:21 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_prolog_select_multi(+,+,-)
|
|
|
|
% db_prolog_select_multi(guest,[(ramos(A,C),A=C),(ramos(D,B),B=10)],[[A],[D,B]]).
|
|
|
|
%
|
2006-01-25 20:40:21 +00:00
|
|
|
db_prolog_select_multi(Connection,DbGoalsList,ListOfResults) :-
|
2015-03-08 02:15:53 +00:00
|
|
|
'$error_checks'(db_prolog_select_multi(Connection,DbGoalsList,ListOfResults)),
|
|
|
|
'$create_multi_query'(ListOfResults,DbGoalsList,SQL),
|
|
|
|
|
|
|
|
get_value(Connection,Con),
|
|
|
|
c_db_connection_type(Con,ConType),
|
|
|
|
'$write_or_not'(SQL),
|
|
|
|
( ConType == mysql ->
|
|
|
|
db_my_result_set(Mode),
|
|
|
|
c_db_my_query(SQL,ResultSet,Con,Mode,_)
|
2016-07-31 16:02:06 +01:00
|
|
|
;
|
|
|
|
ConType == postgres ->
|
|
|
|
postgres_result_set(Mode),
|
|
|
|
c_postgres_query(SQL,ResultSet,Con,Mode,_)
|
|
|
|
;
|
|
|
|
ConType == mysql ->
|
|
|
|
sqlite3_result_set(Mode),
|
|
|
|
c_sqlite3_query(SQL,ResultSet,Con,Mode,_)
|
|
|
|
;
|
|
|
|
ConType == mysql ->
|
|
|
|
odbc_result_set(Mode),
|
|
|
|
c_odbc_query(SQL,ResultSet,Con,Mode,_)
|
2015-03-08 02:15:53 +00:00
|
|
|
;
|
|
|
|
true
|
|
|
|
),
|
|
|
|
'$get_multi_results'(Con,ConType,ResultSet,ListOfResults).
|
2006-01-25 20:40:21 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
|
|
|
|
|
|
|
|
2006-01-09 13:38:02 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_command/2
|
|
|
|
%
|
|
|
|
%
|
2006-01-09 13:38:02 +00:00
|
|
|
db_command(Connection,SQL):-
|
2015-03-08 02:15:53 +00:00
|
|
|
'$error_checks'(db_command(Connection,SQL)),
|
|
|
|
get_value(Connection,Con),
|
|
|
|
'$write_or_not'(SQL),
|
|
|
|
c_db_connection_type(Con,ConType),
|
|
|
|
( ConType == mysql ->
|
|
|
|
db_my_result_set(Mode),
|
|
|
|
c_db_my_query(SQL,_,Con,Mode,_)
|
|
|
|
;
|
|
|
|
true
|
|
|
|
).
|
2006-01-09 13:38:02 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
2005-11-22 11:25:59 +00:00
|
|
|
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_assert/2
|
|
|
|
% db_assert/1
|
|
|
|
%
|
2006-03-03 14:14:54 +00:00
|
|
|
db_assert(PredName):-
|
2015-03-08 02:15:53 +00:00
|
|
|
db_assert(myddas,PredName).
|
2006-03-03 14:14:54 +00:00
|
|
|
|
|
|
|
db_assert(Connection,PredName):-
|
2015-03-08 02:15:53 +00:00
|
|
|
translate(PredName,PredName,Code),
|
|
|
|
'$error_checks'(db_insert2(Connection,PredName,Code)),
|
|
|
|
'$get_values_for_insert'(Code,ValuesList,RelName),
|
|
|
|
'$make_atom'(['INSERT INTO `',RelName,'` VALUES '|ValuesList],SQL),
|
|
|
|
|
|
|
|
get_value(Connection,Con),
|
|
|
|
c_db_connection_type(Con,ConType),
|
|
|
|
'$write_or_not'(SQL),
|
|
|
|
( ConType == mysql ->
|
|
|
|
db_my_result_set(Mode),
|
|
|
|
c_db_my_query(SQL,_,Con,Mode,_)
|
|
|
|
;ConType == postgres ->
|
|
|
|
postgres_result_set(Mode),
|
|
|
|
c_postgres_query(SQL,_,Con,Mode,_)
|
|
|
|
;ConType == sqlite3 ->
|
|
|
|
sqlite3_result_set(Mode),
|
|
|
|
c_sqlite3_query(SQL,_,Con,Mode,_)
|
|
|
|
;
|
2016-07-31 16:02:06 +01:00
|
|
|
c_odbc_query(SQL,_,_,_,Con)
|
2015-03-08 02:15:53 +00:00
|
|
|
).
|
2005-11-22 11:25:59 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
|
|
|
|
2015-02-14 11:35:07 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_create_table/3
|
|
|
|
% FieldsList = [field(Name,Type,Null,Key,DefaultValue)]
|
|
|
|
% Example [field(campo1,'char(12)',y,y,a),field(campo2,int,y,y,0)]
|
|
|
|
% TODO Test with ODBC & Type Checks
|
2005-12-19 13:41:15 +00:00
|
|
|
db_create_table(Connection,TableName,FieldsInf):-
|
2015-03-08 02:15:53 +00:00
|
|
|
'$error_checks'(db_create_table(Connection,TableName,FieldsInf)),
|
|
|
|
get_value(Connection,Con),
|
|
|
|
|
|
|
|
'$process_fields'(FieldsInf,FieldString,KeysSQL),
|
|
|
|
'$make_atom'(['CREATE TABLE `',TableName,'` ( ',FieldString,KeysSQL,' )'],FinalSQL),
|
|
|
|
|
|
|
|
c_db_connection_type(Con,ConType),
|
|
|
|
'$write_or_not'(FinalSQL),
|
|
|
|
( ConType == mysql ->
|
|
|
|
db_my_result_set(Mode),
|
|
|
|
c_db_my_query(FinalSQL,_,Con,Mode,_)
|
|
|
|
;ConType == posgres ->
|
|
|
|
postgres_result_set(Mode),
|
|
|
|
c_postsgres_query(FinalSQL,_,Con,Mode,_)
|
|
|
|
;ConType == sqlite3 ->
|
|
|
|
sqlite3_result_set(Mode),
|
|
|
|
c_sqlite3_query(FinalSQL,_,Con,Mode,_)
|
|
|
|
;
|
2016-07-31 16:02:06 +01:00
|
|
|
c_odbc_query(FinalSQL,_,_,_,Con)
|
2015-03-08 02:15:53 +00:00
|
|
|
).
|
2005-11-22 11:25:59 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2005-12-19 13:41:15 +00:00
|
|
|
|
|
|
|
|
2015-02-14 11:35:07 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_export_view/4
|
|
|
|
% TODO Test with ODBC
|
|
|
|
%
|
2005-12-19 13:41:15 +00:00
|
|
|
db_export_view(Connection,TableViewName,SQLorDbGoal,FieldsInf):-
|
2015-03-08 02:15:53 +00:00
|
|
|
'$error_checks'(db_export_view(Connection,TableViewName,SQLorDbGoal,FieldsInf)),
|
|
|
|
get_value(Connection,Con),
|
|
|
|
'$process_sql_goal'(TableViewName,SQLorDbGoal,TableName,SQL),
|
|
|
|
|
|
|
|
% Case there's some information about the
|
|
|
|
% attribute fields of the relation given
|
|
|
|
% by the user
|
|
|
|
( FieldsInf == [] ->
|
|
|
|
'$make_atom'(['CREATE TABLE ',TableName,' AS ',SQL],FinalSQL)
|
|
|
|
;
|
|
|
|
'$process_fields'(FieldsInf,FieldString,KeysSQL),
|
|
|
|
'$make_atom'(['CREATE TABLE ',TableName,' (',FieldString,KeysSQL,') AS ',SQL],FinalSQL)
|
|
|
|
),
|
|
|
|
|
|
|
|
c_db_connection_type(Con,ConType),
|
|
|
|
'$write_or_not'(FinalSQL),
|
|
|
|
( ConType == mysql ->
|
|
|
|
db_my_result_set(Mode),
|
|
|
|
c_db_my_query(FinalSQL,_,Con,Mode,_)
|
|
|
|
;
|
2016-07-31 16:02:06 +01:00
|
|
|
c_odbc_query(FinalSQL,_,_,_,Con)
|
2015-03-08 02:15:53 +00:00
|
|
|
).
|
2005-12-19 13:41:15 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2006-01-09 13:38:02 +00:00
|
|
|
|
|
|
|
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_update/2
|
|
|
|
% BUG: db_update dosen't work for this case, just an example
|
|
|
|
% db_update(my1,edge(1,3)-edge(99,99)).
|
|
|
|
% The case where the set condition is "set" to change all the fields
|
2006-01-09 19:07:26 +00:00
|
|
|
db_update(Connection,WherePred-SetPred):-
|
2015-03-08 02:15:53 +00:00
|
|
|
%TODO: error_checks
|
|
|
|
get_value(Connection,Conn),
|
2006-01-09 19:07:26 +00:00
|
|
|
|
2015-03-08 02:15:53 +00:00
|
|
|
% Match and Values must be "unifiable"
|
|
|
|
functor(WherePred,PredName,Arity),
|
|
|
|
functor(SetPred,PredName,Arity),
|
2006-01-09 19:07:26 +00:00
|
|
|
|
2015-03-08 02:15:53 +00:00
|
|
|
functor(NewRelation,PredName,Arity),
|
2015-02-14 11:35:07 +00:00
|
|
|
|
2015-03-08 02:15:53 +00:00
|
|
|
'$extract_args'(WherePred,1,Arity,WhereArgs),
|
|
|
|
'$extract_args'(SetPred,1,Arity,SetArgs),
|
2006-01-09 19:07:26 +00:00
|
|
|
|
2015-03-08 02:15:53 +00:00
|
|
|
copy_term(WhereArgs,WhereArgsTemp),
|
|
|
|
NewRelation=..[PredName|WhereArgsTemp],
|
|
|
|
translate(NewRelation,NewRelation,Code),
|
2006-01-09 19:07:26 +00:00
|
|
|
|
2015-03-08 02:15:53 +00:00
|
|
|
'$get_values_for_update'(Code,SetArgs,SetCondition,WhereCondition),
|
2015-02-14 11:35:07 +00:00
|
|
|
|
2015-03-08 02:15:53 +00:00
|
|
|
'$get_table_name'(Code,TableName),
|
|
|
|
append(SetCondition,WhereCondition,Conditions),
|
|
|
|
'$make_atom'(['UPDATE `',TableName,'` '|Conditions],SQL),
|
|
|
|
'$write_or_not'(SQL),
|
2016-07-31 16:02:06 +01:00
|
|
|
get_value(Connection,Con),
|
|
|
|
c_db_connection_type(Con,ConType),
|
|
|
|
( ConType == mysql ->
|
2015-03-08 02:15:53 +00:00
|
|
|
db_my_result_set(Mode),
|
2016-07-31 16:02:06 +01:00
|
|
|
c_db_my_query(SQL,_,Conn,Mode,_)
|
2016-11-16 23:17:33 +00:00
|
|
|
;
|
2016-07-31 16:02:06 +01:00
|
|
|
ConType == mysql ->
|
|
|
|
postgres_result_set(Mode),
|
|
|
|
c_postgres_query(SQL,_,Conn,Mode,_)
|
|
|
|
;
|
|
|
|
ConType == sqlite3 ->
|
|
|
|
sqlite3_result_set(Mode),
|
|
|
|
c_sqlite3_query(SQL,_,Conn,Mode,_)
|
|
|
|
;
|
|
|
|
ConType == odbc ->
|
|
|
|
odbc_result_set(Mode),
|
|
|
|
c_odbc_query(SQL,_,Conn,Mode,_)
|
|
|
|
).
|
2005-12-19 13:41:15 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_get_attributes_types/3
|
|
|
|
% db_get_attributes_types/2
|
|
|
|
%
|
2006-03-03 14:14:54 +00:00
|
|
|
db_get_attributes_types(RelationName,TypesList) :-
|
2015-03-08 02:15:53 +00:00
|
|
|
db_get_attributes_types(myddas,RelationName,TypesList).
|
2005-12-19 13:41:15 +00:00
|
|
|
db_get_attributes_types(Connection,RelationName,TypesList) :-
|
2015-03-08 02:15:53 +00:00
|
|
|
'$error_checks'(db_get_attributes_types(Connection,RelationName,TypesList)),
|
|
|
|
get_value(Connection,Con),
|
|
|
|
c_db_connection_type(Con,ConType),
|
|
|
|
( ConType == mysql ->
|
|
|
|
c_db_my_number_of_fields(RelationName,Con,Arity)
|
|
|
|
;
|
2016-07-31 16:02:06 +01:00
|
|
|
ConType == postgres ->
|
|
|
|
c_postgres_number_of_fields(RelationName,Con,Arity)
|
|
|
|
;
|
|
|
|
ConType == sqlite3 ->
|
|
|
|
c_sqlite3_number_of_fields(RelationName,Con,Arity)
|
|
|
|
;
|
|
|
|
ConType == odbc ->
|
|
|
|
c_odbc_number_of_fields(RelationName,Con,Arity)
|
2015-03-08 02:15:53 +00:00
|
|
|
),
|
|
|
|
Size is 2*Arity,
|
|
|
|
'$make_a_list'(Size,TypesList),
|
|
|
|
c_db_connection_type(Con,ConType),
|
|
|
|
( ConType == mysql ->
|
|
|
|
c_db_my_get_attributes_types(RelationName,Con,TypesList)
|
|
|
|
;
|
2016-07-31 16:02:06 +01:00
|
|
|
ConType == odbc ->
|
|
|
|
c_odbc_get_attributes_types(RelationName,Con,TypesList)
|
2015-03-08 02:15:53 +00:00
|
|
|
).
|
2005-12-19 13:41:15 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
|
|
|
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_number_of_fields/3
|
|
|
|
%
|
|
|
|
%
|
2006-03-03 14:14:54 +00:00
|
|
|
db_number_of_fields(RelationName,Arity) :-
|
2015-03-08 02:15:53 +00:00
|
|
|
db_number_of_fields(myddas,RelationName,Arity).
|
2005-12-19 13:41:15 +00:00
|
|
|
db_number_of_fields(Connection,RelationName,Arity) :-
|
2015-03-08 02:15:53 +00:00
|
|
|
'$error_checks'(db_number_of_fields(Connection,RelationName,Arity)),
|
|
|
|
get_value(Connection,Con),
|
|
|
|
c_db_connection_type(Con,ConType),
|
|
|
|
( ConType == mysql ->
|
|
|
|
c_db_my_number_of_fields(RelationName,Con,Arity)
|
|
|
|
;ConType == postgres ->
|
|
|
|
c_postgres_number_of_fields(RelationName,Con,Arity)
|
|
|
|
;ConType == sqlite3 ->
|
|
|
|
c_sqlite3_number_of_fields(RelationName,Con,Arity)
|
|
|
|
;
|
2016-07-31 16:02:06 +01:00
|
|
|
c_odbc_number_of_fields(RelationName,Con,Arity)
|
2015-03-08 02:15:53 +00:00
|
|
|
).
|
2005-12-19 13:41:15 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2006-01-17 22:54:02 +00:00
|
|
|
|
|
|
|
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2015-03-08 02:15:53 +00:00
|
|
|
% db_multi_queries_number(+,+)
|
|
|
|
% TODO: EVERITHING
|
|
|
|
%
|
2006-01-17 22:54:02 +00:00
|
|
|
db_multi_queries_number(Connection,Number) :-
|
2015-03-08 02:15:53 +00:00
|
|
|
'$error_checks'(db_multi_queries_number(Connection,Number)),
|
|
|
|
get_value(Connection,Con),
|
|
|
|
c_db_multi_queries_number(Con,Number).
|
2006-01-17 22:54:02 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
|
|
|
|
2017-10-18 17:02:27 +01:00
|
|
|
|