id,page,ref,title,content,breadcrumbs,references changelog:v1-0-a14,changelog,v1-0-a14,1.0a14 (2024-08-05),"This alpha introduces significant changes to Datasette's Metadata system, some of which represent breaking changes in advance of the full 1.0 release. The new Upgrade guide document provides detailed coverage of those breaking changes and how they affect plugin authors and Datasette API consumers. The /databasename?sql= interface and JSON API for executing arbitrary SQL queries can now be found at /databasename/-/query?sql= . Requests with a ?sql= parameter to the old endpoints will be redirected. Thanks, Alex Garcia . ( #2360 ) Metadata about tables, databases, instances and columns is now stored in Datasette's internal database . Thanks, Alex Garcia. ( #2341 ) Database write connections now execute using the IMMEDIATE isolation level for SQLite. This should help avoid a rare SQLITE_BUSY error that could occur when a transaction upgraded to a write mid-flight. ( #2358 ) Fix for a bug where canned queries with named parameters could fail against SQLite 3.46. ( #2353 ) Datasette now serves E-Tag headers for static files. Thanks, Agustin Bacigalup . ( #2306 ) Dropdown menus now use a z-index that should avoid them being hidden by plugins. ( #2311 ) Incorrect table and row names are no longer reflected back on the resulting 404 page. ( #2359 ) Improved documentation for async usage of the track_event(datasette, event) hook. ( #2319 ) Fixed some HTTPX deprecation warnings. ( #2307 ) Datasette now serves a attribute. Thanks, Charles Nepote . ( #2348 ) Datasette's automated tests now run against the maximum and minimum supported versions of SQLite: 3.25 (from September 2018) and 3.46 (from May 2024). Thanks, Alex Garcia. ( #2352 ) Fixed an issue where clicking twice on the URL output by datasette --root produced a confusing error. ( #2375 )","[""Changelog""]","[{""href"": ""https://github.com/asg017"", ""label"": ""Alex Garcia""}, {""href"": ""https://github.com/simonw/datasette/issues/2360"", ""label"": ""#2360""}, {""href"": ""https://github.com/simonw/datasette/issues/2341"", ""label"": ""#2341""}, {""href"": ""https://github.com/simonw/datasette/issues/2358"", ""label"": ""#2358""}, {""href"": ""https://github.com/simonw/datasette/issues/2353"", ""label"": ""#2353""}, {""href"": ""https://github.com/redraw"", ""label"": ""Agustin Bacigalup""}, {""href"": ""https://github.com/simonw/datasette/pull/2306"", ""label"": ""#2306""}, {""href"": ""https://github.com/simonw/datasette/issues/2311"", ""label"": ""#2311""}, {""href"": ""https://github.com/simonw/datasette/issues/2359"", ""label"": ""#2359""}, {""href"": ""https://github.com/simonw/datasette/issues/2319"", ""label"": ""#2319""}, {""href"": ""https://github.com/simonw/datasette/issues/2307"", ""label"": ""#2307""}, {""href"": ""https://github.com/CharlesNepote"", ""label"": ""Charles Nepote""}, {""href"": ""https://github.com/simonw/datasette/issues/2348"", ""label"": ""#2348""}, {""href"": ""https://github.com/simonw/datasette/pull/2352"", ""label"": ""#2352""}, {""href"": ""https://github.com/simonw/datasette/issues/2375"", ""label"": ""#2375""}]" changelog:v1-0-a15,changelog,v1-0-a15,1.0a15 (2024-08-15),"Datasette now defaults to hiding SQLite ""shadow"" tables, as seen in extensions such as SQLite FTS and sqlite-vec . Virtual tables that it makes sense to display, such as FTS core tables, are no longer hidden. Thanks, Alex Garcia . ( #2296 ) Fixed bug where running Datasette with one or more -s/--setting options could over-ride settings that were present in datasette.yml . ( #2389 ) The Datasette homepage is now duplicated at /-/ , using the default index.html template. This ensures that the information on that page is still accessible even if the Datasette homepage has been customized using a custom index.html template, for example on sites like datasette.io . ( #2393 ) Failed CSRF checks now display a more user-friendly error page. ( #2390 ) Fixed a bug where the json1 extension was not correctly detected on the /-/versions page. Thanks, Seb Bacon . ( #2326 ) Fixed a bug where the Datasette write API did not correctly accept Content-Type: application/json; charset=utf-8 . ( #2384 ) Fixed a bug where Datasette would fail to start if metadata.yml contained a queries block. ( #2386 )","[""Changelog""]","[{""href"": ""https://github.com/asg017/sqlite-vec"", ""label"": ""sqlite-vec""}, {""href"": ""https://github.com/asg017"", ""label"": ""Alex Garcia""}, {""href"": ""https://github.com/simonw/datasette/issues/2296"", ""label"": ""#2296""}, {""href"": ""https://github.com/simonw/datasette/issues/2389"", ""label"": ""#2389""}, {""href"": ""https://datasette.io/"", ""label"": ""datasette.io""}, {""href"": ""https://github.com/simonw/datasette/issues/2393"", ""label"": ""#2393""}, {""href"": ""https://github.com/simonw/datasette/issues/2390"", ""label"": ""#2390""}, {""href"": ""https://github.com/sebbacon"", ""label"": ""Seb Bacon""}, {""href"": ""https://github.com/simonw/datasette/issues/2326"", ""label"": ""#2326""}, {""href"": ""https://github.com/simonw/datasette/issues/2384"", ""label"": ""#2384""}, {""href"": ""https://github.com/simonw/datasette/pull/2386"", ""label"": ""#2386""}]" changelog:v1-0-a16,changelog,v1-0-a16,1.0a16 (2024-09-05),"This release focuses on performance, in particular against large tables, and introduces some minor breaking changes for CSS styling in Datasette plugins. Removed the unit conversions feature and its dependency, Pint. This means Datasette is now compatible with the upcoming Python 3.13. ( #2400 , #2320 ) The datasette --pdb option now uses the ipdb debugger if it is installed. You can install it using datasette install ipdb . Thanks, Tiago Ilieve . ( #2342 ) Fixed a confusing error that occurred if metadata.json contained nested objects. ( #2403 ) Fixed a bug with ?_trace=1 where it returned a blank page if the response was larger than 256KB. ( #2404 ) Tracing mechanism now also displays SQL queries that returned errors or ran out of time. datasette-pretty-traces 0.5 includes support for displaying this new type of trace. ( #2405 ) Fixed a text spacing with table descriptions on the homepage. ( #2399 ) Performance improvements for large tables: Suggested facets now only consider the first 1000 rows. ( #2406 ) Improved performance of date facet suggestion against large tables. ( #2407 ) Row counts stop at 10,000 rows when listing tables. ( #2398 ) On table page the count stops at 10,000 rows too, with a ""count all"" button to execute the full count. ( #2408 ) New .dicts() internal method on Results that returns a list of dictionaries representing the results from a SQL query: ( #2414 ) rows = (await db.execute(""select * from t"")).dicts() Default Datasette core CSS that styles inputs and buttons now requires a class of ""core"" on the element or a containing element, for example