Download the PHP package nette/database without Composer
On this page you can find all versions of the php package nette/database. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download nette/database
More information about nette/database
Files in nette/database
Package database
Short Description 💾 Nette Database: layer with a familiar PDO-like API but much more powerful. Building queries, advanced joins, drivers for MySQL, PostgreSQL, SQLite, MS SQL Server and Oracle.
License BSD-3-Clause GPL-2.0-only GPL-3.0-only
Homepage https://nette.org
Informations about the package database
<!---->
Introduction
Nette provides a powerful layer for accessing your database easily.
✅ composes SQL queries with ease
✅ significantly simplifies retrieving data without writing SQL queries
✅ uses efficient queries and does not transmit unnecessary data
The Nette Database Core is a wrapper around the PDO and provides core functionality.
The Nette Database Explorer layer helps you to fetch database data more easily and in a more optimized way.
<!---->
Support Me
Do you like Nette Database? Are you looking forward to the new features?
Thank you!
<!---->
Installation
The recommended way to install is via Composer:
It requires PHP version 8.1 and supports PHP up to 8.4.
<!---->
Usage
This is just a piece of documentation. Please see our website.
<!---->
Database Core
To create a new database connection just create a new instance of Nette\Database\Connection
class:
Connection allows you to easily query your database by calling query
method:
<!---->
Database Explorer
Nette Database Explorer layer helps you to fetch database data more easily and in a more optimized way. The primary attitude is to fetch data only from one table and fetch them at once. The data are fetched into ActiveRow
instances. Data from other tables connected by relationships are delivered by another queries - this is maintained by Database Explorer layer itself.
Let's take a look at common use-case. You need to fetch books and their authors. It is common 1:N relationship. The often used implementation fetches data by one SQL query with table joins. The second possibility is to fetch data separately, run one query for getting books and then get an author for each book by another query (e.g. in your foreach cycle). This could be easily optimized to run only two queries, one for books, and another for the needed authors - and this is just the way how Nette Database Explorer does it.
Selecting data starts with the table, just call $explorer->table()
on the Nette\Database\Explorer
object. The easiest way to get it is described here, but if we use Nette Database Explorer alone, it can be manually created.
We can simply iterate over the selection and pass through all the books. The rows are fetched as ActiveRow instances; you can read row data from their properties.
Getting just one specific row is done by get()
method, which directly returns an ActiveRow instance.
Working with relationships
You will be pleased how efficiently the database layer works. The example above performs constant number of queries, see following 4 queries:
If you use caching (defaults on), no columns will be queried unnecessarily. After the first query, cache will store the used column names and Nette Database Explorer will run queries only with the needed columns:
All versions of database with dependencies
ext-pdo Version *
nette/caching Version ^3.2
nette/utils Version ^4.0