The Lack of a Small Unified Database
Many desktop users do not have the skills or, frankly, any real need to install and manage a multiuser database server. They still need, however, to use and exchange SQL databases. Unfortunately, many developers fail to see this situation as a problem and dismiss it, at least initially, with any combination of these responses:
It now is so easy to install PostgreSQL, MySQL or any other RDBMS server, desktop users should install one of them.
Program X also is available for Windows/Mac/whatever, so just install it.
If anything, we only need to improve the interface and/or the documentation to do the above.
Nothing technically is wrong with these arguments, but they simply don't apply to the niche sector of soho and corporate users. Nobody in this sector is whining because installing a server requires two or one mouse click instead of zero. But there is a huge difference between a perfect, completely documented install wizard for any SQL server and what those users currently are getting.
Everybody says how great file sharing is. Okay, so answer this one: how can a Linux/KOffice geek share his book or recipe database with his aunt, who is running Windows/OO.o? How can an employee send a product database from his MAC/OO.o desktop to a potential corporate customer running Solaris/KOffice? What if the receiver has no root password or permission to install extra software, the standard situation in most offices? In general, in the real world, the "just install and configure this" attitude doesn't make sense and doesn't help information to flow freely. This attitude can be just as impractical, if not impossible, as having to install a new font or print server simply to open a text file.
Currently, free software users are missing a single-file SQL standard format, which may be a tar or ZIP archive, that contains everything needed by a generic frontend to let people work: schemas, data, indexes, forms structures and so on. Such databases could be copied immediately, uploaded to a Web server or sent by e-mail, the same as any other file. Users would have the certainty that the receiver immediately could access all the data, queries and forms, even if they might look different. Above all, it would be great if such a file format became an OASIS standard, because it would make it much easier to accept in corporate or government scenarios.
In the text/spreadsheet/presentation space, the Right Thing already is happening. The two most popular free office software suites, OO.o and KOffice, are converging on the same default file format, which is an OASIS standard. This means being able to write, read and share such documents today between OO.o KOffice and tomorrow with any other OASIS-compliant application--transparently. This level of standardization also gives much more credibility and strength to Free Software.
Wouldn't it be really great and isn't it time to do the same thing for simple SQL databases? Without, of course, preventing anybody who wants a full blown RDBMS daemon from using it? Today, such databases are not covered or influenced by OASIS. I say that they should be. The rest of this article proposes a way to achieve this goal.
The first two applications that should converge on this database standard are OpenOffice.org (OO.o) and KOffice. OO.o has data sources, meaning it can connect to external RDBMS servers and can use single-file databases in dBase format, whose features simply are too limited. When I started to investigate this matter, I learned that OO.o developers already have begun working on improving support for a server-less database engine. Standardization, however, simply isn't among their objectives right now, though. What they anticipate today to include in OO.o 2.0 (alpha snapshot available here) is a database file format that is XML-based and that contains everything except the actual data (forms, reports, queries and administrative information).
When I asked, I was told that the most probable file format choice is HSQLDB, mainly because it supports more features than its competitors do. Personally, I am against this choice for four reasons. The first is performance (read more here and here), especially considering that OO.o doesn't need to remain as heavy as it is today. The second reason is HSQLDB requires Java, and I don't like the idea of depending on third-party elements, as it makes it more likely that these single-file DBs don't work in practice when moved from PC to PC. The third reason is many other application and languages in the free software arena have partially converged on something else (more on this in a moment), so I think OO.o should be a good community citizen and follow suit. Hence, my fourth reason: by not proposing a portable standard in OO.o, OO.o users would be in the position of saying to everybody else "yes, we are using this so called "free" software, but if you want to share small databases transparently, please force yourself to freely install OO.o, HSQLDB/Java or any combination of the above".
Articles about Digital Rights and more at http://stop.zona-m.net CV, talks and bio at http://mfioretti.com
Today’s modular x86 servers are compute-centric, designed as a least common denominator to support a wide range of IT workloads. Those generic, virtualized IT workloads have much different resource optimization requirements than hyperscale and cloud applications. They have resulted in a “one size fits all” enterprise IT architecture that is not optimized for a specific set of IT workloads, and especially not emerging hyperscale workloads, such as web applications, big data, and object storage. In this report, you will learn how shifting the focus from traditional compute-centric IT architectures to an innovative disaggregated fabric-based architecture can optimize and scale your data center.
Sponsored by AMD
Built-in forensics, incident response, and security with Red Hat Enterprise Linux 6
Every security policy provides guidance and requirements for ensuring adequate protection of information and data, as well as high-level technical and administrative security requirements for a system in a given environment. Traditionally, providing security for a system focuses on the confidentiality of the information on it. However, protecting the data integrity and system and data availability is just as important. For example, when processing United States intelligence information, there are three attributes that require protection: confidentiality, integrity, and availability.
Learn more about catching the bad guy in this free white paper.
Sponsored by DLT Solutions
| Making Linux and Android Get Along (It's Not as Hard as It Sounds) | May 16, 2013 |
| Drupal Is a Framework: Why Everyone Needs to Understand This | May 15, 2013 |
| Home, My Backup Data Center | May 13, 2013 |
| Non-Linux FOSS: Seashore | May 10, 2013 |
| Trying to Tame the Tablet | May 08, 2013 |
| Dart: a New Web Programming Experience | May 07, 2013 |
- RSS Feeds
- Making Linux and Android Get Along (It's Not as Hard as It Sounds)
- New Products
- Drupal Is a Framework: Why Everyone Needs to Understand This
- A Topic for Discussion - Open Source Feature-Richness?
- Home, My Backup Data Center
- Validate an E-Mail Address with PHP, the Right Way
- Tech Tip: Really Simple HTTP Server with Python
- Trying to Tame the Tablet
- New Products
- git-annex assistant
4 hours 9 min ago - direct cable connection
4 hours 31 min ago - Agreed on AirDroid. With my
4 hours 42 min ago - I just learned this
4 hours 46 min ago - enterprise
5 hours 16 min ago - not living upto the mobile revolution
8 hours 7 min ago - Deceptive Advertising and
8 hours 43 min ago - Let\'s declare that you have
8 hours 44 min ago - Alterations in Contest Due
8 hours 45 min ago - At a numbers mindset, your
8 hours 46 min ago
Enter to Win an Adafruit Prototyping Pi Plate Kit for Raspberry Pi

It's Raspberry Pi month at Linux Journal. Each week in May, Adafruit will be giving away a Pi-related prize to a lucky, randomly drawn LJ reader. Winners will be announced weekly.
Fill out the fields below to enter to win this week's prize-- a Prototyping Pi Plate Kit for Raspberry Pi.
Congratulations to our winners so far:
- 5-8-13, Pi Starter Pack: Jack Davis
- 5-15-13, Pi Model B 512MB RAM: Patrick Dunn
- Next winner announced on 5-21-13!
Free Webinar: Linux Backup and Recovery
Most companies incorporate backup procedures for critical data, which can be restored quickly if a loss occurs. However, fewer companies are prepared for catastrophic system failures, in which they lose all data, the entire operating system, applications, settings, patches and more, reducing their system(s) to “bare metal.” After all, before data can be restored to a system, there must be a system to restore it to.
In this one hour webinar, learn how to enhance your existing backup strategies for better disaster recovery preparedness using Storix System Backup Administrator (SBAdmin), a highly flexible bare-metal recovery solution for UNIX and Linux systems.



Comments
I think it should be mentione
I think it should be mentioned (a long time after the release of this article) that koffice is now standardising on the same format as OO. I presume that this will mean they will naturally move to the same native database format. So the standardisation is happening. Maybe this article helped?
Cheers
Antoine
Re: The Lack of a Small Unified Database
You forgot to mention that there's already a native OO.o 1.1.x
SQLite driver available (alpha-version, only tested on Linux).
More information here.
Re: The Lack of a Small Unified Database
I submitted this article some time ago. As far as I remember (should check
my notes at home to be sure), that page had not been mentioned back then by any
of the developers I spoke with, but I might be wrong.
Thanks for pointing it out, of course it helps to reach the unified database
goal
Marco F.
unified database
In the DOS world I used to use a simple integrated package called Alpha Works. It had spreadsheet, database, word processor, communications, shell access all in one piece of software. The database format was dBase III+. When I moved to Windows, I began using Microsoft Works. The database service (or should I call it the "table" service) provided filtering, sorting, some formulas that were similar to what was available in the spreadsheet, table reporting and a form view. I have been using it for years and it has become my favorite application. The spreadsheet is more than adequate (most users aren't plotting space craft trajectories or performing complex matrix algebra). Excel has more than most users need and so does Word. Oddly enough, Works was free with the computer but I have yet to find anybody around me who uses it. They all went out and bought Excel and Word and the fact is they do far less on their systems than me. I am a sales rep handling multiple companies and multiple customers who buy some lines but not others. The database files aren't large 2 - 3000 records. The MSWorks program works totally in memory so sorting and filters are instantaneous. I can cut and paste records easily into the spreadsheet and into my Windows version of Open Office which I used to set up the order forms that my companies require (each requires a different order form). I use Open Office for this because the Works spreadsheet doesn't allow the embedding of graphics my orders often require graphic representations of what I need. I export the forms to pdf and email them to the various companies. So what is Linux missing ? (I'm writing this on my Linux system now) Something like Microsoft Works. A full integrated set of applications that isn't overloaded with features most people never use, allows easy cutting and pasting as well as database field embedding in form letters, has a small footprint, runs in memory and can export and import all the basic file formats (as Microsoft Works can). Then I would ditch Windows for good. Not that everything would be great with Linux. There's still the problem of driver support especially wireless USB and printers. My laptop's Linksys USB 1.0 802.11.b wireless network device is not recognised and my workhorse cheap Konica Minolta laser printer has no drivers for Linux. I know there is a ton of software available for Linux but the average user doesn't need a ton. A Swiss army knife with a couple of good blades, a scissors and a screwdriver covers alot of needs. Keep the corkscrew and the toothpick.