首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在mysql数据库中插入自定义对象数组

如何在mysql数据库中插入自定义对象数组
EN

Stack Overflow用户
提问于 2013-07-12 19:41:06
回答 1查看 917关注 0票数 0

我正在构建一个iOS应用程序,允许用户浏览产品并进行订购。当用户点击订单时,我希望将他/她的用户名、电子邮件、地址、交货日期以及他订购的一系列产品保存到我的mysql数据库中。我需要能够在我的其他应用程序上看到订单,这是我为企业制作的。

保存像用户名或地址这样的字符串不是问题,但是保存产品数组(由自定义对象表示)似乎是错误的。我的数据库没有返回数组,当我尝试在我的其他应用程序上下载它时,它应该返回的数组,我不能找出原因。

我的自定义对象具有以下属性:

itemName、itemCode、itemBarCode、itemCompany、itemPrice、itemQuantity、itemUserRemark、itemCompany、productImageNumber

每个变量都是一个字符串,对象表示用户购物车(由orderProducts数组表示)中的一个项目。

我将订单发送到我的web服务,如下所示:

代码语言:javascript
运行
复制
NSString *orderToSend = [NSString stringWithFormat:@"http://www.imagine-app.nl/orderInsert.php?user=%@&orderAdressStreet=%@&orderAdressZip=%@&orderAdressNumber=%@&orderAdressCity=%@&paymentType=%@&orderDate=%@&orderDelivery=%@&orderProducts=%@&company=%@", orderClass.user, orderClass.orderAdressStreet, orderClass.orderAdressZip, orderClass.orderAdressNumber, orderClass.orderAdressCity, orderClass.orderPaymentType, orderClass.orderDate, orderClass.orderDelivery, orderClass.orderProducts, orderClass.company];
        NSString *strURL = [orderToSend stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];

        NSLog(@"connection %@", strURL);

在我的web服务上:

代码语言:javascript
运行
复制
<?php

if (isset($_GET["user"]) && isset($_GET["orderAdressStreet"]) && isset($_GET["orderAdressZip"]) && isset($_GET["orderAdressNumber"]) && isset($_GET["orderAdressCity"]) && isset($_GET["paymentType"]) && isset($_GET["orderDate"]) && isset($_GET["orderDelivery"]) && isset($_GET["orderProducts"])  && isset($_GET["company"]) ){
                $user = $_GET["user"];
                $orderAdressStreet = $_GET["orderAdressStreet"];
                $orderAdressZip = $_GET["orderAdressZip"];
                $orderAdressNumber = $_GET["orderAdressNumber"];
                $orderAdressCity = $_GET["orderAdressCity"];
                $paymentType = $_GET["paymentType"];
                $orderDate = $_GET["orderDate"];
                $orderDelivery = $_GET["orderDelivery"];
                $orderProducts = $_GET["orderProducts"];
                $company = $_GET['company'];

                $result = insertOrder($user, $orderAdressStreet, $orderAdressZip, $orderAdressNumber, $orderAdressCity, $paymentType, $orderDate, $orderDelivery, $orderProducts, $company);
                echo $result;
                }

function makeSqlConnection()
{
$DB_HostName = "xxxxx";
$DB_Name = "xxxxx";
$DB_User = "xxxxx";
$DB_Pass = "xxxxxxx";


    $con = mysql_connect($DB_HostName,$DB_User,$DB_Pass) or die(mysql_error()); 

        mysql_select_db($DB_Name,$con) or die(mysql_error()); 

    return $con;
}

function disconnectSqlConnection($con)
{
    mysql_close($con);
}

function insertOrder($user, $orderAdressStreet, $orderAdressZip, $orderAdressNumber, $orderAdressCity, $paymentType, $orderDate, $orderDelivery, $orderProducts, $company)
{
    $con = makeSqlConnection();

    $sqlInsert = "INSERT INTO Orders (user, orderAdressStreet, orderAdressZip, orderAdressNumber, orderAdressCity, paymentType, orderDate, orderDelivery, orderProducts, company) VALUES ('$user', '$orderAdressStreet', '$orderAdressZip', '$orderAdressNumber', '$orderAdressCity', '$paymentType', '$orderDate', '$orderDelivery', '$orderProducts' , '$company');";

    $insertNewItems = mysql_query($sqlInsert,$con) or die(mysql_error());

    disconnectSqlConnection($con);  
}

?>

这似乎是可行的,因为所有的对象都被插入到我的数据库中。我的orderProducts数组包含一个有序的产品,插入到一个单元格中,如下所示:

( "“)

当我在我的业务端应用程序上下载此订单时,我使用以下代码:

代码语言:javascript
运行
复制
on my server side:

    <?php

if (isset($_GET["company"])){
                $company = $_GET["company"];
                $result = getOrders($company);
                echo $result;
        }

function makeSqlConnection()
{
$DB_HostName = "xxxxx";
$DB_Name = "xxxxx";
$DB_User = "xxxxx";
$DB_Pass = "xxxxxxxx";


    $con = mysql_connect($DB_HostName,$DB_User,$DB_Pass) or die(mysql_error()); 
    mysql_select_db($DB_Name,$con) or die(mysql_error()); 

    return $con;
}

function disconnectSqlConnection($con)
{
    mysql_close($con);
}

function getOrders($company)
{
    $con = makeSqlConnection(); 
    $query = mysql_query("SELECT * from items  WHERE company = '$company'");
    $ordersFromDatabase = array();
        while ($row = mysql_fetch_assoc($query)) {
        $orders['ordersFromDatabase'][] = $row;
    }   
    print json_encode($orders);
    $res = mysql_query($sql,$con) or die(mysql_error());
    echo $res;

        disconnectSqlConnection($con);  
    }
    ?>

在我的应用程序的viewDidLoad中:

代码语言:javascript
运行
复制
- (void)viewDidLoad
{
    [super viewDidLoad];

    Store* myStore = [Store sharedStore];
    NSString *companyID = [[NSString alloc] initWithString: myStore.companyID];

    NSURL *strUrl = [NSURL URLWithString:[NSString stringWithFormat:@"http://www.imagine-app.nl/getOrders.php?company=%@", companyID]];
    NSLog(@"connection: %@", strUrl);
    NSData *jsonData = [NSData dataWithContentsOfURL:strUrl];
    NSLog(@"%@", jsonData);
    NSMutableArray *ordersFromDataBbase = [NSJSONSerialization JSONObjectWithData:jsonData options:kNilOptions error:NULL][@"ordersFromDatabase"];
    NSLog(@"Products Array: %@", ordersFromDataBbase);

}

无论我做什么,数组总是为null,我不确定这是否是将自定义对象数组发送到mysql的正确方式。

所以我的最后一个问题,有没有人知道一些示例代码,教程,或者仅仅是如何从Objective-c通过php向mysql发送和检索自定义对象的数组?

提前感谢您,如有保留,不胜感激。

EN

回答 1

Stack Overflow用户

发布于 2013-07-12 20:56:39

只需创建一个REST服务器,并在移动客户端和服务器之间发送数据。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17614148

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档