用javeEE实现淘宝收获地址,单表存储,具有翻页功能,增删改功能

时间: 2024-05-01 18:20:02 浏览: 91
首先,我们需要设计数据库表结构。本例中,我们只使用一张表来存储收货地址信息,表名为`tb_address`,包含以下字段: - `id`:主键,自增长; - `user_id`:用户 ID,用于关联用户表; - `name`:收货人姓名; - `phone`:收货人电话; - `province`:省份; - `city`:城市; - `district`:区县; - `address`:详细地址; - `is_default`:是否默认地址,0 表示不是默认地址,1 表示是默认地址。 接下来,我们可以创建一个 `Address` 类来封装地址信息,并为其编写相应的 Getter 和 Setter 方法。 ```java public class Address { private int id; private int userId; private String name; private String phone; private String province; private String city; private String district; private String address; private int isDefault; // Getter 和 Setter 方法省略 } ``` 接着,我们可以创建一个 `AddressDao` 类来实现对地址表的增删改查操作。在本例中,我们使用 JDBC 连接数据库来实现数据访问。 ```java public class AddressDao { // 数据库连接信息 private String driver = "com.mysql.jdbc.Driver"; private String url = "jdbc:mysql://localhost:3306/test"; private String username = "root"; private String password = "123456"; // 查询地址列表 public List<Address> getAddressList(int userId, int page, int pageSize) throws Exception { // 计算分页参数 int start = (page - 1) * pageSize; int end = start + pageSize; // 创建数据库连接 Class.forName(driver); Connection conn = DriverManager.getConnection(url, username, password); // 执行 SQL 查询 String sql = "SELECT * FROM tb_address WHERE user_id = ? LIMIT ?, ?"; PreparedStatement pstmt = conn.prepareStatement(sql); pstmt.setInt(1, userId); pstmt.setInt(2, start); pstmt.setInt(3, pageSize); ResultSet rs = pstmt.executeQuery(); // 封装查询结果 List<Address> list = new ArrayList<>(); while (rs.next()) { Address address = new Address(); address.setId(rs.getInt("id")); address.setUserId(rs.getInt("user_id")); address.setName(rs.getString("name")); address.setPhone(rs.getString("phone")); address.setProvince(rs.getString("province")); address.setCity(rs.getString("city")); address.setDistrict(rs.getString("district")); address.setAddress(rs.getString("address")); address.setIsDefault(rs.getInt("is_default")); list.add(address); } // 关闭连接 rs.close(); pstmt.close(); conn.close(); return list; } // 查询地址总数 public int getAddressCount(int userId) throws Exception { // 创建数据库连接 Class.forName(driver); Connection conn = DriverManager.getConnection(url, username, password); // 执行 SQL 查询 String sql = "SELECT COUNT(*) FROM tb_address WHERE user_id = ?"; PreparedStatement pstmt = conn.prepareStatement(sql); pstmt.setInt(1, userId); ResultSet rs = pstmt.executeQuery(); // 获取查询结果 int count = 0; if (rs.next()) { count = rs.getInt(1); } // 关闭连接 rs.close(); pstmt.close(); conn.close(); return count; } // 添加地址 public void addAddress(Address address) throws Exception { // 创建数据库连接 Class.forName(driver); Connection conn = DriverManager.getConnection(url, username, password); // 执行 SQL 插入语句 String sql = "INSERT INTO tb_address(user_id, name, phone, province, city, district, address, is_default) " + "VALUES (?, ?, ?, ?, ?, ?, ?, ?)"; PreparedStatement pstmt = conn.prepareStatement(sql); pstmt.setInt(1, address.getUserId()); pstmt.setString(2, address.getName()); pstmt.setString(3, address.getPhone()); pstmt.setString(4, address.getProvince()); pstmt.setString(5, address.getCity()); pstmt.setString(6, address.getDistrict()); pstmt.setString(7, address.getAddress()); pstmt.setInt(8, address.getIsDefault()); pstmt.executeUpdate(); // 关闭连接 pstmt.close(); conn.close(); } // 更新地址 public void updateAddress(Address address) throws Exception { // 创建数据库连接 Class.forName(driver); Connection conn = DriverManager.getConnection(url, username, password); // 执行 SQL 更新语句 String sql = "UPDATE tb_address SET name = ?, phone = ?, province = ?, city = ?, district = ?, " + "address = ?, is_default = ? WHERE id = ?"; PreparedStatement pstmt = conn.prepareStatement(sql); pstmt.setString(1, address.getName()); pstmt.setString(2, address.getPhone()); pstmt.setString(3, address.getProvince()); pstmt.setString(4, address.getCity()); pstmt.setString(5, address.getDistrict()); pstmt.setString(6, address.getAddress()); pstmt.setInt(7, address.getIsDefault()); pstmt.setInt(8, address.getId()); pstmt.executeUpdate(); // 关闭连接 pstmt.close(); conn.close(); } // 删除地址 public void deleteAddress(int id) throws Exception { // 创建数据库连接 Class.forName(driver); Connection conn = DriverManager.getConnection(url, username, password); // 执行 SQL 删除语句 String sql = "DELETE FROM tb_address WHERE id = ?"; PreparedStatement pstmt = conn.prepareStatement(sql); pstmt.setInt(1, id); pstmt.executeUpdate(); // 关闭连接 pstmt.close(); conn.close(); } } ``` 最后,我们可以创建一个 `AddressServlet` 类来处理收货地址相关的 HTTP 请求。 ```java public class AddressServlet extends HttpServlet { private AddressDao addressDao = new AddressDao(); @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { // 获取用户 ID 参数 int userId = Integer.parseInt(req.getParameter("userId")); // 获取分页参数 int page = req.getParameter("page") != null ? Integer.parseInt(req.getParameter("page")) : 1; int pageSize = req.getParameter("pageSize") != null ? Integer.parseInt(req.getParameter("pageSize")) : 10; try { // 查询地址列表 List<Address> list = addressDao.getAddressList(userId, page, pageSize); // 查询地址总数 int count = addressDao.getAddressCount(userId); // 计算总页数 int pageCount = count % pageSize == 0 ? count / pageSize : count / pageSize + 1; // 封装查询结果 Map<String, Object> result = new HashMap<>(); result.put("code", 200); result.put("message", "success"); result.put("data", list); result.put("count", count); result.put("pageCount", pageCount); // 将查询结果转换成 JSON 格式并输出到客户端 Gson gson = new Gson(); String json = gson.toJson(result); resp.getWriter().write(json); } catch (Exception e) { e.printStackTrace(); // 封装错误信息并输出到客户端 Map<String, Object> result = new HashMap<>(); result.put("code", 500); result.put("message", "server error: " + e.getMessage()); Gson gson = new Gson(); String json = gson.toJson(result); resp.getWriter().write(json); } } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { // 获取操作参数 String action = req.getParameter("action"); try { if ("add".equals(action)) { // 添加地址 Address address = new Address(); address.setUserId(Integer.parseInt(req.getParameter("userId"))); address.setName(req.getParameter("name")); address.setPhone(req.getParameter("phone")); address.setProvince(req.getParameter("province")); address.setCity(req.getParameter("city")); address.setDistrict(req.getParameter("district")); address.setAddress(req.getParameter("address")); address.setIsDefault(Integer.parseInt(req.getParameter("isDefault"))); addressDao.addAddress(address); // 封装添加结果并输出到客户端 Map<String, Object> result = new HashMap<>(); result.put("code", 200); result.put("message", "success"); Gson gson = new Gson(); String json = gson.toJson(result); resp.getWriter().write(json); } else if ("update".equals(action)) { // 更新地址 Address address = new Address(); address.setId(Integer.parseInt(req.getParameter("id"))); address.setName(req.getParameter("name")); address.setPhone(req.getParameter("phone")); address.setProvince(req.getParameter("province")); address.setCity(req.getParameter("city")); address.setDistrict(req.getParameter("district")); address.setAddress(req.getParameter("address")); address.setIsDefault(Integer.parseInt(req.getParameter("isDefault"))); addressDao.updateAddress(address); // 封装更新结果并输出到客户端 Map<String, Object> result = new HashMap<>(); result.put("code", 200); result.put("message", "success"); Gson gson = new Gson(); String json = gson.toJson(result); resp.getWriter().write(json); } else if ("delete".equals(action)) { // 删除地址 int id = Integer.parseInt(req.getParameter("id")); addressDao.deleteAddress(id); // 封装删除结果并输出到客户端 Map<String, Object> result = new HashMap<>(); result.put("code", 200); result.put("message", "success"); Gson gson = new Gson(); String json = gson.toJson(result); resp.getWriter().write(json); } } catch (Exception e) { e.printStackTrace(); // 封装错误信息并输出到客户端 Map<String, Object> result = new HashMap<>(); result.put("code", 500); result.put("message", "server error: " + e.getMessage()); Gson gson = new Gson(); String json = gson.toJson(result); resp.getWriter().write(json); } } } ``` 最后,我们需要在 `web.xml` 文件中配置 `AddressServlet` 类的映射关系。 ```xml <servlet> <servlet-name>AddressServlet</servlet-name> <servlet-class>com.example.AddressServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>AddressServlet</servlet-name> <url-pattern>/address/*</url-pattern> </servlet-mapping> ``` 现在,我们可以在浏览器中访问以下地址来测试代码: - 查询地址列表:`http://localhost:8080/address?userId=1&page=1&pageSize=10` - 添加地址:`http://localhost:8080/address?action=add&userId=1&name=张三&phone=13800138000&province=广东省&city=深圳市&district=福田区&address=华强北&isDefault=0` - 更新地址:`http://localhost:8080/address?action=update&id=1&name=李四&phone=13800138111&province=广东省&city=深圳市&district=南山区&address=科技园&isDefault=1` - 删除地址:`http://localhost:8080/address?action=delete&id=1`

