关于上篇博文,依然是有需要改进的地方,比如它不能实现代码复用。在这里我们可以试着采用MVC设计模式。
采用MVC设计模式有以下优点:耦合性低、重用性高、生命周期成本低(MVC使开发和维护用户接口的技术含量降低)、部署快、可维护性高、有利于软件工程化管理
以下程序是用来判断数据库表中学生的性别,并输出女生的相关信息
第一步:完成model层
package idv.honey.model;
public class StudentInfo
{
private String id;
private String name;
public StudentInfo()
{}
public StudentInfo(String id, String name)
{
this.id=id;
this.name=name;
}
public String getId()
{
return id;
}
public void setId(String id)
{
this.id=id;
}
public String getName()
{
return name;
}
public void setName(String name)
{
this.name=name;
}
@Override
public String toString()
{
return "famale:" + name + ", 身份证=" + id;
}
}
第二步:dao层的编写
注意这里的List包一定要导对
我发现直接复制上一篇博文中的主要代码时,eclipse并不会自动帮你导包,然而还不会报错
package idv.honey.dao;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import idv.honey.model.StudentInfo;
public class StudentDao
{
public StudentDao()
{
}
public List<StudentInfo> getStudentList()
{
List<StudentInfo> students=new ArrayList<>();
try
{
Class.forName("com.mysql.cj.jdbc.Driver");
Connection connection=DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/javase?serverTimezone=Asia/Shanghai",
"root", "lq111111");
String sql="SELECT id,name FROM test";
PreparedStatement state=connection.prepareStatement(sql);
ResultSet rs=state.executeQuery();
while(rs.next())
{
String id=rs.getString("id");
String name=rs.getString("name");
StudentInfo student1=new StudentInfo(id, name);
students.add(student1);
}
rs.close();
state.close();
connection.close();
}
catch(ClassNotFoundException e)
{
e.printStackTrace();
}
catch(SQLException e)
{
e.printStackTrace();
}
return students;
}
}
然后我们给出一个测试类
package idv.honey.test;
import java.util.ArrayList;
import java.util.List;
import idv.honey.dao.StudentDao;
import idv.honey.model.StudentInfo;
public class Test
{
public static void main(String[] args)
{
StudentDao dao=new StudentDao();
List<StudentInfo> studentList=dao.getStudentList();
List<StudentInfo> studentFemale=new ArrayList<StudentInfo>();
for(StudentInfo stu : studentList)
{
int sexType=Integer.valueOf(stu.getId().substring(16, 16 + 1));
if(sexType % 2 == 0)
{
studentFemale.add(stu);
}
}
for(StudentInfo stu : studentFemale)
{
System.out.println(stu);
}
}
}
程序执行结果为: