Premium Only Content
SQLite in Production - Master Course
SQLite is perfect for production of most websites
And here I’ll show how to run SQLite in production
It is short video
as there are not much to learn
with sqlite
We’ll also see why it is possible
and why you want to do so
Let’s get to it
Why?
Why would you use SQLite in production?
In short:
Simple and easy
That makes it robust
Extremely fast as there’s no server
If you’re not convinced
then checkout my video called “SQLite is enough”
You can find that in the description
Configuration
SQLite is a so called zero-configuration database
and that’s mostly true
Now, I’d like to highlight 3 configurations that you should probably do
1. journal mode
You probably want to configure SQLite to use
the journal mode WAL = Write Ahead Log
You do this by
PRAGMA journal_mode = wal;
and you only need to do this once
What this does is it sacrifices a little bit of atomicity for a shit tonnes performance.
I always put this on.
I also heard there’s a new wal2
but I have no experience with this
But you should probably take a look at that
2. Foreigns keys
In Sqlite3 the foreign keys are not enforced by default
You can do this by using
PRAGMA foreign_keys = ON;
This have a small effect on performance,
but you should probably do it.
Now I haven’t done it,
and I already shot myself in the foot a few times because of
I will do that in the next project
3. Strict table
Sqlite forgives you if you do weird shit
Such as inserting string into a int
Now that’s usually not a good idea
and since version 3.37
you can now make a table strict by adding prepending “strict” when creating a table
CREATE TABLE Goleko(age INTEGER) STRICT;
Now I haven’t done this as well
and again
I shot myself in the foot a few times
So I’ll probably do this in my next projects
Intersting opportunities as files
Your sqlite database is just a file
and it gives interesting opportunities to play around
Let’s say you make a system that have have organizations
Then you could have a database for each organization.
Futuremore, you could distribute those databases to an region
Making it easier to be GDPR compliant and improve latency for the users
You can also very easily just copy the prod db to testing environments
Indices / indexes
Indexes are some of the most important things in databases
not only in traditional databases,
but also in sqlite.
So, if your database is slow
checkout how to do indexes
as they will greatly improve performance
Performance consideration
You don’t need to worry that much about performance of SQLite databases
For most cases,
if you put write ahead logging on it is good enough
However, if you’re in a write heavy environment you might need to do
connection pooling as writes are serialized.
Now, this is the champagne problem,
and so be happy when you are gifted that problem
Example PocketBase uses SQLite and boast a 10k connection on just a 4 euro Hetnzer machine
That’s enough for 95% of the websites out there.
-
2:53
GreenMan Studio
12 hours agoGREENMANS STOCKING STUFFERS 2 – GRIMMS CAMPING SUPPLIES
483 -
42:06
Rpurham
19 hours agoSpecial guest: Sam Anthony, CEO & Founder, [your] News
25 -
15:23
Standpoint with Gabe Groisman
17 hours agoDual Citizenship Coming to an End? US Senator Bernie Moreno
61.1K17 -
1:22:19
FreshandFit
10 hours agoGirls Try To Get 60 Year Old Granny To Do OF
352K126 -
3:05:53
Decoy
10 hours agoNobody is talking about this..
90.2K25 -
1:57:00
Badlands Media
16 hours agoBaseless Conspiracies Ep. 163: False Memories, MKUltra & the Machinery of Disbelief
85.3K23 -
5:34:44
Drew Hernandez
1 day agoERIKA KIRK & CANDACE OWENS CEASEFIRE SUMMIT?
50.4K29 -
1:37:33
efenigson
19 hours agoUnapologetically Yourself: The Courage to Speak & Be Different - Zuby | Ep. 111
65.7K6 -
1:07:27
Inverted World Live
9 hours agoAI Person of the Year & Robot Wolves in Japan | Ep. 153
90.3K12 -
3:03:11
TimcastIRL
11 hours agoRob Reiner MURDERED, Son Arrested, Trump Faces Backlash Over Comments | Timcast IRL
308K176