V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
DreamCMS
V2EX  ›  问与答

表单生成器,如金数据,是如何对字段数据进行存储的? 想知道如何用 MySQL 设计结构

  •  
  •   DreamCMS · 2022-04-11 14:45:22 +08:00 · 835 次点击
    这是一个创建于 959 天前的主题,其中的信息可能已经有所发展或是发生改变。
    10 条回复    2022-04-13 01:35:56 +08:00
    DreamCMS
        1
    DreamCMS  
    OP
       2022-04-11 14:47:12 +08:00 via Android
    想在后台做个表单生成器,但存储感觉有点难,请大神讲解一二
    murmur
        2
    murmur  
       2022-04-11 14:52:25 +08:00
    有什么难的呢,你可以说一下,除了搜索部分比较纠结,存储很简单的,直接用代码动态建表,不要管性能,也别管浪费,直接 select * 全弄出来,然后跟着前端 json 一套,就出来了,只要不是涉及计算的字段全给他 varchar 拉爆

    子表也类似处理,这样就是子表不支持搜索,能搜性能也太差了
    murmur
        3
    murmur  
       2022-04-11 14:54:46 +08:00
    字段的 id 可以自动生成,直接 field1 ,input2 ,text3 ,datetime4 这样,或者随机,拼音自动转都行
    DreamCMS
        4
    DreamCMS  
    OP
       2022-04-11 14:57:07 +08:00 via Android
    @murmur 这样确实可以,存储是没多大问题,最主要的多建表 一个表单一个表太浪费了,最好可以设计三表关联起来就能存储,搜索起来也非常方便,我想到的是只能横向 kv 存储数据,但这样表单改动及搜索很不方便
    murmur
        5
    murmur  
       2022-04-11 14:59:53 +08:00
    @DreamCMS 一个表单就是一个业务,怎么浪费了,是按业务计算表的个数,传统 sql 设计 1 对多不就是开子表么

    这样设计做报表是爽的,他除了字段难看点跟传统表设计没太大区别
    DreamCMS
        6
    DreamCMS  
    OP
       2022-04-11 15:03:32 +08:00 via Android
    @murmur 业务量不大这样设计确认也没问题,确认用起来也挺爽,但生成表越来越多的时候,类似金数据,我觉得应该不会这样设计吧
    murmur
        7
    murmur  
       2022-04-11 15:07:05 +08:00   ❤️ 1
    @DreamCMS 低代码、拖拽开发太多了,人家本身就是面向中小企业的,表多不是问题,你用列数据库行增长不也得考虑,企业审批就是业务固定字段巨多,别人一行存 30 个字段,你就得拆出 30 行了,用 kv 的话,行数据库还能保留个 date 类型,你用 kv ,真的全 string 啊
    DreamCMS
        8
    DreamCMS  
    OP
       2022-04-11 15:11:12 +08:00 via Android
    @murmur 确实理是这个理,还是没发现到最优的解。
    devswork
        9
    devswork  
       2022-04-11 15:26:56 +08:00
    建议你看下 form-create 。存储字段的话,就是有组件表( id,component_type,label,options ),表单表( id,title ),表单结构表(id,form_id,component_id),业务数据表(id,form_id,component_data_json)
    DreamCMS
        10
    DreamCMS  
    OP
       2022-04-13 01:35:56 +08:00 via Android
    @devswork json 存储搜索不方便
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5624 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 34ms · UTC 08:41 · PVG 16:41 · LAX 00:41 · JFK 03:41
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.