.
*
*/
$host="localhost";
$baseAnt="Inventario";
$baseNueva="Inventario2";
$usuario="root";
$claveUsuario="galeote";
$probar=false;
// No se debería modificar nada después de este comentario
function creaUbicacion($bd1,$bd2,$clave)
{
global $probar;
$comando="select nombre from Ubicaciones where codigo=".$clave.";";
$resultado=$bd1->query($comando);
if ($bd1->affected_rows==0) {
echo $comando;
die("No encontró la ubicación ".$clave);
}
$dato=$resultado->fetch_assoc();
$valor=$dato['nombre'];
$comando="insert into Ubicaciones values (NULL,'".$valor."');";
if ($probar) {
echo $comando;
return 1;
} else {
$test=$bd2->query($comando);
if (!$test) {
die("**No pudo insertar ubicacion.".$comando);
}
return $bd2->insert_id;
}
}
function creaArticulo($bd1,$bd2,$clave)
{
global $probar;
$comando="select * from Articulos where codigo='".$clave."';";
$resultado=$bd1->query($comando);
if ($bd1->affected_rows==0) {
echo $comando;
die("No encontró el artículo ".$clave);
}
$dato=$resultado->fetch_assoc();
$valor1=$dato['descripcion'];
$valor2=$dato['marca'];
$valor3=$dato['modelo'];
$valor4=$dato['cantidad'];
$comando="insert into Articulos values (NULL,'".$valor1."','".$valor2."','".$valor3."',".$valor4.");";
if ($probar) {
echo $comando;
return 1;
} else {
$test=$bd2->query($comando);
if (!$test) {
die("**No pudo insertar artículo.".$comando);
}
return $bd2->insert_id;
}
}
function generaSesion()
{
$long=10;
$cadena="";
for ($i=0;$i<$long;$i++) {
$cadena.=chr(rand(40,126));
}
return $cadena;
}
/*
*
* Comienzo del programa principal.
*
*/
$bd1=new mysqli($host,$usuario,$claveUsuario,$baseAnt);
if(mysqli_connect_errno()) {
die("**Error conectando a la base de datos antigua.".$bd1->error);
}
$bd2=new mysqli($host,$usuario,$claveUsuario,$baseNueva);
if(mysqli_connect_errno()) {
die("**Error conectando a la base de datos nueva.".$bd2->error);
}
$bd2->autocommit(false);
$datos=$bd1->query("select * from Elementos;");
if (!$datos) {
die("**No encontró datos en la tabla de elementos.");
}
$numRegistros=$bd1->affected_rows;
$contador=0;
$ubicaciones=array();
$articulos=array();
echo "++Comenzando proceso de actualización de Elementos con ".$numRegistros." registros por procesar.
\n";
while($fila=$datos->fetch_assoc()) {
$contador++;
echo "Procesando registro ".$contador." de ".$numRegistros."
\n";
if (!isset($ubicaciones[$fila['codUbicacion']])) {
$ubicaciones[$fila['codUbicacion']]=creaUbicacion($bd1,$bd2,$fila['codUbicacion']);
}
if (!isset($articulos[$fila['codArticulo']])) {
$articulos[$fila['codArticulo']]=creaArticulo($bd1,$bd2,$fila['codArticulo']);
}
$comando="insert into Elementos values (NULL,".$articulos[$fila['codArticulo']].",".$ubicaciones[$fila['codUbicacion']];
$comando.=",'".$fila['numserie']."',".$fila['cantidad'].",'".$fila['fechaCompra']."');";
if ($probar) {
echo $comando."
";
} else {
$res=$bd2->query($comando);
if (!$res) {
die("**Error ejecutando el comando de actualización. ".$comando." ".$bd2->error);
}
}
}
//Traspasa los usuarios
$datos=$bd1->query("select * from Usuarios;");
if (!$datos) {
die("**No encontró datos en la tabla de Usuarios.");
}
$numRegistros=$bd1->affected_rows;
$contador=0;
while ($fila=$datos->fetch_assoc()) {
$contador++;
echo "Procesando registro ".$contador." de ".$numRegistros."
\n";
$sesion=generaSesion();
$comando="insert into Usuarios values (NULL,'".$fila['usuario']."','".$fila['usuario']."','".$sesion;
$comando.="',".$fila['altas'].",".$fila['modificaciones'].",".$fila['bajas'].",".$fila['consultas'].",";
$comando.=$fila['informes'].",".$fila['usuarios'].",1);";
if ($probar) {
echo $comando."
";
} else {
$res=$bd2->query($comando);
if (!$res) {
die("**Error ejecutando el comando de actualización. ".$comando." ".$bd2->error);
}
}
}
echo "++Fin del proceso.
\n";
$bd2->commit();
$bd1->close();
$bd2->close();
?>