首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

数据表多字段存储值与单字段存储json值的区别

使用场景 电商系统中商品参数数据,假设包括以下几项 品牌 产地 尺寸 生产日期 保质期 重量 在设计数据表结构的时候,可以选择2种方式 第1种是分别创建不同的字段存储对应的参数值 第2种是建立一个字段用于存储参数的...json值 具体设计的区别 商品表(第1种) ID 标题 参数-品牌 参数-产地 参数-等等 1 某某商品 某某品牌 某某产地 某某参数 2 某某商品 某某品牌 某某产地 某某参数...商品表(第2种) ID 标题 参数内容 1 某某商品 {json字符串} 2 某某商品 {json字符串} 其中json字符串的值可以是以下内容 {"品牌":"测试内容","产地"...多字段存储数据的缺点 1、灵活性:如果数据结构经常变化,可能需要频繁地修改数据库表结构,可能会涉及复杂的迁移过程。 2、空间效率:对于包含大量空值或重复值的字段,可能不如JSON存储方式节省空间。...单字段存储JSON值的优点 1、灵活性:可以轻松地存储和查询非结构化或半结构化数据,无需事先定义所有可能的字段。当数据结构发生变化时,不需要修改数据库表结构。

17131
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    PostgreSQL 库,表,字段,值大小写的问题

    需要测试的内容如下 1 数据库大小写 2 表名大小写 3 字段大小写 4 字段值得大小写 一些相关的大小写的函数以及数据的转换函数 let's go 1 数据库名的大小写 首先会建立三个数据库名字为...(你可以试试,结果是一样的,postgresql 在一个数据库中只能运行小写表名的存在) 当然如果你非要存储不同大小写的表名,PostgreSQL 也不是不可以,那就是需要加“” 双引号 最后我们来尝试一下字段名和字段值的问题...我们还是在test 数据库里面建立表,并且会在这个表里面建立三个字段 分表是 name Name NAME 并且在每个字段里面的值,也是和字段名的撰写方式一样。...在做到下面的时候,大家应该看到这个错误, 在一个表里面,的字段名也默认统一为小写。当然如果你不喜欢,还是可以建立你想建立的字段名大小写,还是那样加“双引号”。...既然如此,我们只能继续在字段的值的上面找问题了 我们在一个表中的name 字段,插入不同的值, TIM, tim, Tim 三个值,我们看看结果如何,并且在查询中是不是会有什么问题?

    4.8K20

    SQL函数 LENGTH

    ,其中基础数据类型可以表示为任何字符类型(例如 CHAR 或 VARCHAR)。...LENGTH 和其他长度函数($LENGTH、CHARACTER_LENGTH、CHAR_LENGTH 和 DATALENGTH)都执行以下操作: LENGTH 返回字段的逻辑(内部数据存储)值的长度...所有 SQL 函数始终使用字段的内部存储值。 LENGTH 返回数字的规范形式的长度。规范形式的数字不包括前导零和尾随零、前导符号(单个减号除外)和尾随小数分隔符。...如果传递一个 NULL 值,则 $LENGTH 返回 0,如果传递一个空字符串,则返回 0。 LENGTH 不支持数据流字段。为字符串表达式指定流字段会导致 SQLCODE -37。...(LTRIM(' INTERSYSTEMS ')) AS CharCount 15 12 以下示例返回 Sample.Person 表中每个 Name 值中的字符数: SELECT

    2K30

    MySQL的CHAR、VARCHAR、TEXT等字符串字段在等值比较(=)时,会忽略掉尾部的空格,导致有空格也能匹配上的坑

    ('lingyejun '); #一个空格 INSERT INTO user_info(user_name) values('lingyejun '); #四个空格 如上有个user_info表,...二、原因 查询MySQL的官方文档(https://dev.mysql.com/doc/refman/5.7/en/char.html),原来MySQL的校对规则基于PAD SPACE,这就意味着CHAR...SELECT * FROM user_info WHERE user_name LIKE 'lingyejun '; #四个空格 3.2 binary binary不是函数,是类型转换运算符,它用来强制它后面的字符串为一个二进制字符串...SELECT * FROM user_info WHERE user_name = BINARY 'lingyejun '; #四个空格 注:这里的BINARY关键字要放在“=”的后边,以便有效利用该字段的索引...四、结论 MySQL的CHAR、VARCHAR、TEXT等字符串字段在等值比较("=")时,基于PAD SPACE校对规则,会忽略掉尾部的空格; 在存储时,不会自动截断尾部的空格,会按原值存储; 如果想要精确查询就不能用等值查询

    27410

    MySQL|update字段为相同的值是否会记录binlog

    一 前言 前几天一个开发同事咨询我,update 更新字段为相同的值是否会记录binlog,我回复说不会。 其实 严格的说这个答案是不准确的,说要区分场景。...是否记录 update 语句到binlog依赖于 binlog_format 的设置。具体情况 实践出真知。 二 测试 2.1 binlog_format 为 ROW 模式 ?...2.2 binlog_format 为 STATEMENT 模式 ? 解析binlog内容,完整的记录了update语句。 ? 2.2 binlog_format 为 MIXED 模式 ?...当 row_format 为mixed或者statement格式是,binlog 的大小发生改变,不管是否真的更新数据,MySQL都记录执行的sql 到binlog。...三 小结 基于row模式时,server层匹配到要更新的记录,发现新值和旧值一致,不做更新,就直接返回,也不记录binlog。

    6.5K20

    Mysql - 数据库面试题打卡第四天

    CHAR 和 VARCHAR 类型在存储和检索方面有所不同 CHAR 列长度固定为创建表时声明的长度,长度值范围是 1 到 255 当 CHAR值被存储时,它们被用空格填充到特定长度,检索 CHAR 值时需删除尾随空格...在 MyISAM Static 上的所有字段有固定宽度。动态 MyISAM Dynamic 表将具有像 TEXT,BLOB 等字段,以适应 不同长度的数据类型。...36、如果一个表有一列定义为 TIMESTAMP,将发生什么? 每当行被更改时,时间戳字段将获取当前时间戳。 列设置为 AUTO INCREMENT 时,如果在表中达到最大值,会发生什么情况?...LAST_INSERT_ID 将返回由 Auto_increment 分配的最后一个值,并且不需要指定表名称 37、你怎么看到为表格定义的所有索引?...索引是通过以下方式为表格定义的: SHOW INDEX FROM ; 38、LIKE 声明中的%和_是什么意思?

    1.2K30

    SQL谓词 %STARTSWITH(二)

    尾随空格的%STARTSWITH行为取决于数据类型和排序规则类型。 %STARTSWITH忽略定义为SQLUPPER的字符串子串的尾随空格。...%STARTSWITH不会忽略数字、日期或列表子字符串中的尾随空格。 在下面的示例中,%STARTSWITH将结果集限制为以“M”开头的名称。...通常这是一个有或没有重音标记的字符,例如在Czech2区域设置中,其中CHAR(65)和CHAR(193)都排序为“a”。 %STARTSWITH将这些字符识别为等效字符。...默认情况下,Contains操作符比较是区分大小写的,即使字段被定义为不区分大小写。 使用SQL Search进行上下文感知的等价比较。...'1U1"C"' ORDER BY Home_State 这个示例选择任何包含Home_State字段值的记录,该字段值匹配1U(一个大写字母)后跟1个“C”(一个字母“C”)的模式。

    1.2K10

    避免锁表:为Update语句中的Where条件添加索引字段

    深入分析后,问题的核心暴露出来:另一业务流程中对工单表执行更新(UPDATE)操作的SQL,其where子句中涉及的字段缺少必要的索引,导致其他业务在操作表中的数据时需要等待该更新完成。...问题描述 mysql 修改数据时,如果where条件后的字段未加索引或者未命中索引会导致锁表。这种锁表行为会阻塞其他事务对该表的访问,显著降低并发性能和系统响应速度。..._20240525223958.jpg 然后我们给表bus_pages的mark__id字段创建索引 然后在执行修改及新增接口,可以看到新增接口不会在等待修改接口执行完在去执行了 注意: 并不是创建了索引就不会锁表...; 总结 在编写Update语句时,务必注意Where条件中涉及的字段是否有索引支持。...避免全表锁的关键在于优化查询,利用索引提高查询效率,减少系统性能的影响。通过合理地设计索引,并确保Update语句中的Where条件包含索引字段,可以有效地提升数据库的性能和并发能力。

    50310

    SQL函数 %SQLUPPER

    maxlen - 可选 — 一个整数,指定整理后的值将被截断为 maxlen 的值。请注意, maxlen 包括附加的前导空格。...%SQLUPPER 将表达式转换为排序为(不区分大小写)大写字符串的格式。 %SQLUPPER 将所有字母字符转换为大写,从字符串中去除尾随空格(空格、制表符等),然后在字符串开头添加一个前导空格。...因为 %SQLUPPER 将空格附加到所有值,所以它将 NULL 值作为空格进行整理,字符串长度为 1。 %SQLUPPER 将任何仅包含空格(空格、制表符等)的值整理为 SQL 空字符串 ('')。...当 %SQLUPPER 将空格附加到空(零长度)字符串时,它会将空格加上空字符串的内部表示形式 $CHAR(0) 进行整理,从而导致字符串长度为 2。...以下是转换数据值大小写的其他函数: UPPER 和 UCASE:将字母转换为大写,对数字字符、标点字符、嵌入空格以及前导和尾随空格没有影响。不强制将数字解释为字符串。

    1.4K10

    SQL语言元素(一)

    空字符串(")与空字符串是不同的。 空字符串是一个已定义的值,一个不包含字符的字符串,一个长度为0的字符串。 一个零长度的字符串在内部由非显示字符$CHAR(0)表示。...长度不计算尾随空格; 所有其他长度函数都计算末尾的空格。 null 处理 NOT NULL数据约束要求字段必须接收一个数据值; 不允许指定NULL而不是值。 这个约束不阻止使用空字符串值。...NULL的长度 在SQL中,NULL的长度是没有定义的(它返回)。 然而,空字符串的长度被定义为长度为0。...$LENGTH函数返回这些值的InterSystems IRIS内部表示:NULL表示为长度为0的已定义值,SQL空字符串表示为长度为0的字符串。 该功能与ObjectScript兼容。...,而不是尾随空格。

    1.4K10

    MySQL面试题集锦,据说国内外知名互联网公司都在用!

    ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用。...以下是CHAR和VARCHAR的区别: CHAR和VARCHAR类型在存储和检索方面有所不同 CHAR列长度固定为创建表时声明的长度,长度值范围是1到255 当CHAR值被存储时,它们被用空格填充到特定长度...,检索CHAR值时需删除尾随空格。...在MyISAM Static上的所有字段有固定宽度。动态MyISAM表将具有像TEXT,BLOB等字段,以适应不同长度的数据类型。 MyISAM Static在受损情况下更容易恢复。...LAST_INSERT_ID将返回由Auto_increment分配的最后一个值,并且不需要指定表名称。 27、你怎么看到为表格定义的所有索引?

    2K00

    MySQL面试题集锦,据说国内外知名互联网公司都在用!

    ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用。...以下是CHAR和VARCHAR的区别: CHAR和VARCHAR类型在存储和检索方面有所不同 CHAR列长度固定为创建表时声明的长度,长度值范围是1到255 当CHAR值被存储时,它们被用空格填充到特定长度...,检索CHAR值时需删除尾随空格。...在MyISAM Static上的所有字段有固定宽度。动态MyISAM表将具有像TEXT,BLOB等字段,以适应不同长度的数据类型。 MyISAM Static在受损情况下更容易恢复。...LAST_INSERT_ID将返回由Auto_increment分配的最后一个值,并且不需要指定表名称。 27、你怎么看到为表格定义的所有索引?

    1.8K00
    领券