DOB与手机号校验及JDBC存储实现方法
2026-02-06 20:24:44
0浏览
收藏
“纵有疾风来,人生不言弃”,这句话送给正在学习文章的朋友们,也希望在阅读本文《Java注册表单DOB与手机号校验及JDBC存储实现》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新文章相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!

本文详解如何在Java JDBC应用中对用户出生日期(DOB)和手机号字段进行健壮性校验——DOB需介于1940-01-01至2000-01-01之间,手机号须严格为10位数字,并安全插入MySQL数据库。
在基于Java + JDBC构建的用户信息管理系统中,仅完成数据插入是远远不够的;业务有效性校验(如DOB合理性、手机号格式)是保障数据质量与系统健壮性的关键环节。本文将从零重构原始代码,提供一套生产就绪的校验方案,涵盖日期范围验证、10位纯数字手机号校验、资源安全管理及用户友好的错误反馈。
✅ 核心校验逻辑说明
1. DOB校验:使用 LocalDate 替代过时的 java.sql.Date
- java.sql.Date 包含隐式时区语义,而出生日期是纯粹的“日历日期”,应使用 java.time.LocalDate 进行逻辑判断。
- 定义合法区间:
LocalDate minDob = LocalDate.of(1940, 1, 1); LocalDate maxDob = LocalDate.of(2000, 1, 1);
- 输入验证流程:
String dateStr = sc.nextLine(); // 安全读取整行 Date sqlDate = Date.valueOf(dateStr); // 转为SQL兼容格式 LocalDate localDate = sqlDate.toLocalDate(); if (localDate.isBefore(minDob) || localDate.isAfter(maxDob)) { System.out.printf("❌ DOB must be between %s and %s%n", minDob, maxDob); continue; // 跳过本次插入 }
2. 手机号校验:用 long 类型 + 数值范围判断(适配 BIGINT 字段)
- 数据库字段为 phone BIGINT,Java端应使用 long(非 int 或 double),避免精度丢失或科学计数法干扰。
- 关键点:10位手机号数值范围为 1_000_000_000L 至 9_999_999_999L(即 10^9 到 10^10 - 1)。
- 验证示例:
long phoneNum = Long.parseLong(sc.nextLine().trim()); if (phoneNum < 1_000_000_000L || phoneNum > 9_999_999_999L) { System.out.println("❌ Phone number must be exactly 10 digits (no leading zeros allowed)."); continue; }
⚠️ 注意:若业务要求支持带前导零(如 0123456789),则必须将手机号存为 VARCHAR 并改用字符串长度+正则校验(^\d{10}$)。当前 BIGINT 设计天然不支持前导零,故数值校验是合理且高效的选择。
✅ 完整优化版代码(含最佳实践)
import java.sql.*;
import java.time.LocalDate;
import java.util.Scanner;
public class UserData {
public static void main(String[] args) throws SQLException {
final LocalDate MIN_DOB = LocalDate.of(1940, 1, 1);
final LocalDate MAX_DOB = LocalDate.of(2000, 1, 1);
Scanner sc = new Scanner(System.in);
String insertSql = """
INSERT INTO UserDetails (userid, name, DOB, address, phone, UserRole)
VALUES (?, ?, ?, ?, ?, ?)
""";
// 使用 try-with-resources 自动关闭连接与语句
try (Connection con = DriverManager.getConnection(
"jdbc:mysql://localhost:3306/mydatabase", "root", "root");
PreparedStatement pst = con.prepareStatement(insertSql)) {
int option;
do {
displayMenu();
option = sc.nextInt();
sc.nextLine(); // 消费换行符,避免 nextLine() 被跳过
switch (option) {
case 1:
if (insertUser(pst, sc, MIN_DOB, MAX_DOB)) {
System.out.println("✅ Data inserted successfully.");
}
break;
case 2:
case 3:
case 4:
System.out.println("⚠️ Feature not implemented yet.");
break;
case 5:
System.out.println("? Exiting application...");
break;
default:
System.out.println("❌ Invalid option. Please choose 1–5.");
}
} while (option != 5);
}
}
private static void displayMenu() {
System.out.println("\n=== User Data Management ===");
System.out.println("1. Insert user data");
System.out.println("2. Display all users");
System.out.println("3. Delete user by ID");
System.out.println("4. Search user by ID");
System.out.println("5. Exit\n");
System.out.print("Enter your choice: ");
}
private static boolean insertUser(PreparedStatement pst, Scanner sc,
LocalDate minDob, LocalDate maxDob) {
try {
// 读取并校验 UserID
System.out.print("Enter User ID: ");
int userId = Integer.parseInt(sc.nextLine().trim());
// 读取并校验 Name
System.out.print("Enter Name: ");
String name = sc.nextLine().trim();
if (name.isEmpty()) {
System.out.println("❌ Name cannot be empty.");
return false;
}
// 读取并校验 DOB
System.out.print("Enter DOB (YYYY-MM-DD): ");
String dobStr = sc.nextLine().trim();
java.sql.Date sqlDate;
try {
sqlDate = java.sql.Date.valueOf(dobStr);
} catch (IllegalArgumentException e) {
System.out.println("❌ Invalid date format. Use YYYY-MM-DD.");
return false;
}
LocalDate localDob = sqlDate.toLocalDate();
if (localDob.isBefore(minDob) || localDob.isAfter(maxDob)) {
System.out.printf("❌ DOB must be between %s and %s.%n", minDob, maxDob);
return false;
}
// 读取 Address
System.out.print("Enter Address: ");
String address = sc.nextLine().trim();
// 读取并校验 Phone
System.out.print("Enter 10-digit phone number: ");
String phoneStr = sc.nextLine().trim();
long phone;
try {
phone = Long.parseLong(phoneStr);
} catch (NumberFormatException e) {
System.out.println("❌ Phone must contain only digits.");
return false;
}
if (phone < 1_000_000_000L || phone > 9_999_999_999L) {
System.out.println("❌ Phone number must be exactly 10 digits.");
return false;
}
// 读取 UserRole
System.out.print("Enter User Role: ");
String role = sc.nextLine().trim();
// 执行插入
pst.setInt(1, userId);
pst.setString(2, name);
pst.setDate(3, sqlDate);
pst.setString(4, address);
pst.setLong(5, phone);
pst.setString(6, role);
pst.executeUpdate();
return true;
} catch (Exception e) {
System.err.println("❌ Insertion failed: " + e.getMessage());
return false;
}
}
}✅ 关键改进总结
| 改进项 | 原始问题 | 优化方案 |
|---|---|---|
| 驱动加载 | Class.forName() 冗余调用 | 已移除(JDBC 4.0+ 自动服务发现) |
| 异常处理 | throws Exception 过宽泛 | 精确声明 throws SQLException |
| 资源管理 | 手动 con.close() 易遗漏 | try-with-resources 保证自动释放 |
| 输入安全 | nextInt() + next() 导致换行符残留 | 统一用 nextLine() + trim() + parseInt/parseLong |
| DOB校验 | 依赖 java.sql.Date 时区敏感 | LocalDate 纯日期语义,范围判断清晰可靠 |
| 手机号校验 | double 类型导致精度丢失 | long + 数值区间校验,贴合 BIGINT 语义 |
| 用户体验 | 错误后无重试机制 | 校验失败立即提示并跳过插入,保持流程可控 |
? 扩展建议:
- 后续可引入 javax.validation 注解(如 @Past, @Pattern)配合 Bean Validation 实现声明式校验;
- 对敏感操作(如删除)增加二次确认;
- 将数据库配置抽取至 properties 文件,提升可维护性。
通过以上重构,您的应用不仅满足了基础功能需求,更具备了企业级数据校验能力与工程规范性,为后续功能扩展打下坚实基础。
终于介绍完啦!小伙伴们,这篇关于《DOB与手机号校验及JDBC存储实现方法》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!
Win11关闭最近应用方法详解
- 上一篇
- Win11关闭最近应用方法详解
- 下一篇
- Golang结构体嵌套指针怎么用
查看更多
最新文章
-
- 文章 · java教程 | 8秒前 |
- Java验证码生成实现详解
- 125浏览 收藏
-
- 文章 · java教程 | 4分钟前 |
- Gradle多项目依赖配置技巧
- 154浏览 收藏
-
- 文章 · java教程 | 6分钟前 |
- Java枚举映射优化与使用技巧
- 153浏览 收藏
-
- 文章 · java教程 | 19分钟前 |
- Java集合分组统计方法详解
- 355浏览 收藏
-
- 文章 · java教程 | 22分钟前 |
- JavaProperties读取配置方法
- 102浏览 收藏
-
- 文章 · java教程 | 24分钟前 |
- Java泛型提升集合安全方法
- 348浏览 收藏
-
- 文章 · java教程 | 33分钟前 |
- Java为何推荐for-each遍历集合
- 214浏览 收藏
-
- 文章 · java教程 | 34分钟前 |
- Java线程池动态调整技巧
- 483浏览 收藏
-
- 文章 · java教程 | 56分钟前 |
- Java封装数据与行为的优势解析
- 421浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- Java配置Tomcat与调试环境教程
- 470浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- final关键字在Java中的作用详解
- 202浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- Java手机号验证正则表达式合集
- 356浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
查看更多
AI推荐
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 3919次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 4253次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 4135次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 5364次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 4510次使用
查看更多
相关文章
-
- 提升Java功能开发效率的有力工具:微服务架构
- 2023-10-06 501浏览
-
- 掌握Java海康SDK二次开发的必备技巧
- 2023-10-01 501浏览
-
- 如何使用java实现桶排序算法
- 2023-10-03 501浏览
-
- Java开发实战经验:如何优化开发逻辑
- 2023-10-31 501浏览
-
- 如何使用Java中的Math.max()方法比较两个数的大小?
- 2023-11-18 501浏览

