热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

用户自定义数据表中的字段

有一个需求,比如客户上传以前的excel表格或者csv文件,导入用户表,是用户信息,包括以下列:昵称,城市,生日,订单号,手机号等,但在我们的系统中,现有的用户表的字段只有昵称,城市等,没有生日,订单号,...
有一个需求,比如客户上传以前的excel表格或者csv文件,导入用户表,是用户信息,包括以下列:昵称,城市,生日,订单号,手机号等,

但在我们的系统中,现有的用户表的字段只有昵称,城市等,没有生日,订单号,手机号等字段。

能否让客户上传文件时,读取表格文件并新建一张表,储存本来用户表中没有的字段信息?

或是把本来没有的字段信息串行化后存入原用户表中的一个特定字段?在前台呈现时,格式化这个特定字段并显示?

哪种可行性更高呢,或是有其他办法?

回复内容:

有一个需求,比如客户上传以前的excel表格或者csv文件,导入用户表,是用户信息,包括以下列:昵称,城市,生日,订单号,手机号等,

但在我们的系统中,现有的用户表的字段只有昵称,城市等,没有生日,订单号,手机号等字段。

能否让客户上传文件时,读取表格文件并新建一张表,储存本来用户表中没有的字段信息?

或是把本来没有的字段信息串行化后存入原用户表中的一个特定字段?在前台呈现时,格式化这个特定字段并显示?

哪种可行性更高呢,或是有其他办法?

如果自定义的字段没有排序,检索方面的需求,还是建议用大字段吧,把非标准字段的数据全部以JSON或数组序列化的格式存到一个大字段中,需要展示的时候再做格式化输出就好了。

如果有排序或检索需求,则可能需要结合一些开源的索引软件比如Apache Lucene来实现了,看具体需求吧。


还有另外一种方式,代码逻辑上可能稍微复杂一点,存储效率也会很低,其实不大建议,但是如果你不是海量数据的话,问题也不大。方法就是建立一张字段足够多的表(user_data),字段命名都采用通用命名方式比如“column1,column2“等,然后专门建立一个表做用户的数据字段对应(user_data_columns),格式如下:

| uid | name | field |
| 101 | 生日 | column1 |
| 101 | 手机号 | column5 |

需要使用的时候,先到user_data_columns表中把相应的字段名和表的字段读取出来,然后到user_data表中去取相应列的数据。

推荐阅读
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文介绍了在Win10上安装WinPythonHadoop的详细步骤,包括安装Python环境、安装JDK8、安装pyspark、安装Hadoop和Spark、设置环境变量、下载winutils.exe等。同时提醒注意Hadoop版本与pyspark版本的一致性,并建议重启电脑以确保安装成功。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • 本文介绍了关于apache、phpmyadmin、mysql、php、emacs、path等知识点,以及如何搭建php环境。文章提供了详细的安装步骤和所需软件列表,希望能帮助读者解决与LAMP相关的技术问题。 ... [详细]
  • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
    本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
  • 标题: ... [详细]
  • 本文介绍了在Windows环境下如何配置php+apache环境,包括下载php7和apache2.4、安装vc2015运行时环境、启动php7和apache2.4等步骤。希望对需要搭建php7环境的读者有一定的参考价值。摘要长度为169字。 ... [详细]
  • 本文介绍了一些Java开发项目管理工具及其配置教程,包括团队协同工具worktil,版本管理工具GitLab,自动化构建工具Jenkins,项目管理工具Maven和Maven私服Nexus,以及Mybatis的安装和代码自动生成工具。提供了相关链接供读者参考。 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了StartingzookeeperFAILEDTOSTART相关的知识,希望对你有一定的参考价值。下载路径:https://ar ... [详细]
  • 本文介绍了在Linux下安装和配置Kafka的方法,包括安装JDK、下载和解压Kafka、配置Kafka的参数,以及配置Kafka的日志目录、服务器IP和日志存放路径等。同时还提供了单机配置部署的方法和zookeeper地址和端口的配置。通过实操成功的案例,帮助读者快速完成Kafka的安装和配置。 ... [详细]
author-avatar
U友50140932
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有