當前位置: 首頁>>代碼示例>>PHP>>正文


PHP DoliDB::getVersionArray方法代碼示例

本文整理匯總了PHP中DoliDB::getVersionArray方法的典型用法代碼示例。如果您正苦於以下問題:PHP DoliDB::getVersionArray方法的具體用法?PHP DoliDB::getVersionArray怎麽用?PHP DoliDB::getVersionArray使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在DoliDB的用法示例。


在下文中一共展示了DoliDB::getVersionArray方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: migrate_restore_missing_links

/**
 * Migration du champ fk_remise_except dans llx_facturedet doit correspondre a
 * lien dans llx_societe_remise_except vers llx_facturedet
 *
 * @param	DoliDB		$db		Database handler
 * @param	Translate	$langs	Object langs
 * @param	Conf		$conf	Object conf
 * @return	void
 */
function migrate_restore_missing_links($db, $langs, $conf)
{
    dolibarr_install_syslog("upgrade2::migrate_restore_missing_links");
    if ($db->type == 'mysql' || $db->type == 'mysqli') {
        if (versioncompare($db->getVersionArray(), array(4, 0)) < 0) {
            dolibarr_install_syslog("upgrade2::migrate_restore_missing_links Version of database too old to make this migrate action");
            return 0;
        }
    }
    print '<tr><td colspan="4">';
    print '<br>';
    print '<b>' . $langs->trans('MigrationFixData') . "</b> (1)<br>\n";
    $error = 0;
    // Restore missing link for this cross foreign key (link 1 <=> 1). Direction 1.
    $table1 = 'facturedet';
    $field1 = 'fk_remise_except';
    $table2 = 'societe_remise_except';
    $field2 = 'fk_facture_line';
    $db->begin();
    $sql = "SELECT t1.rowid, t1." . $field1 . " as field";
    $sql .= " FROM " . MAIN_DB_PREFIX . $table1 . " as t1";
    $sql .= " WHERE t1." . $field1 . " IS NOT NULL AND t1." . $field1 . " NOT IN";
    $sql .= " (SELECT t2.rowid FROM " . MAIN_DB_PREFIX . $table2 . " as t2";
    $sql .= " WHERE t1.rowid = t2." . $field2 . ")";
    dolibarr_install_syslog("upgrade2:migrate_restore_missing_links DIRECTION 1", LOG_DEBUG);
    $resql = $db->query($sql);
    if ($resql) {
        $i = 0;
        $num = $db->num_rows($resql);
        if ($num) {
            while ($i < $num) {
                $obj = $db->fetch_object($resql);
                print 'Line ' . $obj->rowid . ' in ' . $table1 . ' is linked to record ' . $obj->field . ' in ' . $table2 . ' that has no link to ' . $table1 . '. We fix this.<br>';
                $sql = "UPDATE " . MAIN_DB_PREFIX . $table2 . " SET";
                $sql .= " " . $field2 . " = '" . $obj->rowid . "'";
                $sql .= " WHERE rowid=" . $obj->field;
                $resql2 = $db->query($sql);
                if (!$resql2) {
                    $error++;
                    dol_print_error($db);
                }
                //print ". ";
                $i++;
            }
        } else {
            print $langs->trans('AlreadyDone') . "<br>\n";
        }
        if ($error == 0) {
            $db->commit();
        } else {
            $db->rollback();
        }
    } else {
        dol_print_error($db);
        $db->rollback();
    }
    print '</td></tr>';
    print '<tr><td colspan="4">';
    print '<br>';
    print '<b>' . $langs->trans('MigrationFixData') . "</b> (2)<br>\n";
    // Restore missing link for this cross foreign key (link 1 <=> 1). Direction 2.
    $table2 = 'facturedet';
    $field2 = 'fk_remise_except';
    $table1 = 'societe_remise_except';
    $field1 = 'fk_facture_line';
    $db->begin();
    $sql = "SELECT t1.rowid, t1." . $field1 . " as field";
    $sql .= " FROM " . MAIN_DB_PREFIX . $table1 . " as t1";
    $sql .= " WHERE t1." . $field1 . " IS NOT NULL AND t1." . $field1 . " NOT IN";
    $sql .= " (SELECT t2.rowid FROM " . MAIN_DB_PREFIX . $table2 . " as t2";
    $sql .= " WHERE t1.rowid = t2." . $field2 . ")";
    dolibarr_install_syslog("upgrade2:migrate_restore_missing_links DIRECTION 2", LOG_DEBUG);
    $resql = $db->query($sql);
    if ($resql) {
        $i = 0;
        $num = $db->num_rows($resql);
        if ($num) {
            while ($i < $num) {
                $obj = $db->fetch_object($resql);
                print 'Line ' . $obj->rowid . ' in ' . $table1 . ' is linked to record ' . $obj->field . ' in ' . $table2 . ' that has no link to ' . $table1 . '. We fix this.<br>';
                $sql = "UPDATE " . MAIN_DB_PREFIX . $table2 . " SET";
                $sql .= " " . $field2 . " = '" . $obj->rowid . "'";
                $sql .= " WHERE rowid=" . $obj->field;
                $resql2 = $db->query($sql);
                if (!$resql2) {
                    $error++;
                    dol_print_error($db);
                }
                //print ". ";
                $i++;
            }
//.........這裏部分代碼省略.........
開發者ID:ADDAdev,項目名稱:Dolibarr,代碼行數:101,代碼來源:upgrade2.php


注:本文中的DoliDB::getVersionArray方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。