Creating a LibreOffice Music Database
Tune Finder
LibreOffice Calc and Base are all you need to create a simple database for organizing the songs in your music collection.
MySQL is the most commonly used open source database management system. Developers often use MySQL and its cousin MariaDB to build database applications for organizing office records, managing inventories, and other common tasks. However, MySQL is often too complex and too much trouble for personal, home-office uses. LibreOffice offers a simpler alternative for users who just want to create a small, simple database to address a specific need. This article describes how to create a quick and easy database solution using LibreOffice tools. In this case, I'll show you how to set up a music database from an iTunes library.
The Plan
I'll use two tools from the LibreOffice integrated suite to create my music database: LibreOffice Calc (spreadsheet) and LibreOffice Base (database management). With these two applications plus iTunes, the general process is as follows:
- Export library from iTunes as a tab-separated text file.
- Import library into LibreOffice Calc for minor edits.
- Copy modified library data into LibreOffice Base.
- Create SQL queries.
- Run queries and filters to display results.
Of course, you can adapt this process for other types of data. For instance, you could organize a stamp collection or track incoming invoices for this year's taxes.
Export from iTunes
The first step is to export music information from iTunes to a text file in a format that can be imported into LibreOffice. Playlists can be exported from iTunes as a table in a tab-delimited plain text file format. The comma-separated values (CSV) format is unacceptable because some data fields (such as album titles, song titles, or artist names) may contain commas or other special characters. The exported playlist may consist of some or all of the songs in the library. I use the following steps to export my playlist:
- Select all songs in the library
- Go to File | Library | Export Playlist
- In the File name field, enter Music.txt
- Select Text file (*.txt)
These steps save the playlist as a tab-separated text file, Music.txt
(but you choose any name you want), that can be directly imported as a plain text spreadsheet.
Import Text File into LibreOffice Calc
Next, I import the tab-separated file Music.txt
into LibreOffice Calc for minor editing. When I open the text file, LibreOffice Calc pops up a Text Import dialog box with the option to select or change the delimiter. To import the file into Calc:
- Go to File | Open
Select Text documents from the file type drop-down menu (Figure 1)
- Select Music.txt
- Click Open
In the Text Import dialog box that opens, check the Tab option under Separator Options and uncheck the other options here (Figure 2)
- Examine the preview in the Fields section
- Click OK
iTunes exports many data fields as table columns, and some of them are not useful or wanted. Because I am only interested in Name (song title), Artist, Album, Genre, Track Number, and Year, I delete all columns except for these. I also insert an ID field to be used as a primary key (which I will discuss in the database section of this article.)
To insert the ID field (shown in Figure 3), follow these steps:
- Insert a column in the first position, left of the Name column: Sheet | Insert Columns | Columns Left
- Label the new column ID
- Leave cells in the ID column blank (they will be automatically filled in LibreOffice Base)
- Click Save
- Optionally, leave LibreOffice Calc open to cut and paste data later.
At this point, I have the data that I need to populate the database. I need to get that spreadsheet data into a database. To create my music database, I will now use LibreOffice Base, which can create, manage, and edit flat and relational databases.
Buy this article as PDF
(incl. VAT)
Buy Linux Magazine
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters
Support Our Work
Linux Magazine content is made possible with support from readers like you. Please consider contributing when you’ve found an article to be beneficial.
News
-
Canonical Offers 12-Year LTS for Open Source Docker Images
Canonical is expanding its LTS offering to reach beyond the DEB packages with a new distro-less Docker image.
-
Plasma Desktop 6.1 Released with Several Enhancements
If you're a fan of Plasma Desktop, you should be excited about this new point release.
-
SUSE Offers CentOS 7 Support with Liberty Linux Lite
SUSE's Liberty Linux support offering now includes CentOS 7, which means businesses won't be forced to migrate those servers for some time.
-
Ubuntu's App Center Finally Supports Local Installs Again
If you regularly download .deb files and would prefer a GUI method of installing, Ubuntu has your back.
-
AlmaLinux Now Supports Raspberry Pi 5
If you're looking to create with the Raspberry Pi 5 and want to use AlmaLinux as your OS, you're in luck because it's now possible.
-
Kubuntu Focus Releases New Iterations of Ir14 and Ir16 Laptops
If you're a fan of the Kubuntu Focus laptops or have been waiting for the right time to purchase one, that time might be now.
-
NixOS 24.05 Is Ready for Prime Time
The latest release of NixOS (Uakari) has arrived and offers its usual reproducible, declarative, and reliable goodness.
-
Linux Lite 7.0 Officially Released
Based on Ubuntu 24.04 and kernel 6.8, Linux Lite version 7 now offers more options than ever.
-
KaOS Linux 2024.05 Adds Bcachfs Support and More
With updates all around, KaOS Linux now includes support for the bcachefs file system.
-
TUXEDO Computers Unveils New Iteration of the Stellaris Laptop Line
The Stellaris Slim 15 is the 6th generation and includes either an AMD or Intel CPU