Настройка базы данных

Обзор вариантов конфигурации для базы данных Nette.

Если вы используете не весь фреймворк, а только эту библиотеку, прочитайте Как загрузить файл конфигурации.

Одно подключение

Настройте одно подключение к базе данных:

database:
	# DSN, единственный обязательный ключ
	dsn: "sqlite:%appDir%/Model/demo.db"
	user: ...
	password: ...

Создает сервисы Nette\Database\Connection и Nette\Database\Explorer, которые обычно передаются автоподключением или ссылкой на их имя.

Другие настройки:

database:
	# отображает панель Database в Tracy Bar
	debugger: ...     # (bool) по умолчанию true

	# отображает запрос EXPLAIN в Tracy Bar
	explain: ...      # (bool) по умолчанию true

	# включить автосвязывание для этого соединения
	autowired: ...    # (bool) по умолчанию true для первого соединения

	# условные обозначения таблицы: discovered, static, или имя класса
	conventions: discovered  # (string) по умолчанию 'discovered'

	options:
		# подключаться к базе данных только при необходимости?
		lazy: ...     # (bool) по умолчанию false

		# Класс драйвера базы данных PHP
		driverClass:  # (string)

		# только для MySQL: устанавливает sql_mode
		sqlmode:      # (string)

		# только для MySQL: устанавливает SET NAMES
		charset:      # (string) по умолчанию 'utf8mb4'

		# Только для MySQL: преобразует TINYINT(1) в bool
		convertBoolean: # (bool) по умолчанию false

		# возвращает столбцы даты как неизменяемые объекты (с версии 3.2.1)
		newDateTime:  # (bool) по умолчанию false

		# только для Oracle и SQLite: формат даті
		formatDateTime: # (string) по умолчанию 'U'

Ключ options может содержать другие опции, которые можно найти в документации по драйверу PDO, например:

база данных:
	options:
		PDO::MYSQL_ATTR_COMPRESS: true

Множественные подключения

В конфигурации мы можем определить больше соединений с базой данных, разделив их на именованные секции:

database:
	main:
		dsn: 'mysql:host=127.0.0.1;dbname=test'
		user: root
		password: password

	another:
		dsn: 'sqlite::memory:'

Автоподключение включено только для сервисов из первой секции. Это можно изменить с помощью autowired: false или autowired: true.

Услуги DI

Эти сервисы добавляются в контейнер DI, где ### представляет собой имя соединения:

Имя Тип Описание
database.###.connection Nette\Database\Connection database connection
database.###.explorer Nette\Database\Explorer Database Explorer

Если задать только одно соединение, то имена сервисов будут database.default.connection и database.default.explorer. Если задать несколько соединений, как в приведенном примере, то имена будут соответствовать разделам, т.е. database.main.connection, database.main.explorer, а затем database.another.connection и database.another.explorer.

Неаутентифицированные сервисы мы передаем в явном виде, ссылаясь на их имя:

services:
	- UserFacade(@database.another.connection)
версия: 4.0