destructr/examples/mariadb.php

51 lines
1.2 KiB
PHP
Raw Normal View History

<?php
include __DIR__ . '/../vendor/autoload.php';
2020-08-26 17:53:27 +00:00
/*
Constructing MariaDB drivers should be done using factoryFromPDO,
so that they use the MariaDB driver instead of the MySQL driver.
*/
$driver = \Destructr\DriverFactory::factoryFromPDO(
2020-08-26 17:53:27 +00:00
new \PDO(
'mysql:server=localhost;port=3307;dbname=destructr',
'root'
),
'mariadb'
);
2020-08-26 17:53:27 +00:00
/*
Creates a factory using the table 'example_table', and creates
the necessary table. Note that createTable() can safely be called
multiple times.
*/
$factory = new \Destructr\Factory($driver, 'example_table');
$factory->createTable();
2020-08-26 17:53:27 +00:00
/*
The following can be uncommented to insert 1,000 dummy records
into the given table.
*/
// for($i = 0; $i < 1000; $i++) {
// $obj = $factory->create(
// [
// 'dso.type'=>'foobar',
// 'random_data' => md5(rand())
// ]
// );
// $obj->insert();
// }
2020-08-26 17:53:27 +00:00
/*
Search by random data field
*/
$search = $factory->search();
2020-08-26 17:53:27 +00:00
$search->where('${random_data} = :q');
$result = $search->execute(['q'=>'rw7nivub9bhhh3t4']);
2020-08-26 17:53:27 +00:00
/*
Search by dso.id, which is much faster because it's indexed
*/
// $search = $factory->search();
// $search->where('${dso.id} = :q');
// $result = $search->execute(['q'=>'rw7nivub9bhhh3t4']);