Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pavelvais/upsert-doctrine
Upsert-Doctrine is a PHP library aimed at providing an elegant solution for upsert operations in Doctrine. This library simplifies the process of either inserting a new record or updating an existing one in a single operation, all within the Doctrine ORM ecosystem.
https://github.com/pavelvais/upsert-doctrine
dbal doctrine doctrine-orm mariadb mysql symfony
Last synced: about 2 months ago
JSON representation
Upsert-Doctrine is a PHP library aimed at providing an elegant solution for upsert operations in Doctrine. This library simplifies the process of either inserting a new record or updating an existing one in a single operation, all within the Doctrine ORM ecosystem.
- Host: GitHub
- URL: https://github.com/pavelvais/upsert-doctrine
- Owner: PavelVais
- License: mit
- Created: 2023-09-28T11:42:49.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-10-22T17:36:17.000Z (about 1 year ago)
- Last Synced: 2024-03-22T22:43:07.800Z (10 months ago)
- Topics: dbal, doctrine, doctrine-orm, mariadb, mysql, symfony
- Language: PHP
- Homepage:
- Size: 85 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Upsert-Doctrine
[![PHP Unit Tests](https://github.com/PavelVais/upsert-doctrine/actions/workflows/php.yml/badge.svg?branch=main)](https://github.com/PavelVais/upsert-doctrine/actions/workflows/php.yml)
Upsert-Doctrine is a PHP library aimed at providing an elegant solution for upsert operations in Doctrine.
This library simplifies the process of either inserting a new record or updating an existing one
in a single operation, all within the Doctrine ORM ecosystem.## Installation
Install Upsert-Doctrine using [Composer](https://getcomposer.org/):
```bash
composer require pavelvais/upsert-doctrine
```## Usage
Below is a basic example demonstrating how to use Upsert-Doctrine:```php
use PavelVais\UpsertDoctrine\UpsertManager;$entityManager = // ... get your Doctrine entity manager here
$upsertManager = new UpsertManager($entityManager);// Example for Single Upsert
$data = [
'book_id' => 1,
'author_id' => 2,
'ownership_type' => 2,
];
$repositoryClass = DoctrineOrmEntity::class; // Replace with your actual repository classtry {
$result = $upsertManager->execute($data, $repositoryClass);
// $result will contain the number of affected rows
} catch (\Exception $e) {
// Handle exceptions
}// Example for Batch Upsert
$batchData = [
[
'book_id' => 1,
'author_id' => 2,
'ownership_type' => 2,
],
[
'book_id' => 2,
'author_id' => 3,
'ownership_type' => 1,
],
];try {
$result = $upsertManager->executeBatch($batchData, $repositoryClass);
// $result will contain the number of affected rows
} catch (\Exception $e) {
// Handle exceptions
}```
## Local Testing with Docker
This project includes a Docker setup to run local testing and development.
Here are the steps to get started:1. **Build and manage the Containers**:
Build and start the containers in the background.
```bash
make build
```
To stop and remove the containers, use the following command:
```bash
make stop
```2. Installing Dependencies:
Install the project dependencies using Composer with the following command:
```bash
make composer-install
```
3. Running Tests:
Run the PHPUnit tests to ensure everything is working as expected.
```bash
make test
```## Roadmap
- [x] Basic Upsert Functionality
- [x] Batch Upsert method
- [x] Query Manager
- [ ] Postgres Support
- [ ] Live database testing# Contributing
Contributions are welcome! For major changes, please open an issue first to discuss what you would like to change.
Ensure to update tests as necessary.# License
This project is licensed under the MIT License - _see the [LICENSE](LICENSE) file for details._