mysql中怎么存储数组

如题所述

mysql中不能存储数组,但是可以通过传入的字符串截取成多个字符然后传入到临时表中,然后使用游标或者直接关联表过滤数据来储存。

具体步骤如下所示:

1、创建数据库,就如下图所示一样。

2、根据学生编号批量删除学生信息,如下图所示。

3、声明初始化变量,看到以下画面。

4、获取传入参数数组长度,创建临时表,所输入的如下图所示。

5、截取数组字符串并依次存入到临时表中供后面业务使用。

温馨提示:内容为网友见解,仅供参考
第1个回答  2013-03-27
MySQL是“世界上最为流行的开放性数据库”,至少对于MySQL Web站点会这样。但无论MySQL如此流行,很多公司都对MySQL的使用抱有抵触情绪。这种现象来自几个原因,其中有些人错误地认为开放性源代码只不过相当于小孩子的积木游戏,而另一些人认为任何免费的东西都不会是好东西。也许这些想法都是误解,然而有一种抱怨却是合理的,即与其它对应的产品不一样,比如Oracle或者 DB2,MySQL不能够支持存储过程(stored procedures)。

最新的MySQL 5.0能够支持存储过程。如果你对存储过程还没有熟悉,那么你可以认为它们只是存储在数据库服务器端的SQL命令和程序逻辑的集合。这些存储过程可以被应用程序调用,使得不同技术水平的开发人员能够建立自己的SQL。
优点 存储过程能够允许绝大部分的数据库访问逻辑与程序逻辑分离开来。使用存储过程的其中一个间接的优点是,程序的代码变得更加小巧和容易理解。存储过程的另一优点是,SQL可以被预先编译,由此提高了程序的速度。因为存储过程包含程序逻辑,可以在数据库服务器端更多地执行更多的处理。同样,当执行一个n-tier程序时,存储过程被用于将数据层与服务层分离开来。
安全性也是存储过程的另一优点。当不能直接访问表格时,程序可以将执行优先级别分配给存储过程。不幸的是,在这时候,MySQL不支持“授予执行(GRANT EXECUTE)”。这就意味着除非程序具有访问表格的权限,否则调用访问相同表格的一个存储过程也是不行的。使用这一特性有点像在做一个很有趣的赌博。
标准 与Oracle或者微软的相关数据库不一样,MySQL和IBM的DB2能够遵循存储程序的SQL:2003语法。在理论上这意味着,如果数据库结构相同,存储程序可以在不同数据库中使用。
可支持的SQL声明 虽然MySQL不能支持存储程序,但它却可以完成很多任务,如表A所示。除此之外,MySQL的stored procedure documentation(存储过程文档)描述了可用于Oracle的PL/SQL和SQL Server的 T-SQL的很多兼容特性。我对存储过程支持的印象是,它执行比较缓慢,目的是避免任何影响大型软件开发工程的步骤。
表A 声明
描述

CREATE PROCEDURE
建立一个存放在MySQL数据库的表格的存储过程。

CREATE FUNCTION
建立一个用户自定义的函数,尤其是返回数据的存储过程。

ALTER PROCEDURE
更改用CREATE PROCEDURE 建立的预先指定的存储过程,其不会影响相关存储过程或存储功能。.

ALTER FUNCTION
更改用CREATE FUNCTION 建立的预先指定的存储过程,其不会影响相关存储过程或存储功能。.

DROP PROCEDURE
从MySQL的表格中删除一个或多个存储过程。

DROP FUNCTION
从MySQL的表格中删除一个或多个存储函数。

SHOW CREATE PROCEDURE
返回使用CREATE PROCEDURE 建立的预先指定的存储过程的文本。这一声明是SQL:2003规范的一个MySQL扩展。

SHOW CREATE FUNCTION
返回使用CREATE FUNCTION建立的预先指定的存储过程的文本。这一声明是SQL:2003规范的一个MySQL扩展。

SHOW PROCEDURE STATUS
返回一个预先指定的存储过程的特性,包括名称、类型、建立者、建立日期、以及更改日期。这一声明是SQL:2003规范的一个MySQL扩展。

SHOW FUNCTION STATUS
返回一个预先指定的存储函数的特性,包括名称、类型、建立者、建立日期、以及更改日期。这一声明是SQL:2003规范的一个MySQL扩展。

CALL
调用一个使用CREATE PROCEDURE建立的预先指定的存储过程。

BEGIN ... END
包含一组执行的多声明。

DECLARE
用于指定当地变量、环境、处理器,以及指针。

SET
用于更改当地和全局服务器变量的值。

SELECT ... INTO
用于存储显示变量的纵列。

OPEN
用于打开一个指针。

FETCH
使用特定指针来获得下一列。

CLOSE
用于关闭和打开指针。

IF
一个An if-then-else-end if 声明。

CASE ... WHEN
一个 case声明的结构

LOOP
一个简单的循环结构;可以使用LEAVE 语句来退出。

