php - 获取数组并插入到不同的数据库中。插入字符串中增加变量?

标签 php mysql

我已经尝试了几种不同的实现方法,但似乎无法得到最后一点正确的结果。最有效的显然是最好的方案,但目前它的工作是第二位的。

我正在尝试从 Syspro 连接中提取数据并将其插入到 MySQL 连接中。我不需要使用此代码打印任何内容,只需简单地插入 MySQL 数据库即可。

//MySQL Connection
$mysqlcon=mysqli_connect("localhost","root","","production");
// Check connection
if (mysqli_connect_errno()) {
    echo "Failed to connect to MySQL: " . mysqli_connect_error();
    }

//Syspro connection
$conn=odbc_connect('syspro','','');
if (!$conn)
  {exit("Connection Failed: " . odbc_error());}

//Warehouse valuation for S6/SX/SN/SW
$sql_warehouses=
    "SELECT SysproCompanyJ.dbo.InvWarehouse.Warehouse, SUM(UnitCost * QtyOnHand) AS 'Value'

    FROM SysproCompanyJ.dbo.InvWarehouse         

    WHERE   SysproCompanyJ.dbo.InvWarehouse.QtyOnHand > '0' 
        AND SysproCompanyJ.dbo.InvWarehouse.Warehouse NOT LIKE 'A_'
        AND SysproCompanyJ.dbo.InvWarehouse.Warehouse = 'S6' 
        OR Warehouse = 'SX'
        OR Warehouse = 'SN' 
        OR Warehouse = 'SW'

    GROUP BY Warehouse";

$test = array();
$i=0;   
$rs=odbc_exec($conn,$sql_warehouses);
if (!$rs)
  {exit("Error in SQL");}

    while ($row = odbc_fetch_array($rs))    {
        //echo $row['Warehouse'] . ':' .$row['Value']; 
        array_push($test,$row['Warehouse'],$row['Value']);
        //echo mysqli_query($mysqlcon,"INSERT INTO inv_valuation (warehouse, value)
        //VALUES ({$row['Warehouse']} ,{$row['Value']})");
        }

for($i = 0, $size = count($test); $i < $size; ++$i) {
    //echo "WH=" . $test[$i] . ", $=" . $test[++$i];
    mysqli_query($mysqlcon,"INSERT INTO inv_valuation (warehouse, value)
    VALUES ($test[$i] ,$test[++$i])");
    }

    //print_r($test);
    //var_dump($test);
    //echo count($test);

最佳答案

好吧,我会这样做:

while ($row = odbc_fetch_array($rs))    {
    mysqli_query($mysqlcon,"INSERT INTO inv_valuation (warehouse, value)
        VALUES ('" . $row['Warehouse'] . "', '" . $row['Value'] . "')");
}

无需再次循环(正如您之前尝试过的:))

关于php - 获取数组并插入到不同的数据库中。插入字符串中增加变量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19791870/

相关文章:

php - 在 Laravel 5 中存储模型观察者(事件)的位置

php - Zend Studio 中的命名空间提示

php - 如果在 select 中指定大写,则 Order by 子句失败

php - 为什么我的用户被添加到一个表而不是另一个表

mysql - PHP Mysqli 等于运算符不工作

php - 用于大型和可扩展应用程序的数据库表结构

PHP。在注册步骤中使用地理编码谷歌API

php - mysqli 函数 bind_result、store_result 和 fetch 之间有什么区别?

mysql - 用于计算调查完成百分比的 SQL 查询

mysql - 使用表达式查询选择大于