recreateIndexes.php 2.35 KB
<?php

/**
 * $Id: recreateIndexes.php 8085 2008-02-18 15:22:27Z kevin_fourie $
 *
 * KnowledgeTree Open Source Edition
 * Document Management Made Simple
 * Copyright (C) 2004 - 2008 The Jam Warehouse Software (Pty) Limited
 *
 * This program is free software; you can redistribute it and/or modify it under
 * the terms of the GNU General Public License version 3 as published by the
 * Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
 * details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 *
 * You can contact The Jam Warehouse Software (Pty) Limited, Unit 1, Tramber Place,
 * Blake Street, Observatory, 7925 South Africa. or email info@knowledgetree.com.
 *
 * The interactive user interfaces in modified source and object code versions
 * of this program must display Appropriate Legal Notices, as required under
 * Section 5 of the GNU General Public License version 3.
 *
 * In accordance with Section 7(b) of the GNU General Public License version 3,
 * these Appropriate Legal Notices must retain the display of the "Powered by
 * KnowledgeTree" logo and retain the original copyright notice. If the display of the
 * logo is not reasonably feasible for technical reasons, the Appropriate Legal Notices
 * must display the words "Powered by KnowledgeTree" and retain the original
 * copyright notice.
 * Contributor( s): ______________________________________
 *
 */

/*
 * PURPOSE: This script will recreate the indexes on the database. It will also attempt to add foreign key constraints.
 *
 * It will produce 'errors' when there are issues. Many may be ignored as some do not apply to open source.
 */

define('USE_DB_ADMIN_USER',1);
chdir(dirname(__FILE__));
require_once('../config/dmsDefaults.php');
require_once(KT_LIB_DIR . '/database/schema.inc.php');

print _kt('Recreate DB Indexes') . "...\n\n";

ini_set('display_errors','Off');
$schemautil = KTSchemaUtil::getSingleton();

$schemautil->dropForeignKeys();
$schemautil->dropPrimaryKeys();
$schemautil->dropIndexes();
$schemautil->createPrimaryKeys();
$schemautil->createForeignKeys();
$schemautil->createIndexes();

?>