数据库编程(二)

关于上篇博文,依然是有需要改进的地方,比如它不能实现代码复用。在这里我们可以试着采用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);
        }
    }

}

程序执行结果为:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值