相关推荐

zip
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 、4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。、可私 6信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 、4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。、可 6私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 、4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。、可私 6信博主看论文后选择购买源代码。
zip
zip
zip

最新推荐

recommend-type

JavaEE网上书店实验报告.doc

- 图书管理:管理员增删改图书信息,实时更新到用户界面。 - 订单管理:管理员查看、发货订单,更新用户购物车订单状态。 **5. 实体类设计** 例如Customer类,包含用户名、密码、邮箱等属性,用于用户注册、登录,...
recommend-type

在c#的GridView中使用邮件链接的方法.zip

我们知道,在GridView中可以使用HyperLinkField生成一个超链接,但是这个超链接只能是普通的http的超链接, 如果想做一个邮件的链接(mailto:user@abc.com)似乎就不起作用了。通过模板列的方式实现
recommend-type

ASP网上军事论坛的设计与实现(源代码+论文).zip

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 、4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。、可私 6信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 、4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。、可 6私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 、4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。、可私 6信博主看论文后选择购买源代码。
recommend-type

网站与网页设计终版.zip(毕设&课设&实训&大作业&竞赛&项目)

项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
recommend-type

vue+SpringBoot493翻转课堂微视频管理系统java毕业设计源码含论文.rar

jdk版本:jdk1.8+ 前端:vue.js+ElementUI 开发工具:IDEA 或者eclipse都支持 编程语言: java 框架支持:springboot 数据库: mysql 版本不限 数据库工具:Navicat/SQLyog都可以 详细技术:java+springboot+vue+MYSQL+MAVEN 前端采用的Vue框架,后端采用java语言,sprinboot框架,mybatis操作数据源,使用软件:idea,eclipse、MySQL。完成了用户登录管理等模块的设计与实现。完成了系统数据库的设计,并基于MySQL数据库管理系统
recommend-type

