Loading presentation...

Present Remotely

Send the link below via email or IM

Copy

Present to your audience

Start remote presentation

  • Invited audience members will follow you as you navigate and present
  • People invited to a presentation do not need a Prezi account
  • This link expires 10 minutes after you close the presentation
  • A maximum of 30 users can follow your presentation
  • Learn more about this feature in our knowledge base article

Do you really want to delete this prezi?

Neither you, nor the coeditors you shared it with will be able to recover it again.

DeleteCancel

Make your likes visible on Facebook?

Connect your Facebook account to Prezi and let your likes appear on your timeline.
You can change this under Settings & Account at any time.

No, thanks

ORM - Object-Relational Mapping

No description
by

Nestor Mendez

on 27 April 2015

Comments (0)

Please log in to add your comment.

Report abuse

Transcript of ORM - Object-Relational Mapping

ORM - Object-Relational Mapping
Agenda
Motivación
Conceptos
Inicios
ORM Conocidos
Relaciones
Patrones utilizados
Motivación
POO vs BDR


Código SQL dentro de Código Web


Diferencias entre Código SQL
Conceptos Básicos
Es una técnica de programación para convertir datos entre el sistema de tipos utilizado en un lenguaje de
Programación Orientado a Objetos
y la utilización de una
Base de Datos Relacional
como motor de persistencia.
Inicios
Objeto de Acceso a Datos - DAO
Patrón de Diseño
Encapsular el acceso a los datos
Diferentes SMBD
Origen (Conexión a la BD)
Proporcionar mecanismos para
Hacer persistencia
Obtener objetos persistentes
Usa al patrón TransferObject
Transporta datos entre procesos
ORM Conocidos
<?php
$dbhandle = mysql_connect($host, $user, $pass);
$db_selected = mysql_select_db("db_name", $dbhandle);
$cars = mysql_query("SELECT * FROM cars;");
while ($row = mysql_fetch_array($cars)) {
echo "ID:".$row{'id'}." Name:".$row{'model'}."
".$row{'year'}."<br>";
}
?>
SqlServer
SELECT TOP 10 * FROM usuarios;

MySQL
SELECT * FROM usuarios LIMIT 10;

Oracle
SELECT * FROM usuarios WHERE rownum<=10;
Mapping
Archivos XML
Convenciones
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
<class name="Employee" table="EMPLOYEE">
<meta attribute="class-description">
This class contains the employee detail.
</meta>
<id name="id" type="int" column="id">
<generator class="native"/>
</id>
<property name="firstName" column="first_name" type="string"/>
<property name="lastName" column="last_name" type="string"/>
<property name="salary" column="salary" type="int"/>
</class>
</hibernate-mapping>
Los modelos deberán estar en Singular.
La tablas en Plural.

Los modelos deberán nombrarse utilizando la forma CamelCase
Las tablas deberán estar en minuscula y separadas por "guión bajo" (_)

Clave primária - id
Claves Foráneas - nombre_tabla_singular_id
(Ej item_id, order_id)

Opcioales
created_at
updated_at
Full transcript