{"id":21896,"name":"sqlab","description":"SQL Adventure Builder: transform a dataset and a collection of SQL exercises into a self-contained database","url":"https://github.com/laowantong/sqlab","last_synced_at":"2025-09-05T01:10:59.692Z","repository":{"id":225614584,"uuid":"766434726","full_name":"laowantong/sqlab","owner":"laowantong","description":"SQL Adventure Builder: transform a dataset and a collection of SQL exercises into a self-contained database","archived":false,"fork":false,"pushed_at":"2025-08-14T12:36:49.000Z","size":1304,"stargazers_count":10,"open_issues_count":0,"forks_count":1,"subscribers_count":2,"default_branch":"main","last_synced_at":"2025-08-14T14:25:36.999Z","etag":null,"topics":["database","education","game-engine","games","sql","text-adventure"],"latest_commit_sha":null,"homepage":"","language":"Jupyter Notebook","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/laowantong.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":"CITATION.cff","codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2024-03-03T08:58:23.000Z","updated_at":"2025-08-14T12:36:52.000Z","dependencies_parsed_at":"2024-04-10T18:37:48.649Z","dependency_job_id":"166175be-adc6-4a9f-8fc8-7c9213adcdee","html_url":"https://github.com/laowantong/sqlab","commit_stats":null,"previous_names":["laowantong/sqlab"],"tags_count":4,"template":false,"template_full_name":null,"purl":"pkg:github/laowantong/sqlab","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/laowantong","download_url":"https://codeload.github.com/laowantong/sqlab/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":273695771,"owners_count":25151598,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-09-04T02:00:08.968Z","response_time":61,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"owner":{"login":"laowantong","name":"Aristide","uuid":"3048819","kind":"user","description":"","email":"","website":null,"location":"Metz, France","twitter":null,"company":"Université de Lorraine","icon_url":"https://avatars.githubusercontent.com/u/3048819?u=079236559674a9e3e0eee47bddf86dc957388d75\u0026v=4","repositories_count":3,"last_synced_at":"2023-03-03T14:50:30.821Z","metadata":{"has_sponsors_listing":false},"html_url":"https://github.com/laowantong","funding_links":[],"total_stars":null,"followers":null,"following":null,"created_at":"2022-11-14T01:19:22.368Z","updated_at":"2023-03-03T14:50:30.857Z","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/laowantong","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/laowantong/repositories"},"packages":[{"id":9161103,"name":"sqlab","ecosystem":"pypi","description":"SQL Adventure Builder: a command line tool for creating standalone SQL activities.","homepage":"https://github.com/laowantong/sqlab/","licenses":"MIT","normalized_licenses":["MIT"],"repository_url":"https://github.com/laowantong/sqlab","keywords_array":["education","relational","database","sql","games"],"namespace":null,"versions_count":11,"first_release_published_at":"2024-03-03T08:57:49.000Z","latest_release_published_at":"2025-04-14T17:35:00.000Z","latest_release_number":"0.6.6","last_synced_at":"2025-08-14T14:40:38.744Z","created_at":"2024-03-03T09:03:07.681Z","updated_at":"2025-08-14T20:58:12.087Z","registry_url":"https://pypi.org/project/sqlab/","install_command":"pip install sqlab --index-url https://pypi.org/simple","documentation_url":"https://sqlab.readthedocs.io/","metadata":{"funding":null,"documentation":null,"classifiers":["Development Status :: 4 - Beta","Environment :: Console","Framework :: IPython","Intended Audience :: Education","Intended Audience :: Information Technology","License :: OSI Approved :: MIT License","Natural Language :: English","Operating System :: OS Independent","Programming Language :: Python :: 3","Programming Language :: Python :: 3.10","Programming Language :: Python :: 3.11","Programming Language :: Python :: 3.8","Programming Language :: Python :: 3.9","Topic :: Database","Topic :: Education","Topic :: Games/Entertainment"],"normalized_name":"sqlab"},"repo_metadata":{"id":225614584,"uuid":"766434726","full_name":"laowantong/sqlab","owner":"laowantong","description":"SQL Adventure Builder: transform a dataset and a collection of SQL exercises into a self-contained database","archived":false,"fork":false,"pushed_at":"2025-08-14T12:36:49.000Z","size":1304,"stargazers_count":10,"open_issues_count":0,"forks_count":1,"subscribers_count":2,"default_branch":"main","last_synced_at":"2025-08-14T14:25:36.999Z","etag":null,"topics":["database","education","game-engine","games","sql","text-adventure"],"latest_commit_sha":null,"homepage":"","language":"Jupyter Notebook","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/laowantong.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":"CITATION.cff","codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2024-03-03T08:58:23.000Z","updated_at":"2025-08-14T12:36:52.000Z","dependencies_parsed_at":"2024-04-10T18:37:48.649Z","dependency_job_id":"166175be-adc6-4a9f-8fc8-7c9213adcdee","html_url":"https://github.com/laowantong/sqlab","commit_stats":null,"previous_names":["laowantong/sqlab"],"tags_count":4,"template":false,"template_full_name":null,"purl":"pkg:github/laowantong/sqlab","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/laowantong","download_url":"https://codeload.github.com/laowantong/sqlab/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":270482241,"owners_count":24591338,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-08-14T02:00:10.309Z","response_time":75,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"},"owner_record":{"login":"laowantong","name":"Aristide","uuid":"3048819","kind":"user","description":"","email":"","website":null,"location":"Metz, France","twitter":null,"company":"Université de Lorraine","icon_url":"https://avatars.githubusercontent.com/u/3048819?u=079236559674a9e3e0eee47bddf86dc957388d75\u0026v=4","repositories_count":3,"last_synced_at":"2023-03-03T14:50:30.821Z","metadata":{"has_sponsors_listing":false},"html_url":"https://github.com/laowantong","funding_links":[],"total_stars":null,"followers":null,"following":null,"created_at":"2022-11-14T01:19:22.368Z","updated_at":"2023-03-03T14:50:30.857Z","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/laowantong","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/laowantong/repositories"},"tags":[{"name":"0.6.6","sha":"ab8662b0350324f399c6b84889eb5d5238222053","kind":"commit","published_at":"2025-04-14T17:21:52.000Z","download_url":"https://codeload.github.com/laowantong/sqlab/tar.gz/0.6.6","html_url":"https://github.com/laowantong/sqlab/releases/tag/0.6.6","dependencies_parsed_at":null,"dependency_job_id":null,"purl":"pkg:github/laowantong/sqlab@0.6.6","tag_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/tags/0.6.6","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/tags/0.6.6/manifests"},{"name":"0.6.5","sha":"814e80340bf1cbf6ac432d9cec4fceb52fa1ecbd","kind":"commit","published_at":"2025-03-30T13:28:44.000Z","download_url":"https://codeload.github.com/laowantong/sqlab/tar.gz/0.6.5","html_url":"https://github.com/laowantong/sqlab/releases/tag/0.6.5","dependencies_parsed_at":null,"dependency_job_id":null,"purl":"pkg:github/laowantong/sqlab@0.6.5","tag_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/tags/0.6.5","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/tags/0.6.5/manifests"},{"name":"0.5.5","sha":"ed528982e43b091025d1d4363948d867225840ad","kind":"commit","published_at":"2024-06-10T17:28:56.000Z","download_url":"https://codeload.github.com/laowantong/sqlab/tar.gz/0.5.5","html_url":"https://github.com/laowantong/sqlab/releases/tag/0.5.5","dependencies_parsed_at":null,"dependency_job_id":null,"purl":"pkg:github/laowantong/sqlab@0.5.5","tag_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/tags/0.5.5","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/tags/0.5.5/manifests"},{"name":"0.5.4","sha":"ab42d0976151080ca7595f4af7328e8cc8706ba2","kind":"commit","published_at":"2024-06-09T08:15:16.000Z","download_url":"https://codeload.github.com/laowantong/sqlab/tar.gz/0.5.4","html_url":"https://github.com/laowantong/sqlab/releases/tag/0.5.4","dependencies_parsed_at":null,"dependency_job_id":null,"purl":"pkg:github/laowantong/sqlab@0.5.4","tag_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/tags/0.5.4","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/tags/0.5.4/manifests"}]},"repo_metadata_updated_at":"2025-08-14T20:58:12.087Z","dependent_packages_count":0,"downloads":49,"downloads_period":"last-month","dependent_repos_count":0,"rankings":{"downloads":null,"dependent_repos_count":64.4159913421971,"dependent_packages_count":9.763793346142103,"stargazers_count":null,"forks_count":null,"docker_downloads_count":null,"average":37.089892344169606},"purl":"pkg:pypi/sqlab","advisories":[],"docker_usage_url":"https://docker.ecosyste.ms/usage/pypi/sqlab","docker_dependents_count":null,"docker_downloads_count":null,"usage_url":"https://repos.ecosyste.ms/usage/pypi/sqlab","dependent_repositories_url":"https://repos.ecosyste.ms/api/v1/usage/pypi/sqlab/dependencies","status":null,"funding_links":[],"critical":null,"issue_metadata":{"last_synced_at":"2025-07-29T14:43:18.885Z","issues_count":1,"pull_requests_count":2,"avg_time_to_close_issue":58.0,"avg_time_to_close_pull_request":359.5,"issues_closed_count":1,"pull_requests_closed_count":2,"pull_request_authors_count":2,"issue_authors_count":1,"avg_comments_per_issue":1.0,"avg_comments_per_pull_request":0.0,"merged_pull_requests_count":1,"bot_issues_count":0,"bot_pull_requests_count":0,"past_year_issues_count":1,"past_year_pull_requests_count":2,"past_year_avg_time_to_close_issue":58.0,"past_year_avg_time_to_close_pull_request":359.5,"past_year_issues_closed_count":1,"past_year_pull_requests_closed_count":2,"past_year_pull_request_authors_count":2,"past_year_issue_authors_count":1,"past_year_avg_comments_per_issue":1.0,"past_year_avg_comments_per_pull_request":0.0,"past_year_bot_issues_count":0,"past_year_bot_pull_requests_count":0,"past_year_merged_pull_requests_count":1,"issues_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/issues","maintainers":[{"login":"laowantong","count":1,"url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/authors/laowantong"}],"active_maintainers":[{"login":"laowantong","count":1,"url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/authors/laowantong"}]},"versions_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages/sqlab/versions","version_numbers_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages/sqlab/version_numbers","dependent_packages_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages/sqlab/dependent_packages","related_packages_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages/sqlab/related_packages","maintainers":[{"uuid":"laowantong","login":"laowantong","name":null,"email":null,"url":null,"packages_count":4,"html_url":"https://pypi.org/user/laowantong/","role":"Owner","created_at":"2024-03-03T09:06:32.966Z","updated_at":"2024-03-03T09:06:32.966Z","packages_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/maintainers/laowantong/packages"}],"registry":{"name":"pypi.org","url":"https://pypi.org","ecosystem":"pypi","default":true,"packages_count":724946,"maintainers_count":308265,"namespaces_count":0,"keywords_count":237984,"github":"pypi","metadata":{"funded_packages_count":50481},"icon_url":"https://github.com/pypi.png","created_at":"2022-04-04T15:19:23.364Z","updated_at":"2025-09-04T05:23:51.177Z","packages_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages","maintainers_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/maintainers","namespaces_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/namespaces"}}],"commits":{"id":7257151,"full_name":"laowantong/sqlab","default_branch":"master","committers":null,"total_commits":null,"total_committers":null,"total_bot_commits":null,"total_bot_committers":null,"mean_commits":null,"dds":null,"past_year_committers":null,"past_year_total_commits":null,"past_year_total_committers":null,"past_year_total_bot_commits":null,"past_year_total_bot_committers":null,"past_year_mean_commits":null,"past_year_dds":null,"last_synced_at":null,"last_synced_commit":null,"created_at":"2024-12-04T00:17:07.665Z","updated_at":"2024-12-04T00:17:07.665Z","commits_url":"https://commits.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/commits","host":{"name":"GitHub","url":"https://github.com","kind":"github","last_synced_at":"2025-09-05T00:00:10.343Z","repositories_count":5480019,"commits_count":853389012,"contributors_count":31098138,"owners_count":906558,"icon_url":"https://github.com/github.png","host_url":"https://commits.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://commits.ecosyste.ms/api/v1/hosts/GitHub/repositories"}},"issues_stats":{"full_name":"laowantong/sqlab","html_url":"https://github.com/laowantong/sqlab","last_synced_at":"2025-08-15T03:59:11.743Z","status":"error","issues_count":1,"pull_requests_count":2,"avg_time_to_close_issue":58.0,"avg_time_to_close_pull_request":359.5,"issues_closed_count":1,"pull_requests_closed_count":2,"pull_request_authors_count":2,"issue_authors_count":1,"avg_comments_per_issue":1.0,"avg_comments_per_pull_request":0.0,"merged_pull_requests_count":1,"bot_issues_count":0,"bot_pull_requests_count":0,"past_year_issues_count":1,"past_year_pull_requests_count":2,"past_year_avg_time_to_close_issue":58.0,"past_year_avg_time_to_close_pull_request":359.5,"past_year_issues_closed_count":1,"past_year_pull_requests_closed_count":2,"past_year_pull_request_authors_count":2,"past_year_issue_authors_count":1,"past_year_avg_comments_per_issue":1.0,"past_year_avg_comments_per_pull_request":0.0,"past_year_bot_issues_count":0,"past_year_bot_pull_requests_count":0,"past_year_merged_pull_requests_count":1,"created_at":"2024-12-04T00:17:07.975Z","updated_at":"2025-08-31T00:58:21.195Z","repository_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab","issues_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/repositories/laowantong%2Fsqlab/issues","issue_labels_count":{},"pull_request_labels_count":{},"issue_author_associations_count":{"NONE":1},"pull_request_author_associations_count":{"NONE":2,"OWNER":1},"issue_authors":{"Dracaukwak":1},"pull_request_authors":{"Dracaukwak":2,"laowantong":1},"host":{"name":"GitHub","url":"https://github.com","kind":"github","last_synced_at":"2025-09-01T00:00:07.725Z","repositories_count":9897400,"issues_count":29061701,"pull_requests_count":83189859,"authors_count":8742021,"icon_url":"https://github.com/github.png","host_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/repositories","owners_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/owners","authors_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/authors"},"past_year_issue_labels_count":{},"past_year_pull_request_labels_count":{},"past_year_issue_author_associations_count":{"NONE":1},"past_year_pull_request_author_associations_count":{"NONE":2,"OWNER":1},"past_year_issue_authors":{"Dracaukwak":1},"past_year_pull_request_authors":{"Dracaukwak":2,"laowantong":1},"maintainers":[{"login":"laowantong","count":1,"url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/authors/laowantong"}],"active_maintainers":[{"login":"laowantong","count":1,"url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/authors/laowantong"}]},"events":{"total":{"CreateEvent":3,"IssuesEvent":2,"ReleaseEvent":2,"WatchEvent":9,"IssueCommentEvent":1,"PushEvent":30,"PullRequestReviewEvent":2,"PullRequestEvent":4,"ForkEvent":6},"last_year":{"CreateEvent":3,"IssuesEvent":2,"ReleaseEvent":2,"WatchEvent":9,"IssueCommentEvent":1,"PushEvent":30,"PullRequestReviewEvent":2,"PullRequestEvent":4,"ForkEvent":6}},"keywords":["database","education","game-engine","games","sql","text-adventure"],"dependencies":[{"ecosystem":"pypi","filepath":"pyproject.toml","sha":null,"kind":"manifest","created_at":"2024-03-08T11:25:20.414Z","updated_at":"2024-03-08T11:25:20.414Z","repository_link":"https://github.com/laowantong/sqlab/blob/main/pyproject.toml","dependencies":[{"id":16682043780,"package_name":"python","ecosystem":"pypi","requirements":"^3.8.0","direct":true,"kind":"runtime","optional":false},{"id":16682043781,"package_name":"sqlparse","ecosystem":"pypi","requirements":"^0.4.4","direct":true,"kind":"runtime","optional":false},{"id":16682043782,"package_name":"jupysql","ecosystem":"pypi","requirements":"^0.10.10","direct":true,"kind":"runtime","optional":false},{"id":16682043783,"package_name":"mysql-connector-python","ecosystem":"pypi","requirements":"^8.2.0","direct":true,"kind":"runtime","optional":false},{"id":16682043784,"package_name":"sqlalchemy","ecosystem":"pypi","requirements":"2.0.27","direct":true,"kind":"runtime","optional":false},{"id":16682043785,"package_name":"psycopg2","ecosystem":"pypi","requirements":"^2.9.9","direct":true,"kind":"runtime","optional":false},{"id":16682043786,"package_name":"cmd2","ecosystem":"pypi","requirements":"^2.4.3","direct":true,"kind":"runtime","optional":false}]}],"score":null,"created_at":"2025-09-04T15:50:53.424Z","updated_at":"2025-10-07T08:10:29.666Z","avatar_url":"https://github.com/laowantong.png","language":"Jupyter Notebook","category":null,"sub_category":null,"monthly_downloads":49,"funding_links":[],"readme_doi_urls":[],"works":{},"citation_counts":{},"total_citations":0,"keywords_from_contributors":[],"project_url":"https://science.ecosyste.ms/api/v1/projects/21896","html_url":"https://science.ecosyste.ms/projects/21896","bibtex_url":"https://science.ecosyste.ms/projects/21896/export.bibtex","apalike_url":"https://science.ecosyste.ms/projects/21896/export.apalike"}