startSetup(); $installer->run(" -- DROP TABLE IF EXISTS {$this->getTable('review')}; CREATE TABLE {$this->getTable('review')} ( `review_id` bigint(20) unsigned NOT NULL auto_increment, `created_at` datetime NOT NULL default '0000-00-00 00:00:00', `entity_id` smallint(5) unsigned NOT NULL default '0', `entity_pk_value` int(10) unsigned NOT NULL default '0', `status_id` tinyint(3) unsigned NOT NULL default '0', PRIMARY KEY (`review_id`), KEY `FK_REVIEW_ENTITY` (`entity_id`), KEY `FK_REVIEW_STATUS` (`status_id`), KEY `FK_REVIEW_PARENT_PRODUCT` (`entity_pk_value`), CONSTRAINT `FK_REVIEW_ENTITY` FOREIGN KEY (`entity_id`) REFERENCES {$this->getTable('review_entity')} (`entity_id`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `FK_REVIEW_PARENT_PRODUCT` FOREIGN KEY (`entity_pk_value`) REFERENCES {$this->getTable('catalog_product_entity')} (`entity_id`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `FK_REVIEW_STATUS` FOREIGN KEY (`status_id`) REFERENCES {$this->getTable('review_status')} (`status_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Review base information'; -- DROP TABLE IF EXISTS {$this->getTable('review_detail')}; CREATE TABLE {$this->getTable('review_detail')} ( `detail_id` bigint(20) unsigned NOT NULL auto_increment, `review_id` bigint(20) unsigned NOT NULL default '0', `store_id` smallint(6) unsigned NOT NULL default '0', `title` varchar(255) NOT NULL default '', `detail` text NOT NULL, `nickname` varchar(128) NOT NULL default '', `customer_id` int(10) unsigned default NULL, PRIMARY KEY (`detail_id`), KEY `FK_REVIEW_DETAIL_REVIEW` (`review_id`), CONSTRAINT `FK_REVIEW_DETAIL_REVIEW` FOREIGN KEY (`review_id`) REFERENCES {$this->getTable('review')} (`review_id`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Review detail information'; -- DROP TABLE IF EXISTS {$this->getTable('review_entity')}; CREATE TABLE {$this->getTable('review_entity')} ( `entity_id` smallint(5) unsigned NOT NULL auto_increment, `entity_code` varchar(32) NOT NULL default '', PRIMARY KEY (`entity_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Review entities'; insert into {$this->getTable('review_entity')}(`entity_id`,`entity_code`) values (1,'product'),(2,'customer'),(3,'category'); -- DROP TABLE IF EXISTS {$this->getTable('review_entity_summary')}; CREATE TABLE {$this->getTable('review_entity_summary')} ( `primary_id` bigint(20) NOT NULL auto_increment, `entity_pk_value` bigint(20) NOT NULL default '0', `entity_type` tinyint(4) NOT NULL default '0', `reviews_count` smallint(6) NOT NULL default '0', `rating_summary` tinyint(4) NOT NULL default '0', `store_id` smallint (5) unsigned NOT NULL default '0', PRIMARY KEY (`primary_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- DROP TABLE IF EXISTS {$this->getTable('review_status')}; CREATE TABLE {$this->getTable('review_status')} ( `status_id` tinyint(3) unsigned NOT NULL auto_increment, `status_code` varchar(32) NOT NULL default '', PRIMARY KEY (`status_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Review statuses'; insert into {$this->getTable('review_status')}(`status_id`,`status_code`) values (1,'Approved'),(2,'Pending'),(3,'Not Approved'); -- DROP TABLE IF EXISTS `{$this->getTable('review_store')}`; CREATE TABLE `{$this->getTable('review_store')}` ( `review_id` bigint(20) unsigned NOT NULL, `store_id` smallint(5) unsigned NOT NULL, PRIMARY KEY (`review_id`,`store_id`), CONSTRAINT `FK_REVIEW_STORE_REVIEW` FOREIGN KEY (`review_id`) REFERENCES `{$this->getTable('review')}` (`review_id`) ON DELETE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; "); $installer->endSetup();