一、三层框架:mysql
表现层:sql
是用于展现数据数据库
业务层:mybatis
是处理业务需求app
持久层:框架
是和数据库交互spa
注:MyBatis在持久层code
二、JDBC操做数据库对象
public static void main(String[] args) { Connection connection = null; PreparedStatement preparedStatement = null; ResultSet resultSet = null; try { //加载数据库驱动 Class.forName("com.mysql.jdbc.Driver"); //经过驱动管理类获取数据库连接 connection = DriverManager .getConnection("jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8","ro ot", "root"); //定义 sql 语句 ?表示占位符 String sql = "select * from user where username = ?"; //获取预处理 statement preparedStatement = connection.prepareStatement(sql); //设置参数,第一个参数为 sql 语句中参数的序号(从 1 开始),第二个参数为设置的参数值 preparedStatement.setString(1, "王五"); //向数据库发出 sql 执行查询,查询出结果集 resultSet = preparedStatement.executeQuery(); //遍历查询结果集 while(resultSet.next()){ System.out.println(resultSet.getString("id")+" "+resultSet.getString("username")); } } catch (Exception e) { e.printStackTrace(); }finally{ //释放资源 if(resultSet!=null){ try { resultSet.close(); } catch (SQLException e) { e.printStackTrace(); }
}
if(preparedStatement!=null){ try { preparedStatement.close(); } catch (SQLException e) { e.printStackTrace(); }
}
if(connection!=null){ try { connection.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); }
}
}
}
三、ORM(对象关系映射):Object Relational Mapping blog
简单说:
就是把 数据库表 和 实体类 以及 实体类 对应的 属性 对应起来
让咱们能够经过操做 实体类 实现对 数据库表 的操做。
四、<selectKey>标签
五、QueryVo 实现多个实体类的参数传递。
六、
待续。。。。