PHPackages                             maximo-perez-villalba/framework-dao-db - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Database &amp; ORM](/categories/database)
4. /
5. maximo-perez-villalba/framework-dao-db

ActiveLibrary[Database &amp; ORM](/categories/database)

maximo-perez-villalba/framework-dao-db
======================================

Extensión de framework-dao para base de datos a través de PDO.

1.2.1(4y ago)27proprietaryPHPPHP &gt;=7.4

Since May 2Pushed 4y ago1 watchersCompare

[ Source](https://github.com/maximo-perez-villalba/framework-dao-db)[ Packagist](https://packagist.org/packages/maximo-perez-villalba/framework-dao-db)[ RSS](/packages/maximo-perez-villalba-framework-dao-db/feed)WikiDiscussions main Synced 3d ago

READMEChangelogDependencies (2)Versions (5)Used By (0)

framework-dao-db
================

[](#framework-dao-db)

El proyecto implementa una extensión del framework `maximo-perez-villalba/framework-dao` para base de datos a través de PDO. Para ver el proyecto padre ir a [framework-dao](https://github.com/maximo-perez-villalba/framework-dao). Y aunque su fin principal es de apoyo pedagógico, la extensión es completamente funcional.

Instalación
-----------

[](#instalación)

Se puede instalar `framework-dao-db` a través de Composer.

1 Desde una consola de comandos ir al directorio del proyecto y ejecutar:

```
composer require maximo-perez-villalba/framework-dao-db

```

2 También agregando en el archivo `composer.json`, dentro de la sección `"require"`.

```
"require": {
  "maximo-perez-villalba/framework-dao-db": ">=1.0.0"
},

```

2.1 Luego desde una consola de comandos ejecutar:

```
composer update

```

Documentación
-------------

[](#documentación)

### Extensión DAO para bases de datos (DAODB)

[](#extensión-dao-para-bases-de-datos-daodb)

Esta extensión implementa a través de la [clase DAODB](/src/framework/dao/db/DAODB.php) el CRUD definido en la [clase DAO](https://github.com/maximo-perez-villalba/framework-dao/blob/main/src/framework/dao/DAO.php), para comunicarse con bases de datos a través de [PDO](https://www.php.net/manual/es/class.pdo) (PHP Data Object). A su vez la clase DAODB incorpora métodos específicos para la recuperación de datos desde la bases de datos.

[![image:uml-class-daodb.png](/docs/uml-class-daodb.png)](/docs/uml-class-daodb.png)

El diagrama de clases muestra el diseño de implementación de la extensión DAODB, donde **los objetos de modelo** deben extender de la [clase PersistentDB](/src/framework/dao/db/PersistentDB.php). Esto implica que en la base de datos, las tablas que representan **los objetos de modelo** deben contener la columna `PRIMARY KEY` bajo el nombre `uid` y ser de tipo entero.

#### Implementación

[](#implementación)

Como DAODB es una clase abstracta es requerido crear una clase que la extienda para su implementación específica.

Con este fin creamos una clase que se llame Something que extienda de PersistentDB y su respectiva SomethingDAODB que extiende de DAODB.

[![image:uml-class-something-daodb.png](/docs/uml-class-something-daodb.png)](/docs/uml-class-something-daodb.png)

El diagrama de clases muestra el diseño de implementación de la clase SomethingDAODB, donde expone los tres métodos requeridos para particularizar la persistencia en una base de datos de los objetos Something.

Estos 3 métodos son:

- **update():bool** definido en la clase DAO.
- **insert():bool** definido en la clase DAODB.
- **dataToObject(array):Something** definido en la clase DAODB.

#### Como se usa

[](#como-se-usa)

```
