This is a Java application for loading MEDLINE XML files into a relational database (currently supporting SQL Server and PostgreSQL). The application was designed with two goals in mind:
-
Everything in the XML files needs to go into the database.
-
Any changes in the XML structure that occur over the years should not require changing the program.
The application is run in two phases:
-
During analysis, the structure and contents of a large set of XML files is analysed, and a database structure is build to accomodate the data. This is typically done only once a year.
-
During parse, all XML files in a folder are parsed and their contents are inserted into the database. This is typically done every time new XML files are available from MEDLINE.
This is still very much work in progress. See the MainClass to see how one could run this Java project. If you have Ant installed on your system, you might be able to load MEDLINE using Ant targets (see below). Note that you would need your customized 'ini' file to be called 'MedlineXmlToDatabase.ini' and be located in this folder.
Note that the application works directly of the GZipped XML files, so no need to unzip them.
-
Download all xml.gz files from MEDLINE (see http://www.nlm.nih.gov/databases/license/license.html for licensing information)
-
Create an ini file according to the example in the iniFileExamples folder, pointing to the folder containing the xml.gz files, and the server and schema where the data should be uploaded
-
Compile all java classes. If you have Ant installed you can run the 'compile' target
-
Run the MainClass with parameters
-analyze -ini <path to ini file>
to create the database structure. If you have Ant installed you can run the 'run-analyzer' target. On Linux, run it using nohup so that the process is not dependent on the terminal session that starts it: 'nohup ant -noinput run-analyzer &' -
Run the MainClass with parameters
-parse -ini <path to ini file>
to load the data from the xml files into the database. If you have Ant installed you can run the 'run-parse' target. On Linux, run it using nohup so that the process is not dependent on the terminal session that starts it: 'nohup ant -noinput run-parse &'
$ sudo -i -u postgres
postgres$ createuser --interactive
# create the medline user
postgres$ createdb medline
postgres$ psql
postgres: ALTER ROLE medline WITH PASSWORD '<password>'
postgres: \q
-
run the following query as the database user from within psql
-
copy and paste the output within psql
SELECT 'drop table if exists "' || tablename || '" cascade;'
FROM pg_tables
WHERE schemaname = 'public';
This can be done from pgadmin. The backup file for 'medline' can then be moved to a different database and restored using the following commands as the postgres super-user:
$ sudo -i -u postgres
postgres$ createuser --interactive
# create the medline user
postgres$ createdb -T template0 medline
postgres$ pg_restore -d medline <path to the dump file>