DML é um conjunto de instruções SQL usadas para manipular dados em um banco de dados.
Você pode usar o DML para realizar as seguintes operações:
- Inserção em lote
- Excluir linhas
- Resetar uma sequência
- Inserir
- Atualizar
- Upsert (Atualizar ou Inserir)
Para inserir múltiplas linhas em uma tabela, você pode usar o método Yiisoft\Db\Command\CommandInterface::insertBatch()
:
use Yiisoft\Db\Connection\ConnectionInterface;
/** @var ConnectionInterface $db */
$db->createCommand()->insertBatch(
'{{%customer}}',
['name', 'email'],
[
['user1', '[email protected]'],
['user2', '[email protected]'],
['user3', '[email protected]'],
]
)->execute();
It is possible to insert rows as associative arrays, where the keys are column names.
use Yiisoft\Db\Connection\ConnectionInterface;
/** @var ConnectionInterface $db */
$db->createCommand()->insertBatch(
'{{%customer}}',
[
['name' => 'user1', 'email' => '[email protected]'],
['name' => 'user2', 'email' => '[email protected]'],
['name' => 'user3', 'email' => '[email protected]'],
],
)->execute();
Para excluir linhas de uma tabela, você pode usar o método Yiisoft\Db\Command\CommandInterface::delete()
:
use Yiisoft\Db\Connection\ConnectionInterface;
/** @var ConnectionInterface $db */
$db->createCommand()->delete('{{%customer}}', ['id' => 1])->execute();
Para redefinir a sequência de uma tabela, você pode usar o método Yiisoft\Db\Command\CommandInterface::resetSequence()
:
use Yiisoft\Db\Connection\ConnectionInterface;
/** @var ConnectionInterface $db */
$db->createCommand()->resetSequence('{{%customer}}', 1)->execute();
Para inserir uma linha em uma tabela, você pode usar o método Yiisoft\Db\Command\CommandInterface::insert()
:
use Yiisoft\Db\Connection\ConnectionInterface;
/** @var ConnectionInterface $db */
$db->createCommand()->insert('{{%customer}}', ['name' => 'John Doe', 'age' => 18])->execute();
Para atualizar linhas em uma tabela, você pode usar o método Yiisoft\Db\Command\CommandInterface::update()
:
use Yiisoft\Db\Connection\ConnectionInterface;
/** @var ConnectionInterface $db */
$db->createCommand()->update('{{%customer}}', ['status' => 2], ['id' > 1])->execute();
Para atualizar atomicamente linhas existentes e inserir linhas não existentes,
você pode usar o método Yiisoft\Db\Command\CommandInterface::upsert()
:
use Yiisoft\Db\Connection\ConnectionInterface;
use Yiisoft\Db\Expression\Expression;
/** @var ConnectionInterface $db */
$db->createCommand()->upsert(
'pages',
[
'name' => 'Front page',
'url' => 'https://example.com/', // URL is unique
'visits' => 0,
],
updateColumns: [
'visits' => new Expression('visits + 1'),
],
params: $params,
)->execute();