Hi,
Thank you for you responses @ThomasH and @StarWind Software. I could figure out the solutions using the code sames that you pointed out. Well here is a complete picture. I am sure there are so many people out there who need a clear picture of connection from Prolog to a Database.
Notes:
- You can connect to any database from within swi-prolog. I used Oracle 10g and MySQL 5.
First of all download the 'SWI-Prolog' ODBC Interface from here.
There are two main 'dll' files in the package 'ODBCProlog.dll' and 'OracleProlog.dll'
Next, this is the sample code which is same as above one. I Will explain the sections
MYSQL CONNECTION IN PROLOG
:- use_module(oracle).
go :-
db_open('mysql5', 'root', 'admin'),
db_import('EMP'('EMPID', 'EMPNAME'), emp),
%%db_flag(show_query, _, off),
db_query(emp(EMPID, EMPNAME), emp(EMPID, EMPNAME)),
%% Run the query.
get_result,
%% Modify the database.
%%emp_ins(109, 1, 221),
%%test_del(109, 1, 221),
%% Commit changes.
db_transaction(commit),
db_close.
%% Retrieve all records over backtracking.
get_result:-
emp(EMPID, EMPNAME),
write_ln([EMPID, EMPNAME]),
fail.
get_result.
Now the explanation part:
db_open('mysql5', 'root', 'admin'),
the first part 'mysql5' the dsn name for mysql. If you do nmot have it installed in your system, you can download it from the MySQL website. The next one is username and password.
db_flag(show_query, _, off),
prints the SQL statements in the output. commenting it will prevent it from outputting the SQL query.
db_import('EMP'('EMPID', 'EMPNAME'), emp),
Here 'EMP' is the actual table name in the database and 'emp' is its alias.
It is important to create this way otherwise it will not work.
db_query(emp(EMPID, EMPNAME), emp(EMPID, EMPNAME)),
next for quering the database the above call 'db_query' will take 2 arguments. You can either query two tables using this like a JOIN statement. If you are using just quering one table then it is necessary to give the same query twice as this call expects two arguments.
Is you need to insert anything in the database uncomment
emp_ins(109, 1, 221),
This convention is nothing but you are adding _ins to the alias name which is understood by the prolog that it is an insert call to database.
similarly
emp_del(109, 1, 221),
I guess the rest is self explanatory.
Now, the next part is if you need to connect to Oracle database then the only statement that changes is :
:- use_module(odbc).
The rest is pretty same. One thing you have to remember is that you need to use the oracle INSTANCE name while specifying the database.
Usually in Oracle 10g the instance name is 'orcl' and for Oracle Express edition the convention is :
'your full computer name:port/XE','username','password'
You WILL be able to connect to database and display the results with this block of code,
Hope this helps.