-
Notifications
You must be signed in to change notification settings - Fork 1.2k
SQL DDL Course
DDL Course Overview
Below you can find the ordered content of the topic, in a linear progression
The linear progression of content aims to cover all content, course by course, workout by workout as follows:
- first course is the only core one, denoted by its manifest
- the next course is denoted by the first item of the next array in each course manifest
- each course has its order of workouts designated by the sections field in the same aforementioned manifest
1. create
Insights:
no | name | content | aspects | standards | PQ | RQ | Quiz | done |
---|---|---|---|---|---|---|---|---|
1 | create-a-database | ✅ | 👶 introduction 💪 workout |
create-database.0: 10 | ✅ | ✅ | ❌ | ✅ |
2 | create-a-table | ✅ | 👶 introduction 💪 workout |
define-tables.0: 10 define-tables.1: 10 |
✅ | ✅ | ❌ | ✅ |
Exercises:
no | name | type | aspects | standards | done |
---|---|---|---|---|---|
1 | sql-practice-create-table | sqlfiddle | 👶 introduction 💪 workout |
define-tables.0: 1000 define-tables.1: 1000 define-tables.4: 1000 choose-sql-datatype.1: 1000 choose-sql-datatype.2: 1000 define-columns.0: 3000 |
✅ |
2 | sql-practice-create-table-2 | sqlfiddle | 👶 introduction 💪 workout |
define-tables.0: 1000 define-tables.1: 1000 define-tables.4: 1000 choose-sql-datatype.1: 1000 choose-sql-datatype.2: 1000 define-columns.0: 5000 |
✅ |
3 | sql-practice-create-table-3 | sqlfiddle | 👶 introduction 💪 workout |
define-tables.0: 1000 define-tables.1: 1000 define-tables.4: 1000 choose-sql-datatype.1: 1000 choose-sql-datatype.2: 1000 define-columns.0: 4000 |
✅ |
4 | sql-practice-create-table-4 | sqlfiddle | 👶 introduction 💪 workout |
define-tables.0: 1000 define-tables.1: 1000 define-tables.4: 1000 choose-sql-datatype.1: 1000 choose-sql-datatype.2: 1000 define-columns.0: 6000 |
✅ |
5 | sql-practice-define-relationships | sqlfiddle | 👶 introduction 💪 workout 🦑 deep |
define-relationships.1: 1000 | ✅ |
6 | sql-practice-define-relationships-2 | sqlfiddle | 👶 introduction 💪 workout 🦑 deep |
define-relationships.0: 1000 | ✅ |
7 | sql-practice-define-relationships-3 | sqlfiddle | 👶 introduction 💪 workout 🦑 deep |
define-relationships.2: 1000 define-columns.2: 1000 |
✅ |
8 | sql-practice-define-relationships-4 | sqlfiddle | 👶 introduction 💪 workout 🦑 deep |
define-relationships.3: 1000 | ✅ |
Game:
2. data-types
Insights:
no | name | content | aspects | standards | PQ | RQ | Quiz | done |
---|---|---|---|---|---|---|---|---|
1 | sql-numeric-data-types | ✅ | 👶 introduction 💪 workout |
choose-sql-datatype.0: 10 | ✅ | ✅ | ❌ | ✅ |
2 | sql-string-data-types | ✅ | 👶 introduction 💪 workout |
choose-sql-datatype.1: 10 | ✅ | ✅ | ❌ | ✅ |
3 | sql-text-data-type | ✅ | 👶 introduction 💪 workout |
choose-sql-datatype.2: 10 | ✅ | ✅ | ❌ | ✅ |
4 | encoding-and-collation | ✅ | 👶 introduction 💪 workout |
choose-sql-datatype.1: 10 | ✅ | ✅ | ❌ | ✅ |
5 | add-support-for-other-character-sets | ✅ | 👶 introduction 💪 workout |
choose-sql-datatype.1: 10 | ✅ | ✅ | ❌ | ✅ |
Exercises:
Game:
3. alter
Insights:
no | name | content | aspects | standards | PQ | RQ | Quiz | done |
---|---|---|---|---|---|---|---|---|
1 | add-column | ✅ | 💪 workout 🦑 deep |
define-columns.0: 10 define-columns.2: 10 |
✅ | ✅ | ❌ | ✅ |
2 | add-constraint | ✅ | 💪 workout 🦑 deep |
define-relationships.0: 10 | ✅ | ✅ | ❌ | ✅ |
3 | add-default-value | ✅ | 💪 workout 🦑 deep |
define-columns.2: 10 | ✅ | ✅ | ❌ | ✅ |
4 | add-trigger | ✅ | 💪 workout 🦑 deep |
define-tables.2: 10 | ❌ | ✅ | ❌ | ❌ |
5 | add-rule | ✅ | 💪 workout 🦑 deep |
define-tables.3: 10 | ❌ | ✅ | ❌ | ❌ |
Exercises:
no | name | type | aspects | standards | done |
---|---|---|---|---|---|
1 | sql-practice-alter-table | sqlfiddle | 💪 workout | define-columns.1: 1000 define-columns.2: 1000 |
✅ |
2 | sql-practice-alter-table-2 | sqlfiddle | 💪 workout 🦑 deep |
define-columns.0: 1000 define-columns.1: 1000 define-columns.2: 1000 |
✅ |
3 | sql-practice-define-default-seq | sqlfiddle | 👶 introduction 💪 workout 🦑 deep |
define-sequences-or-default-values.0: 1000 | ✅ |
4 | sql-practice-define-default-seq-2 | sqlfiddle | 👶 introduction 💪 workout 🦑 deep |
define-sequences-or-default-values.0: 1000 define-sequences-or-default-values.2: 1000 |
✅ |
5 | sql-practice-define-default-seq-3 | sqlfiddle | 👶 introduction 💪 workout 🦑 deep |
define-sequences-or-default-values.0: 1000 define-sequences-or-default-values.1: 1000 |
✅ |
6 | sql-practice-define-default-seq-4 | sqlfiddle | 👶 introduction 💪 workout 🦑 deep |
define-sequences-or-default-values.1: 1000 define-sequences-or-default-values.2: 1000 |
✅ |
Game:
4. indices
Insights:
no | name | content | aspects | standards | PQ | RQ | Quiz | done |
---|---|---|---|---|---|---|---|---|
1 | create-indexes | ✅ | 💪 workout 🦑 deep |
define-indices.0: 10 define-indices.2: 10 |
✅ | ✅ | ✅ | ✅ |
2 | when-to-add-indexes | ✅ | 💪 workout 🦑 deep |
define-indices.0: 10 define-indices.3: 10 |
✅ | ✅ | ✅ | ✅ |
Exercises:
no | name | type | aspects | standards | done |
---|---|---|---|---|---|
1 | sql-practice-define-indexes | sqlfiddle | 👶 introduction 💪 workout 🦑 deep |
define-indices.0: 1000 define-indices.1: 1000 define-indices.2: 1000 define-indices.3: 1000 |
✅ |
2 | sql-practice-sql-indexes2 | sqlfiddle | 👶 introduction 💪 workout 🦑 deep |
define-indices.0: 1000 define-indices.1: 1000 define-indices.2: 1000 define-indices.3: 1000 |
✅ |
Game:
Insights:
no | name | content | aspects | standards | PQ | RQ | Quiz | done |
---|---|---|---|---|---|---|---|---|
1 | blobs-in-a-rdbms | ✅ | 👶 introduction 💪 workout 🦑 deep |
choose-sql-datatype.2: 10 | ✅ | ✅ | ❌ | ✅ |
2 | storing-blobs-in-psql | ✅ | 👶 introduction 💪 workout 🦑 deep |
choose-sql-datatype.2: 10 | ✅ | ✅ | ❌ | ✅ |
3 | storing-blobs-in-mysql | ✅ | 👶 introduction 💪 workout 🦑 deep |
choose-sql-datatype.2: 10 | ✅ | ✅ | ❌ | ✅ |
4 | storing-blobs-in-mssql | ✅ | 👶 introduction 💪 workout 🦑 deep |
choose-sql-datatype.2: 10 | ✅ | ✅ | ❌ | ✅ |
Exercises:
Game:
6. storing-json
Insights:
no | name | content | aspects | standards | PQ | RQ | Quiz | done |
---|---|---|---|---|---|---|---|---|
1 | storing-json-in-an-rdbms | ✅ | 👶 introduction 💪 workout 🦑 deep |
choose-sql-datatype.2: 10 | ✅ | ✅ | ❌ | ✅ |
2 | storing-json-in-postgresql | ✅ | 👶 introduction 💪 workout 🦑 deep |
choose-sql-datatype.2: 10 | ✅ | ✅ | ❌ | ✅ |
3 | storing-json-in-mysql | ✅ | 👶 introduction 💪 workout 🦑 deep |
choose-sql-datatype.2: 10 | ✅ | ✅ | ❌ | ✅ |
4 | storing-json-in-mssql | ✅ | 👶 introduction 💪 workout 🦑 deep |
choose-sql-datatype.2: 10 | ✅ | ✅ | ❌ | ✅ |
Exercises:
Game:
✅ - At least one insight covers this
❌ - Nothing covers this
🛠️ - This standard has no objectives yet
- ✅ Create a database
- ❌ Create database users
- ❌ Provision roles for database users
- ✅ Create a new table
- ✅ Set the data type or name of columns in a new table
- ✅ Write statements to add a Trigger to a table
- ✅ Write statements to add a Rule to a table
- ❌ Write statements to add Primary or Foreign Keys to a new table
- ✅ Create columns in a table
- ❌ Modify the name or data type of columns in a table
- ✅ Modify other properties of a column in a table
- ✅ Create a one-to-many relationship by creating a reference to a foreign key
- ❌ Create a many-to-many relationship with two foreign key references
- ❌ Create a one-to-one relationship by creating a reference to a foreign key and setting a constraint
- ❌ Join a table to itself with self-referencing foreign keys
- ✅ Create an index on a database table
- ❌ Modify the properties of an index on a database table
- ✅ Create a clustered index on a database table
- ✅ Distinguish between effective indicies that improve the performance of table lookups and ineffective indicies that hinder performance
- ❌ Write column definitions to create auto-incrementing IDs
- ❌ Write column definitions with default values that are static
- ❌ Write column definitions with default values that are computed
- ✅ Distinguish and choose between numeric types based on the desired behavior of the column
- ✅ Distinguish and choose between string types based on the desired behavior of the column
- ✅ Distinguish and choose between large content types based on the desired behavior of the column
Given the insights are tagged with aspects, we can filter over the linear content progression and create learning sub-paths.
These sub-path progressions will most likely not cover all content, but they will ensure and enforce an unified learning experience, tailor for the user wish.
For example, a user might be interested in new additions and updates of a language, rather than introduction lessions. Note that these sub-paths don't take games into consideration
If you are being introduced to the topic for the first time
Insights:
- create-a-database
- create-a-table
- sql-numeric-data-types
- sql-string-data-types
- sql-text-data-type
- encoding-and-collation
- add-support-for-other-character-sets
- blobs-in-a-rdbms
- storing-blobs-in-psql
- storing-blobs-in-mysql
- storing-blobs-in-mssql
- storing-json-in-an-rdbms
- storing-json-in-postgresql
- storing-json-in-mysql
- storing-json-in-mssql
Exercises:
- sql-practice-create-table
- sql-practice-create-table-2
- sql-practice-create-table-3
- sql-practice-create-table-4
- sql-practice-define-relationships
- sql-practice-define-relationships-2
- sql-practice-define-relationships-3
- sql-practice-define-relationships-4
- sql-practice-define-default-seq
- sql-practice-define-default-seq-2
- sql-practice-define-default-seq-3
- sql-practice-define-default-seq-4
- sql-practice-define-indexes
- sql-practice-sql-indexes2
Theory put into practice/that’s how you achieve X points
Insights:
- create-a-database
- create-a-table
- sql-numeric-data-types
- sql-string-data-types
- sql-text-data-type
- encoding-and-collation
- add-support-for-other-character-sets
- add-column
- add-constraint
- add-default-value
- add-trigger
- add-rule
- create-indexes
- when-to-add-indexes
- blobs-in-a-rdbms
- storing-blobs-in-psql
- storing-blobs-in-mysql
- storing-blobs-in-mssql
- storing-json-in-an-rdbms
- storing-json-in-postgresql
- storing-json-in-mysql
- storing-json-in-mssql
Exercises:
- sql-practice-create-table
- sql-practice-create-table-2
- sql-practice-create-table-3
- sql-practice-create-table-4
- sql-practice-define-relationships
- sql-practice-define-relationships-2
- sql-practice-define-relationships-3
- sql-practice-define-relationships-4
- sql-practice-alter-table
- sql-practice-alter-table-2
- sql-practice-define-default-seq
- sql-practice-define-default-seq-2
- sql-practice-define-default-seq-3
- sql-practice-define-default-seq-4
- sql-practice-define-indexes
- sql-practice-sql-indexes2
Prerequisite knowledge consisting of 2 or more 👶/💪 workouts
Insights:
- add-column
- add-constraint
- add-default-value
- add-trigger
- add-rule
- create-indexes
- when-to-add-indexes
- blobs-in-a-rdbms
- storing-blobs-in-psql
- storing-blobs-in-mysql
- storing-blobs-in-mssql
- storing-json-in-an-rdbms
- storing-json-in-postgresql
- storing-json-in-mysql
- storing-json-in-mssql
Exercises:
- sql-practice-define-relationships
- sql-practice-define-relationships-2
- sql-practice-define-relationships-3
- sql-practice-define-relationships-4
- sql-practice-alter-table-2
- sql-practice-define-default-seq
- sql-practice-define-default-seq-2
- sql-practice-define-default-seq-3
- sql-practice-define-default-seq-4
- sql-practice-define-indexes
- sql-practice-sql-indexes2
Recently added/gained traction feature
Stories, obscure details that don’t specifically relate to a learning objective
✅ All content has been tagged with aspects.
Want to contribute to this wiki? Go right ahead! If it has to do with how the Enki software ecosystem works, or editorial guidelines for how to write, let us handle that. Anything else, edit away!
Curriculum Format:
- Topic Documentation
- Course Documentation
- Workout Documentation
- Insight Documentation
- Glossary Documentation
Contributor Resources:
Curriculum overview:
Topic pages: