JDBC__DAO设计模式

JAVA 类的属性:

1)在JavaEE 中,Java类的属性通过getter,setter来定义:get(或set)方法,
去除get(或set)后,首字母小写即为Java类的属性

2)而以前叫的那个属性,即成员变量,称为字段。

3)操作Java类的属性,有一个工具包:beanutils

一:搭建环境:需要同时加入:commons-beanutils-1.9.3.jar 和 commons-logging-1.2.jar

①.setProperty()
BeanUtils.setProperty(object,“idCard”,“22222211”);
②.getProperty()
Object val = BeanUtils.getProperty(object,“idcard”);
1.DAO: Data Access Object

why:
实现功能的模块化。更有利于代码的维护和升级
DAO 可以被子类继承或直接使用

what: 访问数据信息的类。包含了对数据的增删改查,而不包含任务业务相关的信息

how:使用JDBC 编写DAO 可能会包含的方法:

//insert , update, delete都可以包含在其中
void update(String sql, Object…args)

//查询一条记录,返回对应的对象
T get(Class clazz, String sql , Object…args);
//查询多条记录,返回对应的对象的集合
List getForList(Class clazz, String sql , Object…args);

//返回某条记录的某一个字段的值或一个统计的值(一共有多少条记录等)
E getForValue(String sql, Object…args);

public class DAOTest {
    //insert , update, delete都可以包含在其中
    public void update(String sql, Object... args) {
        Connection connection = null;
        PreparedStatement preparedStatement = null;

        try {
            connection = JDBCTools.getConnection2();
            preparedStatement = connection.prepareStatement(sql);

            for (int i = 0; i < args.length; i++) {
                preparedStatement.setObject(i + 1, args[i]);
            }

            preparedStatement.executeUpdate();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            JDBCTools.release(null, preparedStatement, connection);
        }
    }

    //查询一条记录,返回对应的对象
    public <T> T get(Class<T> clazz, String sql, Object... args) {

        T entity = null;
        Connection connection = null;
        PreparedStatement preparedStatement = null;
        ResultSet resultSet = null;

        try {
            //1.获取Connection
            connection = JDBCTools.getConnection2();
            //2.获取PreparedStatement
            preparedStatement = connection.prepareStatement(sql);
            //3.填充占位符
            for (int i = 0; i < args.length; i++) {
                preparedStatement.setObject(i + 1, args[i]);
            }
            //4.进行查询,得到ResultSet
            resultSet = preparedStatement.executeQuery();
            //5.若ResultSet中有记录,准备一个Map<String,Object>  :  键:存放列的别名  ,值:存放列的值
            if (resultSet.next()) {
                Map<String, Object> values = new HashMap<String, Object>();
                //6.得到ResultSetMetaData 对象
                ResultSetMetaData rsmd = resultSet.getMetaData();
                //7.处理ResultSet,把指针向下移动一个单位

                //8.由ResultSetMetaData 对象得到结果集中有多少列
                int columnCount = rsmd.getColumnCount();
                //9.由ResultSetMetaData 得到每一列的别名,由ResultSet 得到具体每一列的值
                for (int i = 0; i < columnCount; i++) {
                    String coulumnLabel = rsmd.getColumnLabel(i + 1);
                    Object coulumnValue = resultSet.getObject(i + 1);

                    //10.填充Map 对象
                    values.put(coulumnLabel, coulumnValue);
                }

                //11.用反射创建Class 对应的对象。
                entity = clazz.newInstance();
                //12.遍历Map 对象,用反射填充对象的属性值:属性为Map 中key。属性值为Map中的value
                for (Map.Entry<String, Object> entry : values.entrySet()) {
                    String propertyName = entry.getKey();
                    Object value = entry.getValue();

//                  ReflectionUtils.setFieldValue(entity, propertyName, value);
                    BeanUtils.setProperty(entity,propertyName,value);
                }
            }

        } catch (Exception E) {
            E.printStackTrace();
        } finally {
            JDBCTools.release(resultSet, preparedStatement, connection);
        }


        return null;
    }

    //查询多条记录,返回对应的对象的集合
    public <T> List<T> getForList(Class<T> clazz, String sql, Object... args) throws Exception {

        List<T> list = new ArrayList<>();

        Connection connection = null;
        PreparedStatement preparedStatement = null;
        ResultSet resultSet = null;

        try{
            connection = JDBCTools.getConnection2();
            preparedStatement = connection.prepareStatement(sql);
            
        //5.准备一个List<Map<String, Object>>:
        //键:存放列的别名  ,值:存放列的值 . 其中一个Map对象对应着一条记录


        //7.处理ResultSet,使用while循环

        //11.把一条记录的一个Map对象放入5准备的List中

        //12.判断List是否为空集合。若不为空,则遍历List,得到一个一个的Map对象,
        //   再把一个Map对象转为一个Class参数对应的Object对象

        //13.把Objcet对象放入到list中。

        return null;
    }

    //返回某条记录的某一个字段的值或一个统计的值(一共有多少条记录等)
    public <E> E getForValue(String sql, Object... args) {

        return null;

    }

}

猜你喜欢

转载自blog.csdn.net/zjhzxjq/article/details/88699208