gpt4 book ai didi

mysql - 在 phpMyAdmin 中存储数组( double )

转载 作者:行者123 更新时间:2023-11-29 03:45:48 25 4
gpt4 key购买 nike

虽然我之前在其他环境中使用过 SQL 数据库,但我对 MySQL 还是个新手。我设置了一个测试站点,其中有一个可以访问 phpMyAdmin 的在线 cPanel。我正在尝试设置一个 MySQL 数据库,到目前为止它工作正常(我可以连接到数据库表)。

我遇到的唯一问题是插入数据。我想将整个数组(具体而言,该数组将是一个 double[])插入到一列中。查看 phpMyAdmin 中可用的列类型后,它似乎不支持插入二进制数组以外的数组。

我找到了许多以编程方式插入数组的解决方案,包括 this线程,但对于此站点,我们将通过在线 cPanel 插入数据。有办法吗?

最佳答案

如果您想要访问该数据,并希望能够使用 SQL 的强大功能在您的 double[] 中进行搜索,您应该这样做:

首先,您应该花一些时间研究关系数据库。它们允许您创建链接数据。

每个关系数据库的一个重要部分是使用好的键。键是行的唯一标识符,可让您以高效的方式访问该行的数据。

关系数据库的另一个重要部分是索引。索引不需要是唯一的。但是,如果您尝试在它们上进行搜索(SQL 已经根据一列或一组列创建了表的“索引”)

如果您想创建一个包含 double [] 数组的表,您可以改为创建第二个表,该表通过第一个表的主键与第一个表关联。

CREATE TABLE base (
base_id INT AUTO_INCREMENT,
name VARCHAR(32),
PRIMARY KEY(base_id)
);

CREATE TABLE darray (
base_id INT,
data DOUBLE,
INDEX(base_id)
);

要获取所需的信息,您可以选择使用 JOIN 语句。如果想获取所有base_id为3的信息,可以这样写:

SELECT * FROM base
JOIN darray ON darray.base_id = base.base_id
WHERE base.base_id = 3;

使用别名编写的高级形式

SELECT * FROM base b
JOIN darray d ON d.base_id = b.base_id
WHERE b.base_id = 3;

如果你不想访问数据,而只是记忆它,你应该这样做:(虽然这是值得商榷的,但我仍然推荐上面的方式,如果你愿意学习更多的sql )

我假设您将使用 PHP,我们将序列化数据(参见:http://php.net/manual/en/function.serialize.php)

请注意,我们不会有 darray 表,而是添加一个

data    BLOB

到基表。

插入 PHP 序列化数据

<?php
$serializedData = serialize($darray);
$result = mysql_query("INSERT INTO base (name, data) VALUES('a name', '$serializedData ')");

获取序列化数据

<?php
$result = mysql_query("SELECT data FROM base WHERE base_id=3");
if($result && mysql_affected_rows($result) > 0) {
$serializedData = mysql_result($result, 0, 'data');
$darray = unserialize($serializedData);
}

关于mysql - 在 phpMyAdmin 中存储数组( double ),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5671117/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com