ptest/frm/Model.php

100 строки
2.6 KiB
PHP
Исходник Обычный вид История

2017-01-25 16:08:19 +00:00
<?php
/**
* Created by PhpStorm.
* User: Игорь
* Date: 24.01.2017
* Time: 12:47
*/
namespace PFRM;
class Model {
protected $_table_name;
public $app;
function __construct() {
global $app;
$this->app = $app;
$this->_table_name = preg_replace( '/^.*\\\(.*)Model$/', "$1", get_called_class() );
}
public function save() {
$operation = "INSERT INTO ";
$suffix = "";
if ( isset( $this->table_id ) ) {
$operation = "UPDATE ";
$suffix = " WHERE id = :id";
}
$table_columns = NULL;
$pseudo_columns = NULL;
foreach ($this as $key => $value ) {
if ( preg_match('/^table_(?<name>.*)/', $key, $matches) ) {
if ( $matches['name'] != 'id' && isset( $this->$key ) ) {
$table_columns[] = $matches['name'];
$pseudo_columns[] = ':' . $matches['name'];
}
}
}
if ( is_array( $table_columns ) ) {
$names = ' ( ' . implode( ',', $table_columns ) . ' ) ';
$pseudo_names = ' ( ' . implode( ',', $pseudo_columns ) . ' ) ';
$stmt = $this->app->dbh->prepare( $operation . $this->_table_name . $names . ' VALUES ' . $pseudo_names . $suffix );
foreach ($table_columns as $value) {
$tmp_str = 'table_' . $value;
$stmt->bindParam( ':' . $value, $this->$tmp_str );
}
if ( isset( $this->table_id ) ) {
$stmt->bindParam( ':id', $this->table_id );
}
$stmt->execute();
}
}
static public function findFirst( $condition ) {
2017-01-25 17:17:56 +00:00
global $app;
$child_model_name = get_called_class();
$model = new $child_model_name;
$stmt = $app->dbh->prepare( 'SELECT * FROM ' . $model->_table_name . ' WHERE ' . $condition);
$stmt->execute();
$data = $stmt->fetchAll(\PDO::FETCH_ASSOC);
if (! empty($data) ) {
foreach ($data[0] as $key => $value ) {
$column_name = 'table_' . $key;
$model->$column_name = $value;
}
return $model;
}
2017-01-25 17:40:48 +00:00
$model = null;
return false;
}
static public function find( $condition ) {
global $app;
$child_model_name = get_called_class();
$model = new $child_model_name;
$stmt = $app->dbh->prepare( 'SELECT * FROM ' . $model->_table_name . ' WHERE ' . $condition);
$model = null;
$stmt->execute();
$data = $stmt->fetchAll(\PDO::FETCH_ASSOC);
if (! empty($data) ) {
$out = [];
foreach ( $data as $data_single ) {
$model = new $child_model_name;
foreach ($data_single as $key => $value ) {
$column_name = 'table_' . $key;
$model->$column_name = $value;
}
$out[]=$model;
$model = null;
}
return $out;
}
2017-01-25 17:17:56 +00:00
return false;
2017-01-25 16:08:19 +00:00
}
}