Microsoft spent years and years trying to get people to not use Excel as a database, until they eventually had to give up hope that anyone who doesn’t know the difference would voluntarily use Access, so they started adding database-like functionality to Excel to meet their customer’s demands and try to make the experience at least a little bit less painful.
This is a real-life case of “meet the user where they are” despite the designer’s wishes, because even within Microsoft, there is strong agreement on not using Excel as a DB.
I only ever encountered Access was once many years ago and I was warned that it had issues with multiple users.
Well, to be fair to Access, it’s not like Excel is such a great multi-user database either, now is it? ;-)
Well excel nowadays doesn’t have issues with concurrent users if you have office 365 like many companies do.
At that time it was Access with the files located at a company shared drive, the issue was concurrent writes I believe.
Better yet, put your access backend to OneDrive to acquire an un-openable, un-deletable file.
I actually ran this setup for a pretty long while without major issues. YMMV but OneDrive is not a terrible way to store a single user database backend if you don’t have a lot of sequential writes going into it in a short timespan.
Yes, but at the time Excel didn’t support concurrency either ;-)
Anyway, you are correct about the issue with concurrent writes, but that’s only because Access was intended as a single user DB. If you wanted a multi-user DB you should be getting MS SQL server.
Not saying this product strategy worked (it clearly didn’t, otherwise people would not be using Excel), but that’s how they envisioned it to work.
i…isn’t that the entire point of excel? what is it for if not to store data?
similarly i remember a reddit comment that broke my brain, saying no one should be using excel, they should be using a ‘cell matrix organizer’ or similar. we all can name 5 off the top of our heads
Excel has a purpose, but storing data long term isn’t it. It’s for calculating data. It shouldn’t be the single source of truth.
One of the things Microsoft did to make it work was extending the row limit from 65k to 1M. Apparently, Economics professors were very excited about that one, which explains a lot.
Excel is this weird mix of storing small amounts of data but so good for visualizing data. If people are saying it shouldn’t be used to store data they mean massive amounts of data as opposed to something like some small scale accounting for a fund raiser.
Storing data is only one of the parts to the formula of what makes a database. Proper databases require structured storage of the data and some way to query the data constructively. Excel did not have those features until Microsoft gave up trying to convince people to not use it as a DB and added it to Excel.
No simple way to join tables though, which is still pretty shocking to me.
Last panel is wrong. Genie would just grant him an MBA from a top tier school
It would be funnier if the genie says “there are two rules”
3gb CSV file goes brrrr…
Should’ve been the version saying:
Geanie: “It is done”
Person: “But… nothing changed”
G: “Correct”
May I introduce you: webxcel
What the fuck. Thanks for sharing!
“I have to make a brochure for the printing shop and I’d like to compose it in Excel”
“There are actually five rules…”
“In Powerpoint?”
“Make that six.”
Except PowerPoint is actually quite nice to make quick, easy and good looking visualizations and brochures without having to deal with Word
Well, Word isn’t really a good choice either.
It’s the most approachable for most people. For real graphics design more professional tools are available
like Paint
Paint?
matplotlib
I can personally attest to entire universities advocating for student use of powerpoint for all sorts of printshop work to include thesis and capstone presentation posters for conferences :)
For people who don’t want to spend time learning yet another single-purpose application, it works quite well
Use Libreoffice Draw
Don’t be gross, use CSV files
I mean it’s a simple file format so it’ll perform better because it doesn’t have to decode any complex formats or protocols.
Big O? Never heard of it!
CSV is great but the byte loss on numbers is sometimes gruesome.
My 5th rule would be “no ‘fix my IT problem without me telling you what the error message says’”. Because fuck that
Error 0x2e8da08150469
That would be something I could google. So not completely useless.
How about “An error message on my screen”?
This is basically what I run for a living and it’s definitely not glamorous.
I work as a network tech for a globally spanning ISP specializing in fiber services, handling major maintenances that are service effecting for business and government customers (SLAs are in effect). These maintenances are planned and tracked through various excel sheets - housed either in a shared network drive (so yeah, we may run into issues where multiple people are trying to edit the same doc at once), or excel tables in a SharePoint.
Prior to the merger of companies I recently went through, we had actual database systems to track this stuff that worked just fine. And now we’re relying on the same shit a grad student would use to track their doctorate progress. It’ll work until it doesn’t. Looking forward to the shit-show if it gets me overtime.
I feel you. Working in healthcare, ms office is the only thing consistently installed site wide I can take advantage of to run a db.
Couldn’t you use Access instead of Excel or is that not possible for your use case?
Unfortunately IT blocked Access installs because some staff were using it for mission critical processes, and upon leaving IT were required to maintain them. They felt excel was less likely to lead to scenarios like this.
Little did they know excel projects are probably worse to maintain.
My old ass crying in MS Access
one of our partners we have to integrate with at work sends us reports in ms access format. it’s not fun, especially when everything is running in lambda and there doesn’t seem to be any good libraries for reading ms access files that would easily run in lambda.
Kind of related question: Is it okay for me to use JSON as a small DB? I just store basic blog page data there.
I mean it will work, but for a blog I’d store the pages in markdown files, to make it easier to edit. For context, look into how Hugo works
I thought of that as well. I might switch to that. It will make the organization better anyways.
A few circumstances to consider…
If it’s just your own little tool and you don’t intend to share it with others: do whatever you want. SQL or NoSQL or JSON, it doesn’t matter. Use your own judgement.
In my experience tho most homegrown JSON-based “databases” tend to load all data into the memory, simply because they are very simplistic (serialize everything into JSON and write to disk, deserialize everything into a struct). If your dataset is too big for that, just go straight for a full-fledged database.
TinyDB literally does this. in general its more of does this work for my use case and am i aware of its limitations.
If it works then it works.
yep, though IO might bottleneck you at some point, and then you can happily switch to mongoDB
then you can happily switch to mongoDB
Honestly, since the introduction of ‘tables’, pivot tables, Power Pivot and Power Query, Excel is way more viable to be used as a database. Tables in particular mean that formulas fill down and the range automically resizes when records are added.
Iirc tables are actually treated similar to databases on the backend.
Database? Good.
I use it to connect to another Excel “database” and generate a PDF form to print. No other way around unfortunately.
It can handle more than a million rows so why not?
A million rows sounds like a lot until you need more than that
Isn’t the Genie usually depicted as malicious, or at least mischievous? I would expect the Genie to grant the wish, knowing what a shitshow it would be.