0

0

Firebase 字段名自动添加下划线前缀的解决方案

聖光之護

聖光之護

发布时间:2026-01-21 16:55:03

|

866人浏览过

|

来源于php中文网

原创

Firebase 字段名自动添加下划线前缀的解决方案

firebase sdk 基于 javabean 规范解析 getter/setter 方法名,将 `get_location_name()` 误判为 `_location_name` 属性的访问器,导致写入 firestore 或 realtime database 时字段名自动带 `_` 前缀;正确做法是遵循驼峰命名(如 `getlocationname()`)或显式使用 `@propertyname` 注解指定字段名。

Firebase 在序列化 Java 对象(如 PoIs 类)到数据库时,并不直接读取私有字段名,而是依赖 JavaBean 标准命名约定:它通过反射扫描 public getter 方法(如 getXxx()),并根据方法名推断对应的数据字段名。关键规则如下:

  • 方法 getXxx() → 推断字段名为 xxx(首字母小写,去除 get 前缀)
  • 方法 get_xxx() → 下划线被视为单词分隔符,推断字段名为 _xxx(即保留开头下划线)
  • 同理,is_xxx()、set_xxx(...) 等也会被识别为 _xxx 属性

在你的代码中:

public Integer get_location_id() { ... }
public String get_location_name() { ... }

Firebase 将其解析为属性 _location_id 和 _location_name,因此最终写入数据库的键名就变成了 _location_id、 _location_name、_location_address —— 这正是你观察到的现象。

推荐解决方案(二选一)

Sesame AI
Sesame AI

一款开创性的语音AI伴侣,具备先进的自然对话能力和独特个性。

下载

方案 1:改用标准驼峰命名(最简洁、无侵入)
重命名所有 getter/setter 方法,严格遵循 JavaBean 规范(无下划线,首字母大写):

public class PoIs {
    private Integer locationId;        // 推荐:字段也用驼峰(非强制但最佳实践)
    private String locationName;
    private String locationAddress;

    // 构造函数保持不变(注意:原代码中构造函数有笔误:this.category_id = category_id; —— 应删除或修正)

    public Integer getLocationId() {
        return locationId;
    }

    public void setLocationId(Integer locationId) {
        this.locationId = locationId;
    }

    public String getLocationName() {
        return locationName;
    }

    public void setLocationName(String locationName) {
        this.locationName = locationName;
    }

    public String getLocationAddress() {
        return locationAddress;
    }

    public void setLocationAddress(String locationAddress) {
        this.locationAddress = locationAddress;
    }
}

✅ 写入后字段名将自动变为 locationId、locationName、locationAddress(纯驼峰)。若你希望保持 location_id 这类蛇形命名,请使用方案 2。

方案 2:使用 @PropertyName 显式声明(精准控制,兼容蛇形)
在 getter/setter 或字段上添加注解(需引入 com.google.firebase.firestore.PropertyName):

import com.google.firebase.firestore.PropertyName;

public class PoIs {
    @PropertyName("location_id")
    private Integer location_id;

    @PropertyName("location_name")
    private String location_name;

    @PropertyName("location_address")
    private String location_address;

    // 构造函数(修正原代码中的 category_id 错误)
    public PoIs(Integer location_id, String location_name, String location_address) {
        this.location_id = location_id;
        this.location_name = location_name;
        this.location_address = location_address;
    }

    // getter/setter 可保留原名,但建议同步加注解以确保双向映射一致
    @PropertyName("location_id")
    public Integer get_location_id() { return location_id; }

    @PropertyName("location_id")
    public void set_location_id(Integer location_id) { this.location_id = location_id; }

    // 其他字段同理...
}

⚠️ 注意事项:

  • @PropertyName 注解需同时作用于 getter 和 setter(或字段),否则反序列化(读取)可能失败;
  • 若使用 Firestore,确保类已添加无参构造函数(你已有 public PoIs() {},符合要求);
  • Realtime Database 同样支持 @PropertyName,但仅限 Android SDK v16.0.1+;
  • 原代码构造函数中存在未定义变量 category_id,请务必检查并移除该行,避免编译错误

? 验证方式:
在 setValue(p) 后,打开 Firebase Console → Realtime Database 或 Firestore 控制台,查看实际写入的 key 名是否已符合预期(如 location_name 而非 _location_name)。

总结:Firebase 的“自动加下划线”本质是 JavaBean 命名推导逻辑的副作用,而非 Bug。统一采用驼峰命名(getLocationName)是最符合生态规范、零配置、长期可维护的选择;而 @PropertyName 则为你保留蛇形命名提供了灵活且可靠的兜底方案。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
console接口是干嘛的
console接口是干嘛的

console接口是一种用于在计算机命令行或浏览器开发工具中输出信息的工具,提供了一种简单的方式来记录和查看应用程序的输出结果和调试信息。本专题为大家提供console接口相关的各种文章、以及下载和课程。

420

2023.08.08

console.log是什么
console.log是什么

console.log 是 javascript 函数,用于在浏览器控制台中输出信息,便于调试和故障排除。想了解更多console.log的相关内容,可以阅读本专题下面的文章。

541

2024.05.29

discuz database error怎么解决
discuz database error怎么解决

discuz database error的解决办法有:1、检查数据库配置;2、确保数据库服务器正在运行;3、检查数据库表状态;4、备份数据;5、清理缓存;6、重新安装Discuz;7、检查服务器资源;8、联系Discuz官方支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

227

2023.11.20

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

385

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2111

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

357

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

259

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

329

2023.10.09

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.3万人学习

C# 教程
C# 教程

共94课时 | 11.1万人学习

Java 教程
Java 教程

共578课时 | 80.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号