多传感器数据融合手册:国外原版技术指南

"Handbook of Multisensor Data Fusion" 是一本由CRC Press LLC出版的国外原版书籍,专注于多传感器数据融合领域。这本书包含了26个章节,全面覆盖了数据融合中的关键议题,如数据关联、目标跟踪、识别以及预处理等。 在数据融合领域,多传感器技术是至关重要的,它涉及多个传感器的协同工作,通过整合来自不同来源的数据来提高信息的准确性和完整性。数据融合不仅仅是简单地将不同传感器收集的信息叠加,而是要进行复杂的处理和分析,以消除噪声,解决不确定性,并提供更可靠的决策依据。这本书深入探讨了这个过程,涵盖了从基础理论到实际应用的各个方面。 数据关联是其中的一个关键主题,它涉及到如何将来自不同传感器的测量值对应到同一个实体上,这对于目标跟踪至关重要。目标跟踪则是监控特定物体或事件在时间序列中的位置和状态,需要处理诸如传感器漂移、目标遮挡和多目标混淆等问题。数据融合在这里的作用是提高跟踪的精度和鲁棒性。 识别部分可能涉及模式识别和分类技术,用于确定传感器数据所代表的对象或事件的身份。预处理步骤则通常包括数据清洗、校准、滤波和标准化等,目的是确保输入数据的质量,以便后续的融合算法能有效地处理。 书中的内容来源于权威且备受尊重的源,并引用了相关材料,列出了多种参考文献。尽管作者和出版商已尽力提供可靠的数据和信息,但他们不对所有材料的准确性和使用后果承担责任。此外,书籍版权受到严格保护,未经许可不得复制或传播,若要进行内部或个人使用,需获得CRC Press LLC的书面许可并支付相应的费用。 "Handbook of Multisensor Data Fusion" 是一份全面且深入的参考资料,对于想要了解和研究多传感器数据融合技术的读者来说,具有极高的价值。无论是学术研究还是实际工程应用,都能从中获取丰富的知识和指导。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【元编程】:Python动态创建和修改函数的运行时魔法