LEAVE
用于退出IF,CASE,LOOP,REPEAT以及WHILE 语句。

ITERATE
用于重新开始循环。

REPEAT
在结束时测试的循环。

WHILE
在开始时测试的循环。

RETURNS
返回一个存储过程的值。

MySQL 5.0支持存储过程语句。

重要的是,请记住当前的MySQL对存储过程的支持没有Oracle,SQL Server或者DB2的成熟。同样记住,具有少量的特性但却操作良好,这比具有大量特性但却错误百出的强得多,这一点更加重要。我知道这是一个比较奇怪的概念,但社区里的很多人有时候却被其它一些概念所迷惑。
第2个回答  推荐于2017-11-28
把数组变成字符串:比如$a=array{"12","23","34","45"};
$a="12,23,34,45"; 把这个存到数据库中就行了
读取时再用explode变成数组本回答被网友采纳

如何在MySQL中有效地存储和操作数组mysql不能存储数组
1. 使用 JSON 类型 MySQL 5.7.8 引入了 JSON 数据类型,可以存储和查询 JSON 格式数据。对于数组,可以使用 JSON 数组来存储。例如,下面是一个包含三个整数元素的 JSON 数组:[1, 2, 3]现在我们将此数组存储为 MySQL 表的一列,可以使用以下语句:CREATE TABLE example (id int(11) NOT NULL...

mysql中怎么存储数组
mysql中不能存储数组,但是可以通过传入的字符串截取成多个字符然后传入到临时表中,然后使用游标或者直接关联表过滤数据来储存。具体步骤如下所示:1、创建数据库,就如下图所示一样。2、根据学生编号批量删除学生信息,如下图所示。3、声明初始化变量,看到以下画面。4、获取传入参数数组长度,创建临时表...

mysql中怎么存储数组?在线等!急!
把数组转换成字符串后再存入数据库 参考函数:implode() ---把数组转换成字符串 explode() ---把字符串转换成数组 手册里有详细说明 序列化以后存储.对于一维数组可以简单的用 implode explode 函数做数组——串的变换,但需注意分隔符要使用数组中不存在的字符 对于多维数组可以用序列化函数处理 s...

mysql中怎么存储数组
如果要将数组的内容存储的mysql中,如 arr[n][m]二维数组,你创建一个table arr, 列是 A B,循环数组的每个元素,然后存储到对应的表中的A B列。当然怎么存储到数据库中看你自己的需要,可以存到一个字段中,用分隔符分开,倒是取出来的时候直接字符串split得到数组。

在mysql中没有数组字段类型,究竟怎么才能存储数组呢
你可以把它存到nvarchar中。比如一个数组[1,2,3,4,5]你存到数据库中就是1,2,3,4,5 你读取的时候在把它放到数组中不就可以了。

MySQL实现一列多值存储方法mysql一列多值
从MySQL 5.7版本开始,提供了对JSON格式的支持,可以将多个值以数组的形式存储在JSON列中,例如在user表中存储用户关注的所有标签。CREATE TABLE `user` (`id` int(11) NOT NULL AUTO_INCREMENT,`name` varchar(50) DEFAULT NULL,`tags` json DEFAULT NULL,PRIMARY KEY (`id`)) ENGINE=InnoDB ...

MySQL中存储16进制数据的方法mysql存16进制
在MySQL中,存储16进制字符串是非常容易的,如果你正在处理byte数组,你可以直接使用BINARY或VARBINARY来存储,只要你能确保转换成byte array,你就可以把它们存储在VARBINARY类型的字段里。下面的代码样例示范了怎么向VARBINARY类型的字段里存储一个byte array.\/\/ create a connection to MySQL conn = mysqli...

MySQL如何在一个字段中包含多个值mysql一个字段包含
使用 JSON 格式存储多个值 在 MySQL 5.7 及以上版本中,我们可以使用 JSON 类型来存储和查询复杂的数据。假设我们有一个名为 “articles” 的表,它包含了一篇文章的标识、标题和标签。我们可以将标签以 JSON 数组的形式存储在一个字段中。表结构如下:CREATE TABLE articles (id int(11...

怎样从mysql数据库中读取数据,并保存到数组?
mysql_query($sql,$local_conn);function get_data($conn,$name){ sql = "select * from t_demo where time like'".$name."'";resultRows = @mysql_query($sql,$conn);while($trow = @mysql_fetch_array($resultRows)){ result[] = $trow;} mysql_free_result($resultRows);retur...

C++ mysql 如何将读取出来的数据保存在数组中
row = mysql_fetch_row(result)会取一样的数据,mysql里面每成功调用一次这个函数mysql_fetch_row就会取一行,类似 vector<struct A> v_a;···赋值v_a···全局定义 int x = 0;function: mysql_fetch_row while (x < v_a.size())row = v_a[x++];mysql_fetch_lengths是得到一个row里...

相似回答