0byt3m1n1
Path:
/
data
/
applications
/
aps.bak
/
vtiger
/
5.0.4
/
standard
/
htdocs
/
modules
/
Migration
/
[
Home
]
File: deleteCustomFields.php
<?php /********************************************************************************* ** The contents of this file are subject to the vtiger CRM Public License Version 1.0 * ("License"); You may not use this file except in compliance with the License * The Original Code is: vtiger CRM Open Source * The Initial Developer of the Original Code is vtiger. * Portions created by vtiger are Copyright (C) vtiger. * All Rights Reserved. * ********************************************************************************/ global $conn; //we have to get all customfields from customview and report related tables (cvcolumnlist, cvstdfilter, etc) and remove the entries from these tables if the customfields are not available in field table and cf table $tables_array = Array( "vtiger_cvcolumnlist"=>"columnname", "vtiger_cvstdfilter"=>"columnname", "vtiger_cvadvfilter"=>"columnname", "vtiger_selectcolumn"=>"columnname", "vtiger_relcriteria"=>"columnname", "vtiger_reportsortcol"=>"columnname", "vtiger_reportdatefilter"=>"datecolumnname", "vtiger_reportsummary"=>"columnname", ); foreach($tables_array as $tablename => $columnname) { $query = "select $columnname from $tablename where $columnname like '%:cf_%'"; $result = $conn->query($query); $noofrows = $conn->num_rows($result); for($i=0;$i<$noofrows;$i++) { //First get the fieldname from the result $col_value = $conn->query_result($result,$i,$columnname); $fieldname = substr($col_value,strpos($col_value,':cf_')+1,6); //Now check whether this field is available in field table $sql1 = "select fieldid from vtiger_field where fieldname='".$fieldname."'"; $result1 = $conn->query($sql1); $noofrows1 = $conn->num_rows($result1); $fieldid = $conn->query_result($result1,0,"fieldid"); //if there is no field then we have to delete that field entries if($noofrows1 == 0 && !isset($fieldid)) { //Now we have to delete that customfield from the $tablename Execute("delete from $tablename where $columnname like '%:".$fieldname.":%'"); } } } ?>