java facade dao_Facade模式的一个典型应用--数据库JDBC的应用

Facade模式的定义: 为子系统中的一组接口提供一个一致的界面.Facade一个典型应用就是数据库JDBC的应用,如下例对数据库的操作:

说明:这是在网上的一篇文章中看到的列子,上面没有写全,我在这里补上了,没有用到接口。

package com.pattern.structural.facade;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.SQLException;

/*

* 外观模式的主要用途就是为子系统的复杂处理过程提供方便的调用方法,

* 使得子系统更加容易被使用。

* Facade对象通常属于Singleton模式。

*/

public class Mysql {

private static Connection conn=null;

private static PreparedStatement prep=null;

public Mysql(String sql) {

try {

Class.forName("com.mysql.jdbc.Driver").newInstance();

conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/test","root","");

prep = conn.prepareStatement(sql);

} catch (Exception e) {

e.printStackTrace();

}

}

public void setString(int index, String parString) {

try {

prep.setString(index, parString);

} catch (SQLException e) {

e.printStackTrace();

}

}

public ResultSet executeQuery() {

try {

return prep.executeQuery();

} catch (SQLException e) {

e.printStackTrace();

return null;

}

}

public void close() {

try {

conn.close();

prep.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

package com.pattern.structural.facade;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

public class DBCompare {

public void getResultSet(String sql) {

//        String sql = "SELECT * FROM bulletin WHERE id = ?";

Mysql mysql = new Mysql(sql);

try {

mysql.setString(1, "4");

ResultSet rset = mysql.executeQuery();

while (rset.next()) {

System.out.println(rset.getString("id"));

}

} catch (Exception e) {

e.printStackTrace();

} finally {

mysql.close();

mysql = null;

}

}

}

package com.pattern.structural.facade;

import java.sql.ResultSet;

public class FacadeTest {

public static void main(String[] args) {

Mysql mysql = new Mysql("SELECT * FROM bulletin");

try {

ResultSet rset = mysql.executeQuery();

while (rset.next()) {

System.out.println(rset.getString("id"));

}

} catch (Exception e) {

e.printStackTrace();

} finally {

mysql.close();

mysql = null;

}

}

}

posted on 2008-02-28 15:27 java flex 结合 阅读(2516) 评论(5)  编辑  收藏 所属分类: pattern 、mysql

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的外观模式Java代码实现: ```java // 外观类 public class ShapeMaker { private Shape circle; private Shape rectangle; private Shape square; public ShapeMaker() { circle = new Circle(); rectangle = new Rectangle(); square = new Square(); } public void drawCircle() { circle.draw(); } public void drawRectangle() { rectangle.draw(); } public void drawSquare() { square.draw(); } } // 形状接口 public interface Shape { void draw(); } // 圆形类 public class Circle implements Shape { @Override public void draw() { System.out.println("Circle::draw()"); } } // 矩形类 public class Rectangle implements Shape { @Override public void draw() { System.out.println("Rectangle::draw()"); } } // 正方形类 public class Square implements Shape { @Override public void draw() { System.out.println("Square::draw()"); } } // 测试类 public class FacadePatternDemo { public static void main(String[] args) { ShapeMaker shapeMaker = new ShapeMaker(); shapeMaker.drawCircle(); shapeMaker.drawRectangle(); shapeMaker.drawSquare(); } } ``` 外观模式Facade Pattern)是一种结构型设计模式,它为一组复杂的子系统提供一个简单的接口,隐藏了子系统的复杂性,使得客户端可以更加方便地使用子系统。外观模式通过减少客户端与子系统之间的耦合度,提高了系统的可维护性、可扩展性和可复用性。 优点: - 简化了客户端和子系统之间的交互,降低了客户端的复杂度。 - 对客户端屏蔽了子系统的复杂性,使得客户端更容易使用子系统。 - 提高了系统的可维护性、可扩展性和可复用性。 - 遵循了开闭原则,使得子系统的变化不会影响客户端。 缺点: - 如果设计不合理,会导致外观类变得过于庞大,不易维护。 - 不符合单一职责原则,因为一个外观类可能需要调用多个子系统的方法。 应用场景: - 当一个系统的复杂性超过了客户端的处理能力时,可以使用外观模式来简化客户端和子系统之间的交互。 - 当需要将一个复杂的系统划分为多个子系统时,可以使用外观模式来定义子系统之间的接口。 - 当需要提供一个简单的接口来访问复杂的子系统时,可以使用外观模式来隐藏子系统的复杂性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值