关于接口在J2EE编程中的小运用及一些体会

2024-05-13 03:38
文章标签 接口 编程 运用 体会 j2ee

本文主要是介绍关于接口在J2EE编程中的小运用及一些体会,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关于接口在J2EE编程中的小运用及一些体会


关于接口

接口是一些列方法的抽象,并没有给出具体的实现,需要特定的类去实现它,在J2EE编程中,通常分为三块,前台的显示,业务逻辑部分以及数据库访问部分,也就是DAO层。在DAO层,则可以定义一个接口,这样换底层是数据库的话,更改起来也比较方便

代码块

例如定义一个将产品存入数据库的接口ProductDAO.java,例如:

@requires_authorization
import java.sql.Timestamp;
import java.util.List;import com.bandc.shopping.Product;public interface ProductDAO {public List<Product> getProductlist();public boolean addProduct(Product p);public List<Product> findProducts(int id,String name,String descr,double lownormalprice,double highnormalprice,double lowmembershipprice,double highmembershiprice,Timestamp pdate,int categoryid);public void deleteProductByCategoryId(int categoryid);public void deleteProductById(int id);public boolean updateProduct(Product p);}

这里定义了一个接口,然后定义一个类去实现它ProductMySQLDAO.java,这就是一个基于MySQL数据库的一个具体的实现

package com.bandc.shopping.DAO;import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.sql.Timestamp;
import java.util.*;import com.bandc.shopping.Product;
import com.bandc.shopping.util.DB;public class ProductMySQLDAO implements ProductDAO {public List<Product> getProductlist() {return null;}public boolean addProduct(Product p) {int id = p.getId();String name = p.getName();String descr = p.getDescr();double normalprice = p.getNormalprice();double memberprice = p.getMemberprice();Timestamp pdate =p.getPdate();int categoryid = p.getCategoryid();Connection conn =null;String sql = null;PreparedStatement pstmt = null; try{conn = DB.getConn();if(id == -1){sql = "insert into product values(null,?,?,?,?,?,?)";}else{sql = "insert into product values("+id+",?,?,?,?,?,?)";}pstmt = conn.prepareStatement(sql);pstmt.setString(1, name);pstmt.setString(2, descr);pstmt.setDouble(3, normalprice);pstmt.setDouble(4, memberprice);pstmt.setTimestamp(5, pdate);pstmt.setInt(6, categoryid);//System.out.println(sql);pstmt.executeUpdate();System.out.println("插入成功");}catch(SQLException e){e.printStackTrace();return false;}finally{DB.closePstmt(pstmt);DB.closeConn(conn);}   //System.out.println("插入成功");return true;}public List<Product> findProducts(int id, String name, String descr,double lownormalprice, double highnormalprice,double lowmembershipprice, double highmembershiprice,Timestamp pdate, int categoryid) {// TODO Auto-generated method stubreturn null;}public void deleteProductByCategoryId(int categoryid) {// TODO Auto-generated method stub}public void deleteProductById(int id) {// TODO Auto-generated method stub}public boolean updateProduct(Product p) {// TODO Auto-generated method stubreturn false;}public List<Product> findProducts(int id, String name, String descr,double lownormalprice, double highnormalprice,double lowmembershipprice, double highmembershiprice,com.sun.jmx.snmp.Timestamp pdate, int categoryid) {// TODO Auto-generated method stubreturn null;}```
然后在业务逻辑层,有一个关于产品的管理类ProductManager.java
``` python
package com.bandc.shopping;import java.util.List;import com.bandc.shopping.DAO.ProductDAO;
import com.bandc.shopping.DAO.ProductMySQLDAO;public class ProductManager {ProductDAO dao = null;private static ProductManager pm = null;static{if(pm == null){pm = new ProductManager();pm.setDAO(new ProductMySQLDAO());//只要改变这一句话,并生成相应的数据库的DAO,那么改变就完成了}}public static ProductManager getInstance(){return pm;}public List<Product> getProductlist() {return dao.getProductlist();}public ProductDAO getDAO(){return dao;}private void setDAO(ProductDAO dao) {this.dao = dao;}public boolean addProduct(Product p) {return dao.addProduct(p);}public List<Product> findProducts(int id, String name, String descr,double lownormalprice, double highnormalprice,double lowmembershipprice, double highmembershiprice,Timestamp pdate, int categoryid) {// TODO Auto-generated method stubreturn null;}public void deleteProductByCategoryId(int categoryid) {// TODO Auto-generated method stub}public void deleteProductById(int id) {// TODO Auto-generated method stub}public boolean updateProduct(Product p) {// TODO Auto-generated method stubreturn false;}
}

这样可以大大的提高代码的灵活性。

这篇关于关于接口在J2EE编程中的小运用及一些体会的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/984579

相关文章

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

go中空接口的具体使用

《go中空接口的具体使用》空接口是一种特殊的接口类型,它不包含任何方法,本文主要介绍了go中空接口的具体使用,具有一定的参考价值,感兴趣的可以了解一下... 目录接口-空接口1. 什么是空接口?2. 如何使用空接口?第一,第二,第三,3. 空接口几个要注意的坑坑1:坑2:坑3:接口-空接口1. 什么是空接

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

如何用java对接微信小程序下单后的发货接口

《如何用java对接微信小程序下单后的发货接口》:本文主要介绍在微信小程序后台实现发货通知的步骤,包括获取Access_token、使用RestTemplate调用发货接口、处理AccessTok... 目录配置参数 调用代码获取Access_token调用发货的接口类注意点总结配置参数 首先需要获取Ac

讯飞webapi语音识别接口调用示例代码(python)

《讯飞webapi语音识别接口调用示例代码(python)》:本文主要介绍如何使用Python3调用讯飞WebAPI语音识别接口,重点解决了在处理语音识别结果时判断是否为最后一帧的问题,通过运行代... 目录前言一、环境二、引入库三、代码实例四、运行结果五、总结前言基于python3 讯飞webAPI语音

MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析

《MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析》本文将详细讲解MyBatis-Plus中的lambdaUpdate用法,并提供丰富的案例来帮助读者更好地理解和应... 目录深入探索MyBATis-Plus中Service接口的lambdaUpdate用法及示例案例背景

Java8需要知道的4个函数式接口简单教程

《Java8需要知道的4个函数式接口简单教程》:本文主要介绍Java8中引入的函数式接口,包括Consumer、Supplier、Predicate和Function,以及它们的用法和特点,文中... 目录什么是函数是接口?Consumer接口定义核心特点注意事项常见用法1.基本用法2.结合andThen链

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll

MyBatis-Flex BaseMapper的接口基本用法小结

《MyBatis-FlexBaseMapper的接口基本用法小结》本文主要介绍了MyBatis-FlexBaseMapper的接口基本用法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具... 目录MyBATis-Flex简单介绍特性基础方法INSERT① insert② insertSelec