0

我有一个 5 级多维数组。数组中键的数量会波动,但我需要将其存储在数据库中,以便稍后使用 PHP 访问它。有没有简单的方法可以做到这一点?

我的想法是使用几个不同的分隔符将数组转换为单个字符串#*%*然后在需要时使用一系列 explode() 将数据转换回数组。

此时我还没有编写任何代码,因为我希望有更好的方法来做到这一点。但我确实有一个潜在的解决方案,我试图在下面概述:

这是我的阵列的概述:

n=button number
i=item number
btn[n][0]               = button name
btn[n][1]               = button desc
btn[n][2]               = success or not (Y or N)
btn[n][3]               = array containing item info
    btn[n][3][i][0]     = item intput type (Default/Preset/UserTxt/UserDD)
    btn[n][3][i][1]     = array containing item value - if more than one index then display as drop down

这是我将要使用的分隔符的一个破败:

#*Button Title                      //button title
    &*val1=*usr1234                 //items and values
    &*val2=*FROM_USER(_TEXT_$*name:)        //if an items value contains "FROM_USER" then extract the data between the perenthesis
    &*val3=*FROM_USER(_TEXT_$*Time:)        //if the datatype contains _TEXT_ then explode AGAIN by $* and just display a textfield with the title
    &*val4=*FROM_USER($*name1@*value1$*name2@*value2)       //else explode AGAIN by $* for a list of name value pairs which represent a drop box - name2@*value2

//sample string - a single button
#*Button Title%*val1=*usr1234&*val2=*FROM_USER(_TEXT_$*name:)&*val3=*FROM_USER(_TEXT_$*date:)&*val4=*FROM_USER($*name1@*value1$*name2@*value2)

总之,我正在寻找一些关于如何将多维数组存储在单个数据库表中的想法。

4

4 回答 4

4

看看serializejson_encode

于 2013-03-28T09:33:50.503 回答
4

你想要的是一种数据序列化方法。不要自己发明,那里已经有很多了。最明显的候选者是 JSON( json_encode) 或特定于 PHP 的serialize. XML 也是一种选择,特别是如果您的数据库可能在某种程度上原生支持它。

于 2013-03-28T09:34:48.640 回答
0

对您来说最好的决定是json_encode

除了序列化存储在数据库中之外,它对于 json_encode 有一些优点。

  1. 采取更小的尺寸
  2. 如果您必须在 db 中手动修改数据,则序列化会出现一些问题,因为此格式存储已序列化的值的大小,并且修改此值您必须计算并修改此参数。
于 2013-03-28T10:12:15.793 回答
0

SQL(无论是 mySQL 还是任何其他变体)不支持数组数据类型。

您应该在 SQL 中处理此类数据的方式是将其存储在多个表中。

因此,在此示例中,您将拥有一个包含buttonIDbuttonNamebuttonSuccess等字段的表,以及另一个包含buttonInputTypebuttonInputValue字段的表,并buttonID链接回父表。

那将是推荐的“关系”做事方式。这样做的意义在于,当时间到来时,可以更轻松地将数据从数据库中查询出来。

不过还有其他选择。

一种选择是使用 mySQL 的enum功能。由于您有一组可用于输入类型的固定值,因此您可以为其使用一个enum字段,这样您就无需为此准备一个额外的表。

当然,另一种选择是其他人所建议的,只需使用json_encode()或类似方法对数据进行序列化,并将其全部存储在一个大文本字段中。

如果数据将被用作一个简单的数据块,而无需运行查询来检查其中的一部分,那么这有时可能是最简单的解决方案。这不是数据库专家想要看到的,但从实用的角度来看,如果它完成了工作,那么请随意使用它。

但是,重要的是要了解这些限制。通过使用序列化解决方案,您基本上是在说“这些数据根本不需要以任何方式管理,所以我不会为它做适当的数据库设计而烦恼。”。这很好,只要您不需要管理它或在其中搜索值。如果你这样做了,你需要更加努力地思考你的数据库设计,并小心选择“简单”的选项。

于 2013-03-28T12:31:55.720 回答