Heim > Java > Java-Tutorial > Hauptteil

servlet的dao层怎么写

(*-*)浩
Freigeben: 2019-05-16 14:18:11
Original
7654 人浏览过

dao层:dao层叫数据访问层,全称为data access object,属于一种比较底层,比较基础的操作,具体到对于某个表、某个实体的增删改查。

推荐课程:Java教程

servlet的dao层怎么写

Dao层 
先声明一个接口类,类里声明一些将会用的方法, 
同一层内写一个实现这个接口类的类,重写接口类里的方法 

以实现Mybatis的写法
方法主要是处理数据的方法;

public interface IStuClassDao {
    //全表查询方法
    public List findAllStuClassInfo();
    //classID查询
    public Map findStuClassById(int classId) ;
    //增加方法
    public void addStuClassById(Stuclass sc) ;
    //更新方法
    public void updateStuClassById(Stuclass sc) ;
    //查询方法
    public String findClassNamesByIds(String ids);
}
Nach dem Login kopieren

以对于user的操作为例进行说明: 

未实现Mybatis的写法

AnimalDAO:

package DAO;


import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;


import util.JDBCUtil;
import entry.Animal;
/**
 * 对数据库进行操作
 * @author dell-
 *
 */
public class AnimalDAO {


	//添加动物信息
	public void addAnimal(Animal animal){
		//1建立连接
		Connection conn= JDBCUtil.getConnection();
		//2创建sql语句
		String sql = "insert into animal (aid,aname,atime)values(?,?,?)";
		//3创建sql执行对象
		PreparedStatement ps =null;
		try {
			ps=conn.prepareStatement(sql);
			ps.setInt(1, animal.getAid());
			ps.setString(2, animal.getAname());
			ps.setDate(3, new java.sql.Date(animal.getAtime().getTime()));
			ps.executeUpdate();
		} catch (SQLException e) {
			e.printStackTrace();
		}finally{
		JDBCUtil.release(null,ps,conn);
		}
	}
	//查询所有信息
	public List getAll(){
		List list = new ArrayList();
		//1连接数据库
		Connection conn = JDBCUtil.getConnection();
		//2拼装sql
		String sql="select * from animal";
		//3创建sql执行对象
		PreparedStatement ps =null;
		ResultSet rs = null;
		try {
			ps = conn.prepareStatement(sql);
			rs=ps.executeQuery();
			while(rs.next()){
				Animal animal = new Animal();
				animal.setAid(rs.getInt("aid"));
				animal.setAname(rs.getString("aname"));
				animal.setAtime(rs.getDate("atime"));
				list.add(animal);
			}
		} catch (SQLException e) {
			e.printStackTrace();
		}finally{
			JDBCUtil.release(rs, ps, conn);
		}

		return list;
	}
	//通过aid 删除动物信息
	public void deleteAnimal(int aid){
		//1建立数据库连接
		Connection conn = JDBCUtil.getConnection();
		//2拼装sql
		String sql = "delete from animal where aid=?";
		//3创建sql执行对象
		PreparedStatement ps =null;
		try {
		ps = conn.prepareStatement(sql);
		ps.setInt(1, aid);
		ps.executeUpdate();
		} catch (SQLException e) {
		e.printStackTrace();
		}finally{
		JDBCUtil.release(null, ps, conn);
		}
		}
		//通过aid修改动物信息
		public void updateAnimal(Animal animal){
			//1建立连接
			Connection conn = JDBCUtil.getConnection();
			//2拼装sql
			String sql = "update animal set aname=?,atime=? where aid=?";
			//3创建sql执行对象
			PreparedStatement ps = null;
		try {
			ps = conn.prepareStatement(sql);
			ps.setString(1, animal.getAname());
			ps.setDate(2, new java.sql.Date(animal.getAtime().getTime()));
			ps.setInt(3, animal.getAid());
			ps.executeUpdate();
		} catch (SQLException e) {
			e.printStackTrace();
		}finally{
			JDBCUtil.release(null, ps, conn);
		}
	}
	public Animal getAnimalByid(int aid){
		//1链接数据库
		Connection conn= JDBCUtil.getConnection();
		//2创建sql语句
		String sql = "select * from animal where aid=?";
		//3创建sql执行对象
		PreparedStatement ps = null;
		ResultSet rs = null;
		try {
			ps = conn.prepareStatement(sql);
			ps.setInt(1, aid);
			rs = ps.executeQuery();
			if(rs.next()){
				Animal animal = new Animal();
				animal.setAid(rs.getInt("aid"));
				animal.setAname(rs.getString("aname"));
				animal.setAtime(rs.getDate("atime"));
				return animal;
			}
		} catch (SQLException e) {
		// TODO Auto-generated catch block
			e.printStackTrace();
		}finally{
			JDBCUtil.release(rs, ps, conn);
		}
		return null;
	}
}
Nach dem Login kopieren

以上是servlet的dao层怎么写的详细内容。更多信息请关注PHP中文网其他相关文章!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!