JDBC学习(5)架构层次之间的数据的解析和传递
来源:互联网 发布:小米2s怎么用3g网络 编辑:程序博客网 时间:2024/05/22 03:20
三层架构:
表示层:基于web的JSP,Servlet等
业务逻辑层:Spring等
数据访问层:JDBC Hibernate
jdbc从数据库中得到的student表的数据业务逻辑层是不能够直接使用的。
我们需要一个实体类Student来解析数据
public class Student {private String Sno;private String Sname;private String Ssex;private int Sage;private String Sdept;public String getSno() {return Sno;}public void setSno(String sno) {Sno = sno;}public String getSname() {return Sname;}public void setSname(String sname) {Sname = sname;}public String getSsex() {return Ssex;}public void setSsex(String ssex) {Ssex = ssex;}public int getSage() {return Sage;}public void setSage(int sage) {Sage = sage;}public String getSdept() {return Sdept;}public void setSdept(String sdept) {Sdept = sdept;}}
我们对于这个实体类(解析的数据的操作我们单独定义类,而且采用实现接口的方式)
接口:
public interface StudentDao {public void addStudent(Student student); //增public Student findStudent(String name); //查public void update(Student student); //改public void delete(Student student); //删}
接口实现:
public class StudentDaoImpl implements StudentDao {}
增加的实现(核心代码):
Connection conn = null;PreparedStatement ps = null;ResultSet rs = null;try{conn = JdbcUtils.getConnection();String sql = "insert into student(Sno,Sname,Ssex,Sage,Sdept) values(?,?,?,?,?)";ps = conn.prepareStatement(sql);ps.setString(1, student.getSno());ps.setString(2, student.getSname());ps.setString(3, student.getSsex());ps.setInt(4, student.getSage());ps.setString(5, student.getSdept());ps.executeUpdate();}
根据传入的学生实体类对象,通过get方法一一获取到属性值传入insert语句,执行。
更新的代码:
Connection conn = null;PreparedStatement ps = null;ResultSet rs = null;try{conn = JdbcUtils.getConnection();String sql = "update student set Ssex=?,Sage=? where Sno=?";ps = conn.prepareStatement(sql);ps.setString(1, student.getSsex());ps.setInt(2, student.getSage());ps.setString(3,student.getSno());ps.executeUpdate();}
因为主键是不变的,所以根据主键来作为where的条件表达式,根据传入的参数(实体类),来get到各个属性值并设置到update语句。
查询的代码:
Connection conn = null;PreparedStatement ps = null;ResultSet rs = null;Student student = null;try{conn = JdbcUtils.getConnection();String sql = "select Sno,Sname,Ssex,Sage,Sdept from student where Sname = ?";ps = conn.prepareStatement(sql);ps.setString(1, name);rs = ps.executeQuery();while(rs.next()){student.setSno(rs.getString("Sno")); student.setSname(rs.getString("Sname")); student.setSsex(rs.getString("Ssex")); student.setSage(rs.getInt("Sage")); student.setSdept(rs.getString("Sdept"));}
这里传入的参数是名字(一个字符串)传入这个名字作为select语句where Sname的条件去匹配查询
再根据返回到的查询结果去设置一个局部的student对象的各个属性,并返回这个对象。
删除的代码:
Connection conn = null;Statement st = null;ResultSet rs = null;try{conn = JdbcUtils.getConnection();st = conn.createStatement();String sql = "delete from student where Sno="+student.getSno();st.executeUpdate(sql);}
根据传入的学生对象get方法获取到属性,作为删除条件传入delete语句,执行删除操作
小结:构造实体类(类属性和列属性对应)
构造操作的方法,操作其实不变,但是会多出传入传出student属性值的操作。(根据逻辑来操作就可以)
0 0
- JDBC学习(5)架构层次之间的数据的解析和传递
- fragment和activity之间的数据传递
- Fragment和Activity之间的数据传递
- Activity和Fragment之间的数据传递
- 应用之间的跳转和数据传递
- Activity 和 Fragment 之间的数据传递
- Fragment和Activity之间的数据传递
- PHP之间以及和C之间数据传递的格式
- Jsp和Servlet之间的数据共享(数据传递和数据调用)
- Servlet(Action)之间的数据传递
- Activity之间的数据传递
- 进程之间的数据传递
- Activity之间的数据传递
- frm之间的数据传递
- activity之间的数据传递
- Activity之间的数据传递
- Activity之间数据的传递
- Activity之间的数据传递
- mysql 带有无参数的存储过程
- AAC音频格式(把AAC打包成ADTS)
- 数据结构实验:连通分量个数
- 几个数论
- MVC控制器和视图间的数据传递
- JDBC学习(5)架构层次之间的数据的解析和传递
- Androi怎么根据url现实图片
- Java的反射
- [Shell]awk内置函数介绍
- WPF 样式
- 设计模式六大原则——开闭原则(OCP,Open Close Principle)
- 7.js数据类型转换1
- Uva16009 POJ 1906 Three Powers 数论 玄学找规律题 高精
- Fragment中调用父Activity中方法的简单方式