![【元编程】:Python动态创建和修改函数的运行时魔法](https://blog.finxter.com/wp-content/uploads/2021/02/object-1-1024x576.jpg) # 1. 元编程的基本概念和重要性 在软件开发中,元编程(Metaprogramming)是指编写可以操作其他程序代码的代码。它允许程序在运行时生成、修改或者执行代码,这意味着你可以创建一个可以编写或者操作其他代码的系统。元编程的概念对于理解程序如何执行以及如何让程序更有效率和可维护至关重要。在这一章中,我们将简要概述元编程的基础知识,包括它的基本定义、历史背景以及在现代软件工程中的
recommend-type

Visual Studio Code中的python如何多行注释

在Visual Studio Code (VSCode) 中,处理 Python 代码的多行注释,你可以按照以下步骤操作: 1. **使用预设快捷键**: - 转到你要注释的多行文本,按 `Ctrl + Shift + `/ 或 `Cmd + Shift + `/(在Mac上)。这将添加三行开始于 `'''` 的多行字符串注释(三个单引号)。 2. **选择注释风格**: - 另一种方式是在菜单栏选择 "Edit" -> "Toggle Line Comment", 然后从下拉列表中选择 "Triple Quotes",这也适用于多行注释。 3. **使用代码片段**:
recommend-type

MyEclipse快捷键大全,提升编程效率

"myeclipse 快捷键" 在编程的世界里,高效的工作离不开快捷键的运用。MyEclipse作为一款强大的Java集成开发环境,拥有众多实用的快捷键,能够极大地提升开发效率。以下是一些常用且重要的MyEclipse快捷键及其功能: 1. Ctrl+Shift+O:自动导入缺失的类,这是非常常用的一个快捷键,可以帮助你快速整理代码中的导入语句。 2. Ctrl+F:全局查找,可以在当前文件或整个项目中查找指定文本。 3. Ctrl+Shift+K:查找下一个匹配项,与Ctrl+K一起使用可以快速在查找结果之间切换。 4. Ctrl+K:查找上一个匹配项,配合Ctrl+Shift+K可以方便地在查找结果间导航。 5. Ctrl+Z:撤销操作,如同“后悔药”,可以撤销最近的一次编辑。 6. Ctrl+C:复制选中的文本或代码,便于快速复制和粘贴。 7. Ctrl+X:剪切选中的文本或代码,与Ctrl+V配合可以实现剪切并粘贴。 8. Ctrl+1:快速修复,当出现错误或警告时,MyEclipse会提供解决方案,按此快捷键可快速应用建议的修复方法。 9. Alt+/:代码完成,自动补全代码,尤其在编写Java代码时非常实用。 10. Ctrl+A:全选当前文件或编辑器的内容。 11. Delete:删除选中的文本或代码,不选择任何内容时,删除光标所在字符。 12. Alt+Shift+?:查看当前方法或类的JavaDoc,了解函数用途和参数说明。 13. Ctrl+Shift+Space:智能提示,提供当前上下文的代码补全建议。 14. F2:跳转到下一个错误或警告,快速定位问题。 15. Alt+Shift+R:重命名,用于修改变量、方法或类名,所有引用都会相应更新。 16. Alt+Shift+L:列出并切换打开的编辑器。 17. Ctrl+Shift+F6:关闭当前编辑器的下一个标签页。 18. Ctrl+Shift+F7:切换到下一个高亮的匹配项。 19. Ctrl+Shift+F8:切换到上一个高亮的匹配项。 20. Ctrl+F6:切换到下一个打开的编辑器。 21. Ctrl+F7:在当前文件中查找下一个匹配项。 22. Ctrl+F8:在当前文件中查找上一个匹配项。 23. Ctrl+W:关闭当前编辑器。 24. Ctrl+F10:运行配置,可以用来启动应用或测试。 25. Alt+-:打开或关闭当前视图。 26. Ctrl+F3:在当前工作空间中搜索所选内容。 27. Ctrl+Shift+T:打开类型,可以快速查找并打开类文件。 28. F4:打开资源,显示所选资源的详细信息。 29. Shift+F2:跳转到上一次的位置,方便在代码间快速切换。 30. Ctrl+Shift+R:打开资源,全局搜索文件。 31. Ctrl+Shift+H:类型层次结构,查看类的继承关系。 32. Ctrl+G:查找行,快速定位到指定行号。 33. Ctrl+Shift+G:在工作空间中查找引用,追踪代码引用。 34. Ctrl+L:跳转到指定行号,方便快速定位。 35. Ctrl+Shift+U:切换大小写,对选中的文本进行大小写转换。 36. Ctrl+H:全局搜索,可以搜索整个工作空间中的代码。 37. Ctrl+G:查找字符,快速找到特定字符。 38. Ctrl+Shift+L:显示快捷键列表,随时查看所有可用的快捷键。 39. Ctrl+Shift+J:插入内联注释,方便快速添加临时注释。 40. Ctrl+Shift+M:引入所需导入的包,自动导入缺少的包。 41. Ctrl+Shift+O:优化导入,删除未使用的导入,并自动排序。 42. Ctrl+Shift+F:格式化代码,按照预设的代码风格进行格式化。 43. Ctrl+/:块注释,选中的代码会被注释掉。 44. Ctrl+\:取消块注释,恢复被注释的代码。 45. Ctrl+Shift+M:快速添加try/catch块,简化异常处理。 46. Ctrl+Shift+F4:关闭所有打开的编辑器。 47. Alt+Enter:显示上下文敏感的帮助或修复建议。 48. Ctrl+N:新建,创建新的文件或项目。 49. Ctrl+B:跳转到定义,快速查看变量或方法的定义。 50. Ctrl+Shift+F:格式化代码,与Ctrl+F不同的是,它会格式化整个文件。 51. Ctrl+/:行注释,对当前行进行注释。 52. Ctrl+Shift+/:块注释,选中的多行代码会被注释掉。 53. F7:在调试模式下,步进进入方法。 54. F6:在调试模式下,步过方法,不会进入方法内部。 55. F5:在调试模式下,强制步进进入方法,即使方法是native或者已经被优化。 56. Ctrl:选中多个选项,如在重构或查找替换时。 通过熟练掌握这些MyEclipse快捷键,你可以更加高效地编写和管理代码,提高编程的生产力。记得经常练习和使用,它们将成为你编程生涯中的得力助手。