`
eastPoint
  • 浏览: 54336 次
  • 性别: Icon_minigender_1
  • 来自: 湖北武汉
社区版块
存档分类
最新评论

对象开发的好处和坏处

阅读更多

           对于现在这个项目对象开发的好处暂时大于坏处

service代码:

java 代码
  1. public class ClientGroupClientService {   
  2.     private Connection con;   
  3.     private ClientGroupClientDAO cgcdao;   
  4.     private final static int INSERT = 1;   
  5.     private final static int UPDATE = 2;   
  6.     private final static int DELETE = 3;   
  7.        
  8.     public ClientGroupClientService() {   
  9. //      con = ConnUtils.getConnection() ;   
  10.         con = ConnUtils.getDefaultConnection();   
  11.         cgcdao = new ClientGroupClientDAO(getPdao());   
  12.     }   
  13.        
  14.     /**  
  15.      * 初始化该pojo的基本信息  
  16.      * @return Pojo的基本信息,用于dao中的构造参数  
  17.      */  
  18.     private PojoDao getPdao(){   
  19.         PojoDao pdao = new PojoDao();   
  20.         pdao.setView_name("V_CLIENTGROUPCLIENT");//设置此操作类的视图   
  21.         pdao.setPrimarykeyname("objectID");//设置此视图的主键   
  22.         pdao.setP_insert("{call pkg_hedge.up_AddClientGroupClient(?,?,?)}");   
  23.         pdao.setP_update("{call pkg_hedge.up_ModClientGroupClient(?,?,?)}");   
  24.         pdao.setP_delete("{call pkg_hedge.up_DelClientGroupClient(?,?,?)}");   
  25.         return pdao;   
  26.     }   
  27.        
  28.     /*  
  29.      * 分页下载数据  
  30.      * */  
  31.     public void getClientGroupCLientByPage(Page page) {   
  32.         int pageSize = page.getPageSize();   
  33.         int pageIndex = page.getPageIndex();   
  34.         int lastNum = pageIndex*pageSize;   
  35.         int beginNum = (pageIndex-1)*pageSize;   
  36.         ResultSet rs = cgcdao.getDataByPage(con, lastNum, beginNum);   
  37.         ClientGroupClient temp = null;   
  38.            
  39.         List templist = null;   
  40.         if(rs!=null)   
  41.         try {   
  42.             templist = new ArrayList();   
  43.             while(rs.next()){   
  44.                 temp = new ClientGroupClient();   
  45.                 temp.setObjectID(new Long(rs.getLong("objectid")));   
  46.                 temp.setClientID(rs.getString("clientid"));   
  47.                 temp.setCreater(rs.getString("creater"));   
  48.                 temp.setGroupID(new Long(rs.getLong("groupid")));   
  49.                 templist.add(temp);   
  50.             }   
  51.         page.setList(templist);    //添加当页数据   
  52.         rs = cgcdao.getCountNum(con);   
  53.         if(rs!=null)   
  54.         if(rs.next()){   
  55.             page.setRecordCount(rs.getInt(1));   
  56.             page.setPageCount((page.getRecordCount()+(page.getPageSize()-1))/page.getPageSize());//设置分页的页数   
  57.         }   
  58.         } catch (SQLException e) {   
  59.             e.printStackTrace();   
  60.         }finally{   
  61.             temp = null;   
  62.             ConnUtils.close(rs, null, con);   
  63.         }   
  64.     }   
  65.        
  66.     public String insert(List list){   
  67.         return cgcdao.operate(con, list, INSERT);   
  68.     }   
  69.        
  70.     public String update(List list){   
  71.         return cgcdao.operate(con, list, UPDATE);   
  72.     }   
  73.        
  74.     public String delete(List list){   
  75.         return cgcdao.operate(con, list, DELETE);   
  76.     }   
  77.        
  78.     public String batchCRUD(List inserts,List updates,List deletes){   
  79.         String re_msg=null;   
  80.         if(inserts!=null && inserts.size()>0)   
  81.             re_msg = cgcdao.operate(con, inserts, INSERT);   
  82.         if(updates!=null && updates.size()>0)   
  83.             re_msg = cgcdao.operate(con, updates, UPDATE);   
  84.         if(deletes!=null && deletes.size()>0)   
  85.             re_msg = cgcdao.operate(con, deletes, DELETE);   
  86.         closeCon();   
  87.         return re_msg;   
  88.     }   
  89.        
  90.     private void closeCon(){   
  91.         ConnUtils.close(con);   
  92.     }   
  93.        
  94. }  

在批量的方法中调用dao层的抽象方法,好处是将同一过程的代码全部都抽象化,这样操作的前提是对象化的开发,一切参数都是对象化,包括传入数据库中存储过程的参数也是对象化的,这样开发的好处有两点:

第一:维护方便,需要修改的只有存储过程中的对象,和表现层的现实对象,中间过程不会变动特别是抽象的dao层不会变。

第二:简化开发代码,特别是简化了dao曾的代码,其他层的代码也大相径庭,特别是给予dorado的开发模式更是如此。

事例代码如下:

java 代码
  1. public abstract class AcceccDao {   
  2.     protected ResultSet rs;   
  3.     protected CallableStatement proc;   
  4.     protected PreparedStatement pst;   
  5.     protected Person person;   
  6.     protected Iterator it;   
  7.     private Object temp; //临时的变量   
  8.        
  9.     protected PojoDao pdao;   
  10.     public AcceccDao() {   
  11.         // TODO Auto-generated constructor stub   
  12.     }   
  13.     /**  
  14.      * 通过继承类的构造函数初始化将要操作的视图和存储过程名  
  15.      * 视图名称为v_xxx  
  16.      * 其中primarykey 用于排序,如果可以传入一个null  
  17.      * 存储过程为"{call pkg_hedge.uf_AddCreditrecord(?,?,?)}"包含了所有的call和大括号  
  18.      * @param view_name  
  19.      * @param p_insert  
  20.      * @param p_update  
  21.      * @param p_delete  
  22.      */  
  23.     public AcceccDao(PojoDao pdao){   
  24.         this.pdao = pdao;   
  25.     }   
  26.        
  27.     /**  
  28.      * 返回分页数据集  
  29.      * @param con 连接对象  
  30.      * @param lastNum 分页数据的最后一条数据号  
  31.      * @param beginNum .......第一条数据号  
  32.      * @return  
  33.      */  
  34.     public ResultSet getDataByPage(Connection con, int lastNum,int beginNum ) {   
  35.         StringBuffer sb = new StringBuffer();   
  36.         try {   
  37.             sb.append("select * from (select vin.*,rownum rn from "+pdao.getView_name()+" vin where rownum <= ?) vout where rn > ?");   
  38.             if(pdao.getPrimarykeyname()!=null)   
  39.                  sb.append(" order by vout."+pdao.getPrimarykeyname()+" asc");   
  40.             pst = con.prepareStatement(sb.toString());   
  41.             pst.setInt(1, lastNum);   
  42.             pst.setInt(2, beginNum);   
  43.             return pst.executeQuery();   
  44.         } catch (SQLException e) {   
  45.             e.printStackTrace();   
  46.             return null;   
  47.         }finally{   
  48.                
  49.         }          
  50.     }   
  51.        
  52.     /**  
  53.      * 返回该视图记录数的总条数  
  54.      */  
  55.     public ResultSet getCountNum(Connection con){   
  56.         String sql = "select max(rownum) from "+pdao.getView_name();   
  57.         try {   
  58.             pst = con.prepareStatement(sql);   
  59.             return pst.executeQuery();   
  60.         } catch (SQLException e) {   
  61.             e.printStackTrace();   
  62.             return null;   
  63.         }   
  64.     }   
  65.        
  66.     /**  
  67.      * 此方法用于批量或者单个处理增删该  
  68.      * @param con  连接对象  
  69.      * @param list 操作的对象pojo  
  70.      * @param operateType 在service里面定义成常量     
  71.      * private static final int INSERT=1;  
  72.      * private static final int UPDATE=1;  
  73.      * private static final int DELETE=1;  
  74.      * @return  
  75.      */  
  76.     public String operate(Connection con, List list,int operateType) {     
  77.         try {   
  78.             String sql = null;   
  79.             switch (operateType) {   
  80.             case 1:   
  81.                 sql = pdao.getP_insert();   
  82.                 break;   
  83.             case 2:   
  84.                 sql = pdao.getP_update();   
  85.                 break;   
  86.             case 3:   
  87.                 sql = pdao.getP_delete();   
  88.                 break;   
  89.             }   
  90.             proc = con.prepareCall(sql);   
  91.             for(it = list.iterator();it.hasNext();){   
  92.                 temp = (ClientGroupClient)it.next();   
  93.                 proc.registerOutParameter(1, OracleTypes.INTEGER);   
  94.                 proc.registerOutParameter(2, OracleTypes.VARCHAR);   
  95.                 proc.setObject(3, temp);   
  96.                 proc.execute();   
  97.             }   
  98.             return proc.getString(2);   
  99.         } catch (SQLException e) {   
  100.             e.printStackTrace();   
  101.             return null;   
  102.         } finally{   
  103.             temp = null;   
  104.             ConnUtils.close(null, proc, null);   
  105.         }   
  106.     }   
  107. }  

 

而实现类中dao的代码为:

java 代码
  1. public class ClientGroupClientDAO extends AcceccDao {      
  2.     public ClientGroupClientDAO(PojoDao pdao){   
  3.         super(pdao);   
  4.     }   
  5. }  

其中构造函数的参数为改到要操作的数据库中的信息,比如视图名,主键名,插入存储过程名,更新存储过程名,以及其他任何你需要的在dao的抽象层中需要的参数,都可以定义在这里。

java 代码
  1. public class PojoDao {   
  2.     private String view_name; //视图的名称   
  3.     private String primarykeyname;//此表的主键 用于排序   
  4.     private String p_insert; //插入的存储过程名   
  5.     private String p_update; //更新的存储过程名   
  6.     private String p_delete; //删除的...   
  7. //  private String order;    //用于asc 或者 desc   这个主要是为了说明面向对象的设计思想   
  8.        
  9.     public PojoDao() {   
  10.     }   
  11.   
  12.     public String getP_delete() {   
  13.         return p_delete;   
  14.     }   
  15.     public void setP_delete(String p_delete) {   
  16.         this.p_delete = p_delete;   
  17.     }   
  18.     public String getP_insert() {   
  19.         return p_insert;   
  20.     }   
  21.     public void setP_insert(String p_insert) {   
  22.         this.p_insert = p_insert;   
  23.     }   
  24.     public String getP_update() {   
  25.         return p_update;   
  26.     }   
  27.     public void setP_update(String p_update) {   
  28.         this.p_update = p_update;   
  29.     }   
  30.     public String getPrimarykeyname() {   
  31.         return primarykeyname;   
  32.     }   
  33.     public void setPrimarykeyname(String primarykeyname) {   
  34.         this.primarykeyname = primarykeyname;   
  35.     }   
  36.     public String getView_name() {   
  37.         return view_name;   
  38.     }   
  39.     public void setView_name(String view_name) {   
  40.         this.view_name = view_name;   
  41.     }   
  42. }  

在service中将这个PojoDao构造好就可以啦:

 

java 代码
  1. public ClientGroupClientService() {   
  2.     con = ConnUtils.getDefaultConnection();   
  3.     cgcdao = new ClientGroupClientDAO(getPdao());//调用getPdao();   
  4. }   
  5.   
  6. /**  
  7.  * 初始化该pojo的基本信息  
  8.  * @return Pojo的基本信息,用于dao中的构造参数  
  9.  */  
  10. private PojoDao getPdao(){   
  11.     PojoDao pdao = new PojoDao();   
  12.     pdao.setView_name("V_CLIENTGROUPCLIENT");//设置此操作类的视图   
  13.     pdao.setPrimarykeyname("objectID");//设置此视图的主键   
  14.     pdao.setP_insert("{call pkg_hedge.up_AddClientGroupClient(?,?,?)}");   
  15.     pdao.setP_update("{call pkg_hedge.up_ModClientGroupClient(?,?,?)}");   
  16.     pdao.setP_delete("{call pkg_hedge.up_DelClientGroupClient(?,?,?)}");   
  17.     return pdao;   
  18. }  

数据库中也是基于type的变成模式.

好处还是很多的。

 

但是也有不利的地方:

例如我们本次采用的是oracle数据库,存储使用起来太麻烦了,pojo中要匹配oracle的字段类型,多做好多工作,并且在tomcat下能够运行,换成weblogic就跑不动了。

分享到:
评论

相关推荐

    白色简洁的艺术展示网页模板下载.zip

    白色简洁的艺术展示网页模板下载.zip

    电商平台开发需求文档.doc

    电商平台开发需求文档.doc

    STM32F030单片机控制LED灯.zip

    1、嵌入式物联网单片机项目开发例程,简单、方便、好用,节省开发时间。 2、代码使用KEIL 标准库开发,当前在STM32F030C8T6运行,如果是STM32F030其他型号芯片,依然适用,请自行更改KEIL芯片型号以及FLASH容量即可。 3、软件下载时,请注意keil选择项是jlink还是stlink。 4、有偿指导v:wulianjishu666; 5、如果接入其他传感器,请查看账号发布的其他资料。 6、单片机与模块的接线,在代码当中均有定义,请自行对照。 7、若硬件有差异,请根据自身情况调整代码,程序仅供参考学习。 8、代码有注释说明,请耐心阅读。 9、编译时请注意提示,请选择合适的编译器版本。

    数电期末练习题.doc

    数电期末练习题.doc

    交易流水证明_用于材料证明_20241225_174557.zip

    交易流水证明_用于材料证明_20241225_174557.zip

    计算机网络期末复习(第八版)谢希仁

    计算机网络期末复习(第八版)谢希仁

    基于微信小程序的汽车销售系统的设计与实现springboot.zip

    汽车销售系统使用Java语言进行编码,使用Mysql创建数据表保存本系统产生的数据。系统可以提供信息显示和相应服务,其管理汽车销售系统信息,查看汽车销售系统信息,管理汽车销售系统。 用户信息管理页面,此页面提供给管理员的功能有:用户信息的查询管理,可以删除用户信息、修改用户信息、新增用户信息,还进行了对用户名称的模糊查询的条件。 汽车信息管理页面,此页面提供给管理员的功能有:查看已发布的汽车信息数据,修改汽车信息,汽车信息作废,即可删除,还进行了对汽车信息名称的模糊查询 汽车信息信息的类型查询等等一些条件。 汽车类型管理页面,此页面提供给管理员的功能有:根据汽车类型进行条件查询,还可以对汽车类型进行新增、修改、查询操作等等。

    VB+ACCESS网络计时管理系统设计(源代码+系统)(2024gv).7z

    1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于计算机科学与技术等相关专业,更为适合;

    电视盒子的远程输入法应用,可跨屏远程输入和跨屏远程控制盒子.7z

    电视盒子的远程输入法应用,可跨屏远程输入和跨屏远程控制盒子.7z

    白色大气的旅游度假酒店企业网站模板下载.zip

    白色大气的旅游度假酒店企业网站模板下载.zip

    【信息融合】基于matlab多维卡尔曼滤波器传感器信息融合(含GPS)【含Matlab源码 9980期】含报告.zip

    Matlab领域上传的视频均有对应的完整代码,皆可运行,亲测可用,适合小白; 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作

    (177453248)用python代 码放烟花.zip

    标题中的“用python代码放烟花”表明我们将讨论如何使用Python编程语言来模拟烟花绽放的效果。在Python编程中,实现这样的视觉效果通常涉及到图形用户界面(GUI)或者更具体地说是图形渲染。描述中的内容与标题一致,暗示我们将深入探讨一个使用Python编写的烟花模拟程序。 `main.py`是这个项目的核心文件,它很可能是整个烟花秀的主入口点。在这个文件中,开发者可能定义了程序的主循环,以及调用其他模块如`particle.py`的代码。`particle.py`可能包含了粒子系统的设计,因为烟花效果通常是通过模拟无数粒子的运动来实现的。粒子系统是一种常见的计算机图形学技术,用于模拟大量独立对象(在这里是烟花)的行为。 在`particle.py`中,我们可以预期找到类或函数来定义烟花粒子的属性,比如位置、速度、颜色、生命周期等。这些粒子可能会随着时间的推移而改变状态,例如从升空到爆炸,再到散开形成绚丽的图案。开发者可能使用了物理学原理,如重力和随机力,来模拟粒子的运动。 `.gitignore`文件是一个配置文件,告诉Git版本控制系统忽略特定的文件或目录。在这个项目中,它可

    白色创意风格的图片浏览源码下载.zip

    白色创意风格的图片浏览源码下载.zip

    白色大气风格的设计公司CSS3单页模板.zip

    白色大气风格的设计公司CSS3单页模板.zip

    Chapter 03 复合数据类型-1(资源)

    Chapter 03 复合数据类型-1(资源)项目中编写代码部分的源代码示例,包括石头剪刀布程序和用户登录以及增删改查程序

    白色大气风格的电子邮件订阅模板下载.zip

    白色大气风格的电子邮件订阅模板下载.zip

    IMG_20241225_230314.jpg

    IMG_20241225_230314.jpg

    白色简洁风格的安卓游戏卡通动漫人物整站网站模板.zip

    白色简洁风格的安卓游戏卡通动漫人物整站网站模板.zip

    (180204840)变电站红外电压电流互感器绝缘子检测图像数据集

    变电站红外电压电流互感器绝缘子检测图像数据集,数据集总共1600张左右图片,标注为VOC格式图像数据集,数据集总共1600张左右图片,标注为VOC格式。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。

Global site tag (gtag.js) - Google Analytics