Envio de mensajes entre usuarios o amigos (Modelo Entidad-Relacion)

Iniciado por sReOn_1R, 3 Diciembre 2009, 02:06 AM

0 Miembros y 1 Visitante están viendo este tema.

^Tifa^

Imagina que tengo estas 2 Tablas con los siguientes datos:

Código (sql) [Seleccionar]

mysql> select * from relacion;
+------+--------+--------+   
| id   | codigo | nombre |   
+------+--------+--------+   
|    1 |      2 | Luis   |   
|    1 |      3 | Marta  |   
|    2 |      4 | Jose   |   
|    2 |      1 | Marian |   
+------+--------+--------+   
4 rows in set (0.00 sec)     

mysql> select * from usuarios;
+----+--------+               
| id | nombre |               
+----+--------+
|  1 | Marian |
|  2 | Luis   |
|  3 | Marta  |
|  4 | Jose   |
+----+--------+
4 rows in set (0.00 sec)


Y yo quiero controlar que cuando actualize o elimine un dato de la tabla usuarios se aplique en la tabla relacion
justo como lo haria las tablas si usase un motor de almacenamiento transaccional como InnoDB, la diferencia es que
estas 2 tablas estan bajo el motor no transaccional Myisam... entonces como tu controlas esto? con la creacion de
triggers como te venia comentando:

Código (sql) [Seleccionar]

mysql> delimiter /
mysql> create trigger trigo
    -> after update on usuarios
    -> for each row           
    -> begin                   
    -> update relacion set id = NEW.id where id = OLD.id;
    -> end;                                             
    -> /                                                 
Query OK, 0 rows affected (0.06 sec) 
mysql> delimiter ;

mysql> update usuarios set id = 6 where id = 1;
Query OK, 1 row affected (0.04 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> select * from relacion;
+------+--------+--------+
| id   | codigo | nombre |
+------+--------+--------+
|    6 |      2 | Luis   |
|    6 |      3 | Marta  |
|    2 |      4 | Jose   |
|    2 |      1 | Marian |
+------+--------+--------+
4 rows in set (0.00 sec)

mysql> select * from usuarios;
+----+--------+
| id | nombre |
+----+--------+
|  6 | Marian |
|  2 | Luis   |
|  3 | Marta  |
|  4 | Jose   |
+----+--------+
4 rows in set (0.00 sec)


Viste como actualice data en la tabla usuarios y automaticamente se aplico en la tabla relacion
como si estuviesen bajo un motor de almacenamiento transaccional, cuando no lo esta?
Ahora si quisieras aplicar el 'ON DELETE CASCADE' por ejemplo que si eliminas una fila en
la tabla usuarios tambien se elimine de forma automatica en la tabla relacion.

Código (sql) [Seleccionar]

mysql> create trigger trigo1
    -> after delete on usuarios
    -> for each row
    -> begin
    -> delete from relacion where id = OLD.id;
    -> end;
    -> /
Query OK, 0 rows affected (0.40 sec)

mysql> delimiter ;

mysql> delete from usuarios where id = 2;
Query OK, 1 row affected (0.00 sec)

mysql> select * from usuarios;
+----+--------+
| id | nombre |
+----+--------+
|  6 | Marian |
|  3 | Marta  |
|  4 | Jose   |
+----+--------+
3 rows in set (0.00 sec)

mysql> select * from relacion;
+------+--------+--------+
| id   | codigo | nombre |
+------+--------+--------+
|    6 |      2 | Luis   |
|    6 |      3 | Marta  |
+------+--------+--------+
2 rows in set (0.00 sec)



Lo anterior expuesto, no fuese posible de realizar sino existiera una relacion de identidad iguales de campos entre el campo ID de ambas tablas. Los datos no tienen que estas de manera obligatoria sobre tablas con motor InnoDB para poder funcionar (A nivel de relacion) como un motor transaccional lo haria. Pero especifico a nivel de relacion de campos no al nivel de todas las funcionalidades que posee un motor transaccional real como son los indices clustered en vez de b-tree, el lockeo de filas en vez de toda la tabla, entre otras cositas internas que poseen los motores transaccionales que no sera aplicable en motores no transaccionales, pero... en el caso que pides no es requerido exponer esto ni abundar tanto, lo que pides se puede controlar con TRIGGERS en motores no transaccionales como puedes ver... y obviamente asi como controlas que campos se actualizan y eliminan de la tabla relacion cuando hacemos algo en la tabla usuarios, puedes crear TRIGGERS que impidan que se actualice o elimine campos sobre relacion sino se ha aplicado nada en la tabla usuarios.


дٳŦ٭

MMMM a ver.. no estoy entendiendo... según yo no las tienes creadas, ya que myisam no te las crea, de hecho no existen con ese motor... mira, con innodb:

Código (sql) [Seleccionar]

mysql> SELECT * FROM `vendor_comment` PROCEDURE ANALYSE ( );
+---------------------------------+-----------------------------+------------------------------+------------+------------+------------------+-------+-------------------------+--------+---------------------------------------------------------------------------------------------------------------+
| Field_name                      | Min_value                   | Max_value                    | Min_length | Max_length | Empties_or_zeros | Nulls | Avg_value_or_avg_length | Std    | Optimal_fieldtype                                                                                             |
+---------------------------------+-----------------------------+------------------------------+------------+------------+------------------+-------+-------------------------+--------+---------------------------------------------------------------------------------------------------------------+
| vsi.vendor_comment.id_vendor    | 1                           | 3                            |          1 |          1 |                0 |     0 | 2.0000                  | 0.8165 | ENUM('1','2','3') NOT NULL                                                                                    |
| vsi.vendor_comment.id_buyer     | 1                           | 1                            |          1 |          1 |                0 |     0 | 1.0000                  | 0.0000 | ENUM('1') NOT NULL                                                                                            |
| vsi.vendor_comment.comment      | Buyer 1 comment to CocaCola | Buyer 1 comment to Microsoft |         27 |         31 |                0 |     0 | 28.6667                 | NULL   | ENUM('Buyer 1 comment to CocaCola','Buyer 1 comment to Ideas de Web','Buyer 1 comment to Microsoft') NOT NULL |
| vsi.vendor_comment.registration | 2009-12-31                  | 2009-12-31                   |         10 |         10 |                0 |     0 | 10.0000                 | NULL   | ENUM('2009-12-31') NOT NULL                                                                                   |
+---------------------------------+-----------------------------+------------------------------+------------+------------+------------------+-------+-------------------------+--------+---------------------------------------------------------------------------------------------------------------+
4 rows in set (0.00 sec)



Con sangre andaluza :)


