mysql怎么存数组

mysql存储数组的方法:先将传入的数组字符串截取成多个字符;然后传入到临时表中;最后使用游标或者直接关联表过滤数据,即可达到mysql存数组的目的了。

mysql怎么存数组

mysql存储过程功能弱问题一直是大家关注的问题,今天讲一下Mysql存储过程无法传递数组类型参数的解决方案。

推荐课程:MySQL教程。

在很多的情况下,在编写存储过程中往往会用到数组,但是mysql中存储过程传入参数并没有可以直接传入数组的方法。在这种情况下我们只能退而求之或者说换个方式以字符串形式传入参数,然后在过程体中把字符串再转成数组?

不过很遗憾告诉你,mysql并没有直接提供把字符串转数组的函数。现在你是不是有种想打人的感觉呢?不过,不用慌,此路不通,咱走另外的路,总有解决方法的。我们可以把传入的字符串截取成多个字符然后传入到临时表中,然后使用游标或者直接关联表过滤数据。这样就可以达到后面预期的效果了。

下面我们以一个例子来具体实践一下:

1、创建数据库,用于实例:

CREATE DATABASE huafeng_db;use huafeng_db;DROP TABLE IF EXISTS `huafeng_db`.`t_scores`;DROP TABLE IF EXISTS `huafeng_db`.`t_students`;DROP TABLE IF EXISTS `huafeng_db`.`t_class`;CREATE TABLE `huafeng_db`.`t_class` (  `class_id` int(11) NOT NULL,  `class_name` varchar(32) CHARACTER SET utf8 DEFAULT NULL,  PRIMARY KEY (`class_id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;INSERT INTO `huafeng_db`.`t_class` (`class_id`, `class_name`) VALUES ('1', '一年级');INSERT INTO `huafeng_db`.`t_class` (`class_id`, `class_name`) VALUES ('2', '二年级');INSERT INTO `huafeng_db`.`t_class` (`class_id`, `class_name`) VALUES ('3', '三年级');INSERT INTO `huafeng_db`.`t_class` (`class_id`, `class_name`) VALUES ('4', '四年级');INSERT INTO `huafeng_db`.`t_class` (`class_id`, `class_name`) VALUES ('5', '五年级');INSERT INTO `huafeng_db`.`t_class` (`class_id`, `class_name`) VALUES ('6', '六年级');CREATE TABLE `t_students` (  `student_id` int(11) NOT NULL AUTO_INCREMENT,  `student_name` varchar(32) NOT NULL,  `sex` int(1) DEFAULT NULL,  `seq_no` int(11) DEFAULT NULL,  `class_id` int(11) NOT NULL,  PRIMARY KEY (`student_id`),  KEY `class_id` (`class_id`),  CONSTRAINT `t_students_ibfk_1` FOREIGN KEY (`class_id`) REFERENCES `t_class` (`class_id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;INSERT INTO `huafeng_db`.`t_students`(`student_name`,`sex`,`seq_no`,`class_id`) VALUES('小红',0,1,'1');INSERT INTO `huafeng_db`.`t_students`(`student_name`,`sex`,`seq_no`,`class_id`) VALUES('小青',0,2,'2');INSERT INTO `huafeng_db`.`t_students`(`student_name`,`sex`,`seq_no`,`class_id`) VALUES('小明',1,3,'3');INSERT INTO `huafeng_db`.`t_students`(`student_name`,`sex`,`seq_no`,`class_id`) VALUES('小兰',0,4,'4');INSERT INTO `huafeng_db`.`t_students`(`student_name`,`sex`,`seq_no`,`class_id`) VALUES('小米',1,5,'5');INSERT INTO `huafeng_db`.`t_students`(`student_name`,`sex`,`seq_no`,`class_id`) VALUES('小白',1,6,'6');CREATE TABLE `huafeng_db`.`t_scores` (  `score_id` int(11) NOT NULL AUTO_INCREMENT,  `course_name` varchar(64) DEFAULT NULL,  `score` double(3,2) DEFAULT NULL,  `student_id` int(11) DEFAULT NULL,  PRIMARY KEY (`score_id`),  KEY `student_id` (`student_id`),  CONSTRAINT `t_scores_ibfk_1` FOREIGN KEY (`student_id`) REFERENCES `t_students` (`student_id`)) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;INSERT INTO `t_scores` (`score_id`, `course_name`, `score`, `student_id`) VALUES ('1', '语文', '90', '1');INSERT INTO `t_scores` (`score_id`, `course_name`, `score`, `student_id`) VALUES ('2', '数学', '97', '1');INSERT INTO `t_scores` (`score_id`, `course_name`, `score`, `student_id`) VALUES ('3', '英语', '95', '1');INSERT INTO `t_scores` (`score_id`, `course_name`, `score`, `student_id`) VALUES ('4', '语文', '92', '2');INSERT INTO `t_scores` (`score_id`, `course_name`, `score`, `student_id`) VALUES ('5', '数学', '100', '2');INSERT INTO `t_scores` (`score_id`, `course_name`, `score`, `student_id`) VALUES ('6', '英语', '98', '2');

2、需求: 根据学生编号批量删除学生信息

DROP PROCEDURE IF EXISTS `p_del_studentInfo_bySeqNo`;DELIMITER $$CREATE PROCEDURE p_del_studentInfo_bySeqNo(IN arrayStr VARCHAR(1000),IN sSplit VARCHAR(10))SQL SECURITY INVOKER  #允许其他用户运行BEGIN    DECLARE e_code INT DEFAULT 0;#初始化报错码为0    DECLARE result VARCHAR(256) CHARACTER set utf8;#初始化返回结果,解决中文乱码问题    DECLARE arrLength INT DEFAULT 0;/*定义数组长度*/    DECLARE arrString VARCHAR(1000);/*定义初始数组字符*/    DECLARE sStr VARCHAR(1000);/*定义初始字符*/    DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET e_code=1;#遇到错误后继续执行;(需要返回执行结果时用这个)    START TRANSACTION;#启动事务    SET arrLength = LENGTH(arrayStr) - LENGTH(REPLACE(arrayStr,sSplit,''));/*获得数组长度*/    SET arrString = arrayStr;    DROP TEMPORARY TABLE IF EXISTS list_tmp;    create temporary table list_tmp(id VARCHAR(32));/*定义临时表*/    WHILE arrLength > 0 DO      set sStr = substr(arrString,1,instr(arrString,sSplit)-1);            -- 得到分隔符前面的字符串        set arrString = substr(arrString,length(sStr)+length(sSplit)+1);     -- 得到分隔符后面的字符串        set arrLength = arrLength -1;      set @str = trim(sStr);      insert into list_tmp(id) values(@str);     END WHILE;     IF row_count()=0 THEN          SET e_code = 1;          SET result = '请输入正确的参数';        END IF;    set @count = (SELECT count(1) FROM t_students s,list_tmp t WHERE s.seq_no = t.id);    IF @count >0 THEN        DELETE FROM t_scores WHERE student_id in (SELECT s.student_id FROM t_students s,list_tmp t WHERE s.seq_no = t.id);        DELETE FROM t_students WHERE student_id in (SELECT t.id FROM list_tmp t);    ELSE         SET e_code = 1;         SET result = '该学生不存在!';    END IF;    IF e_code=1 THEN        ROLLBACK;  #回滚    ELSE        COMMIT;        SET result = '该学生已被删除成功';    END IF;    SELECT result;    DROP TEMPORARY TABLE IF EXISTS list_tmp;END $$DELIMITER ;

说明:在创建存储过程的时候,传入了两个参数,第一个代表要传入的数组字符串形式,第二个参数为以什么分割字符串。

阿里云-虚拟数字人 阿里云-虚拟数字人

阿里云-虚拟数字人是什么? …

阿里云-虚拟数字人 2 查看详情 阿里云-虚拟数字人

声明初始化变量

DECLARE arrLength INT DEFAULT 0;/*定义数组长度*/DECLARE arrString VARCHAR(1000);/*定义初始数组字符*/DECLARE sStr VARCHAR(1000);/*定义初始字符*/

获取传入参数数组长度

SET arrLength = LENGTH(arrayStr) - LENGTH(REPLACE(arrayStr,sSplit,''));/*获得数组长度*/SET arrString = arrayStr;/*赋值*/

创建临时表

DROP TEMPORARY TABLE IF EXISTS list_tmp;create temporary table list_tmp(id VARCHAR(32));/*定义临时表*/

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

WHILE arrLength > 0 DO  set sStr = substr(arrString,1,instr(arrString,sSplit)-1);            -- 得到分隔符前面的字符串    set arrString = substr(arrString,length(sStr)+length(sSplit)+1);     -- 得到分隔符后面的字符串    set arrLength = arrLength -1;  set @str = trim(sStr);  insert into list_tmp(id) values(@str);END WHILE;

注: 存储过程结束时一定要记得删除临时表

不是非常复杂的业务没有必要用到存储过程的,本文不是引导大家一定要使用存储过程,只是让大家知道有这么一回事!

以上就是mysql怎么存数组的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/369377.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 07:01:27
下一篇 2025年11月6日 07:02:41

相关推荐

  • C++中如何使用类型擦除_运行时多态实现

    c++++中类型擦除是一种在运行时统一处理不同类型的技术,通过隐藏具体类型信息实现手动多态。1. 定义抽象基类作为通用接口;2. 创建模板类实现该接口并转发操作;3. 使用包装类包含模板类实例指针,提供相同方法并转发调用。示例中drawable为抽象基类,circle和square为具体类型,dra…

    2025年12月18日 好文分享
    000
  • 静态检查融合:SonarQube + Clang实现C++自动审计

    静态检查融合是通过结合sonarqube规则引擎与c++lang分析能力提升c++代码审计效果的方法。1. 安装sonarqube服务器并配置数据库;2. 安装sonarscanner并配置环境变量;3. 安装clang及相关开发工具;4. 安装并配置sonarqube cfamily插件;5. 创…

    2025年12月18日 好文分享
    000
  • 什么是C++中的数据库索引优化?

    c++++中的数据库索引优化可以通过以下步骤实现:1)选择正确的索引类型,如b-tree适合范围查询;2)维护索引,平衡读写性能;3)使用复合索引提升多列查询性能;4)通过查询优化和性能监控调整索引策略。 C++中的数据库索引优化?这是一个有趣且复杂的主题,让我们深入探讨一下。 C++虽然主要用于系…

    2025年12月18日
    000
  • C++中的ORM框架是什么?

    c++++中的orm框架是一种工具,通过对象映射到数据库表,简化数据库操作。1)orm框架通过对象操作数据库,提高开发效率和代码可维护性。2)常见框架如cppdb、odb和soci,各有特点。3)使用时需注意映射关系、查询优化和性能考虑。 C++中的ORM(对象关系映射)框架是什么?简单来说,ORM…

    2025年12月18日
    000
  • C语言网络编程中数据库连接的优化措施问答

    优化措施:使用连接池预创建数据库连接,避免连接/断开开销。优化查询语句,只查询必要字段,避免通配符或子查询。使用批处理将多个操作组合成一个请求,减少网络开销。尽量使用乐观的锁定机制,减少锁定粒度。考虑使用无服务器数据库,由供应商管理数据库,减少开销。 C语言网络编程中数据库连接的优化措施 在C语言网…

    2025年12月18日
    000
  • C++ 函数库在哪些场景下使用?

    c++++ 函数库预先定义了代码模块,可用于处理常见任务,广泛应用于:输入/输出操作字符串操作数学运算此外,还有特定领域的场景,如:图形处理网络编程数据库连接示例:使用 matplotlibcpp 函数库绘制折线图,实现了便捷的图形化展示。 C++ 函数库的应用场景 简介C++ 函数库提供了预定义的…

    2025年12月18日
    000
  • C++框架内置功能在跨平台开发中的作用

    在跨平台开发中,c++++ 框架的内置功能发挥着至关重要的作用,包括:跨平台兼容性:在多平台上稳定运行,简化移植。图形用户界面 (gui) 支持:提供跨平台的 gui 库,无需编写平台特定代码。数据库集成:支持多种数据库系统,实现数据访问和操作的跨平台性。网络通信:提供网络通信机制,用于分布式应用程…

    2025年12月18日
    000
  • C++框架中的数据处理和存储机制

    本文介绍了 c++++ 框架中处理和存储数据的关键技术:数据处理:stl 容器(vector、map、set)boost 库(额外容器和算法)eigen 库(优化矩阵和向量)数据存储:关系数据库管理系统(rdbms)(mysql、postgresql、sqlite)文档存储(mongodb、redi…

    2025年12月18日
    000
  • C++框架在行业中的实际案例

    c++++ 框架广泛应用于行业中,提供高效且可维护的代码解决方案。这些框架用于开发跨平台 gui(qt)、科学计算(armadillo、eigen)、线性代数运算(eigen)、计算机视觉(opencv)和高性能网络应用程序(ace)。例如,spotify 使用 boost(线程管理和网络操作)、a…

    2025年12月18日
    000
  • C++框架在后端开发方面的优缺点?

    c++++框架在后端开发中的优缺点:优点:高性能低内存使用跨平台原生数据库支持丰富的库生态缺点:学习曲线陡峭内存管理复杂缺乏动态关注编译时间长缺乏垃圾回收 C++ 框架在后端开发中的优缺点 优点: 高性能: C++ 是一种编译语言,可生成高效机器码,从而实现优异的性能。低内存使用: C++ 提供直接…

    2025年12月18日
    000
  • 在线资源和教程如何帮助降低 C++ 框架的学习难度?

    通过在线资源和教程,你可以降低 c++++ 框架的学习难度:利用官方文档和外部教程学习框架的基本概念和最佳实践。加入 stack overflow 和讨论论坛等社区,寻求具体问题的帮助和支持。通过构建 restful api、数据库应用程序和网络服务器等实战案例,获得实践经验。 通过在线资源和教程降…

    2025年12月18日
    000
  • 不同C++框架在特定领域的专业化和适用性对比

    不同的 c++++ 框架针对特定领域进行了专业化,以优化性能和易用性。对于 web 开发,boost.asio 以其轻量级和跨平台能力脱颖而出。用于 gui 开发的 qt 提供了丰富的功能和跨平台支持,而 qtsql 简化了数据库访问。poco 在网络编程中很突出,openmp 在并行计算中表现出色…

    2025年12月18日
    000
  • C++ 框架如何优化大型项目中资源管理和性能

    c++++ 框架通过资源管理和性能优化,提升了大型项目的效率:资源管理优化:通过资源池和智能指针管理资源,优化分配和释放操作。性能优化:利用并发编程和内存管理库,实现跨平台并发编程和提升内存管理性能。 C++ 框架:优化大型项目中资源管理和性能 大型 C++ 项目经常面临资源管理和性能问题。为了解决…

    2025年12月18日
    000
  • C++ 框架性能基准:与其他语言和平台的比较

    基准测试结果表明,c++++ 框架在 http 请求处理和数据库查询方面表现优异,boost.asio 适用于高并发连接,cpp-httplib 和 libuv 具有较低延迟。开发人员应根据不同场景选择最合适的框架。 C++ 框架性能基准:与其他语言和平台的比较 引言 性能是任何软件应用程序的关键方…

    2025年12月18日
    000
  • C++ 框架在网络安全领域的应用:提升网络抵御能力与威胁防御

    c++++ 框架在网络安全中广泛应用,提升网络抵御和威胁防御能力:高性能:c++ 速度和效率使其适合构建实时网络安全应用。内存管理:c++ 提供对内存的细粒度控制,确保安全和资源高效。跨平台支持:c++ 可在多种平台编译,便于构建跨平台安全解决方案。应用包括:入侵检测系统、防火墙、恶意软件分析和取证…

    2025年12月18日
    000
  • C++ 框架的学习指南:快速上手

    对于使用 c++++ 框架,本指南提供了分步指导,包括:了解基础知识:熟悉框架概念和 oop 原则。探索框架功能:容器、算法、线程管理、网络操作和数据库集成。实战案例:创建一个文件管理程序,演示框架的使用。扩展知识:探索其他框架、参与社区和练习项目。 C++ 框架的学习指南:快速上手 随着 C++ …

    2025年12月18日
    000
  • C++ 框架设计中实现代码重用的技术

    在 c++++ 框架设计中,实现代码重用的技术包括:模板方法模式:定义算法大纲,由子类定义具体步骤。策略模式:分离算法实现和使用对象,提高灵活性。工厂方法模式:创建对象的方法由子类实现,允许创建不同类型对象。抽象工厂模式:创建相关对象家族的方法,无需指定具体类,促进松耦合。单例模式:确保类只有一个实…

    2025年12月18日
    000
  • c++是什么语言

    C++ 是一种通用、面向对象、跨平台的编程语言,由比雅尼·斯特劳斯特鲁普开发于 1985 年。它具有面向对象、跨平台、高效、可扩展和低级控制等特点。C++ 被广泛应用于开发操作系统、数据库管理系统、游戏引擎、网络应用程序和大型企业软件。其优点包括效率高、可移植性好、面向对象和强大;缺点则包括复杂性、…

    2025年12月18日
    000
  • C++ 开源库指南:探索丰富的库资源,拓展编程能力

    c++++开源库为开发者提供了丰富的工具,包括:boost库:提供算法和数据结构,可用于字符串操作和图表处理。eigen:线性代数库。opencv:计算机视觉和机器学习库。qt:跨平台gui框架。mysql connector:与mysql数据库交互的库。wxwidgets:图形用户界面库。选择最合…

    2025年12月18日
    000
  • c++怎么连接数据库

    在C++中,可以使用ODBC或第三方库连接到数据库。ODBC步骤:初始化环境,连接到DBMS。其他库:MySQL Connector/C++、PostgreSQL libpq++、SQLite3,根据数据库类型和需求选择库。 C++连接数据库 在C++中连接数据库,可以使用标准的C++数据库连接库(…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信