1. Go to this page and download the library: Download pivotphp/cycle-orm library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
pivotphp / cycle-orm example snippets
use PivotPHP\Core\Core\Application;
use PivotPHP\Core\CycleORM\CycleServiceProvider;
$app = new Application();
$app->register(new CycleServiceProvider());
use Cycle\Annotated\Annotation\Entity;
use Cycle\Annotated\Annotation\Column;
#[Entity(repository: UserRepository::class)]
class User
{
#[Column(type: 'primary')]
private int $id;
#[Column(type: 'string')]
private string $name;
#[Column(type: 'string', unique: true)]
private string $email;
// Getters and setters...
}
$app->get('/users', function (CycleRequest $request) {
$users = $request->getRepository(User::class)->findAll();
return $request->response()->json($users);
});
$app->post('/users', function (CycleRequest $request) {
$user = new User();
$user->setName($request->input('name'));
$user->setEmail($request->input('email'));
$request->persist($user);
return $request->response()->json($user, 201);
});
// Custom repository
class UserRepository extends Repository
{
public function findByEmail(string $email): ?User
{
return $this->findOne(['email' => $email]);
}
public function findActive(): array
{
return $this->select()
->where('active', true)
->orderBy('created_at', 'DESC')
->fetchAll();
}
}
use PivotPHP\Core\CycleORM\Middleware\TransactionMiddleware;
// Automatic transaction handling
$app->post('/api/orders',
new TransactionMiddleware(),
function (CycleRequest $request) {
// All database operations are wrapped in a transaction
$order = new Order();
$request->persist($order);
// If an exception occurs, transaction is rolled back
foreach ($request->input('items') as $item) {
$orderItem = new OrderItem();
$request->persist($orderItem);
}
return $request->response()->json($order);
}
);