^Tifa^

No se en que punto todavia no te aclaras....

En las tablas que yo he creado de ejemplo, hay una relacion el campo ID de ambas tablas, vamos que no es tan dificil de ver  :xD

Dejame intentar desglosar porque creo que tienes una pekena confusion en cuanto a las relaciones de entidades y si un motor es o no transaccional. Basandome en la manera como tu percibes cuando unos datos estan o no relacionados en varias tablas (que para ti solo aplican si el motor es transaccional) el ejemplo posteado por mi, y por casi todos los demas (sino todos) tambien estan erroneos. Porque ellos se basaron en el modelo entidad-relacion de datos, ellos no se han basado de si el motor es o no transaccional, son dos cosas distintas.

Cuando te dicen que un motor de almacenamiento es transaccional te estan diciendo que tiene unas funcionalidades (No las voy a describir todas aqui que conste, solo las basicas para ver si te aclaras un poco) dentro de estas funcionalidades existe el control de forma automatica entre 2  o mas tablas, donde hay una tabla 'padre' y una tabla 'hijo' este control lo que hace es precisamente, que si se actualiza o elimina un dato en la tabla padre aplica automaticamente a la tabla hijo (Siempre y cuando pusieras dicha condicion a la tabla hijo con ON UPDATE y ON DELETE) ahora, si te fijas bien yo te he recreado de forma basica esa mismita funcionalidad en 2 tablas bajo motor NO transaccional, como lo hice?? con los TRIGGERS que te postee. Estoy en este caso haciendo lo mismo que si ambas tablas fuesen transaccionales (En este unico punto ojo que no quiero personas que asuman que estoy comparando transaccional vs no transaccional) lo unico que yo misma cree la condiciones con 2 TRIGGERS, mientras un motor transaccional como InnoDB lo hace ya por defecto de forma automatica porque esta programado a funcionar asi.

Cuando te dicen un motor No transacional, te estan diciendo que las funcionalidades de las cuales carece este motor es precisamente el control automatico de lo que ocurre entre la tabla padre o la tabla hijo (Hay mas diferencias que conste, pero no aplica extenderlas para lo que requieres aclararte). Por esta razon si yo tomo este modelo y lo coloco bajo un motor no transaccional, como yo controlo las transaciones de ahi me vere obligada a implementar de alguna manera las funcionalidades basicas que controlen los cambios de una tabla padre a una tabla hijo, por eso viste que cree 2 TRIGGERS sencillos que me manejaran los UPDATE y DELETE de la tabla padre hacia la tabla hijo.

Las relaciones entre tablas se basan por las entidades que componen las tablas llamase campos, no es obligatorio que este en un motor transacional o no, las relaciones de datos es una cosa, la funcionalidad de control sobre esos datos es otra cosa y te lo he expuesto mas arriba.