DAO是Data Access Object数据访问接口,数据访问:顾名思义就是与数据库打交道。夹在业务逻辑与数据库资源中间。
在连接数据库过程当中,可以定义一个DAO接口,然后编写一个类来扩展这个DAO类来实现DAO接口中的方法。如:有一个用户表t_user:id(int) , username(varchar(255)) , password(varchar(255))
定义一个简单的JAVA类(VO):User
1
package cn.zhang.org.vo;
2data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
3data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class User
{
4
private String username;
5
private String password;
6data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String getUsername()
{
7
return username;
8
}
9data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setUsername(String username)
{
10
this.username = username;
11
}
12data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String getPassword()
{
13
return password;
14
}
15data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setPassword(String password)
{
16
this.password = password;
17
}
18
19
}
定义一个接口UserDAO
1
package cn.zhang.org.dao;
2data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
3
import cn.zhang.org.vo.User;
4data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
5data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public interface UserDAO
{
6
boolean isLogin(User user);
7
8
boolean RegUser(User user);
9
}
10data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
扩展这个接口,实现基本方法
1
ackage cn.zhang.org.imp;
2data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
3
import java.sql.Connection;
4
import java.sql.PreparedStatement;
5
import java.sql.ResultSet;
6
import java.sql.SQLException;
7data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
8
import cn.zhang.org.dao.UserDAO;
9
import cn.zhang.org.exception.MyRuntimeException;
10
import cn.zhang.org.factory.Factory;
11
import cn.zhang.org.vo.User;
12data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
13data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class UserDAOIMP implements UserDAO
{
14
private static final String ISLOGINSQL = "select count(*) from t_user where username = ? and password = ?";
15
private static final String INSERTUSER = "insert into t_user(user , password) values(? , ?)";
16data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public boolean isLogin(User user)
{
17
boolean islogin = false;
18
ResultSet rs = null;
19
PreparedStatement pstm = null;
20
Connection conn = Factory.getMySQLCONN().getConnection();
21data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
22
pstm = conn.prepareStatement(ISLOGINSQL);
23
pstm.setString(1, user.getUsername());
24
pstm.setString(2, user.getPassword());
25
rs = pstm.executeQuery();
26data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(rs.next())
{
27
int i = rs.getInt(1);
28data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(i>0)
{
29
islogin = true;
30
}
31
}
32data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (SQLException e)
{
33
throw new MyRuntimeException(e.getMessage(),e);
34data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
}finally
{
35
close(rs, pstm, conn);
36
}
37
return islogin;
38
}
39data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void close(ResultSet rs, PreparedStatement pstm, Connection conn)
{
40data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
41data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(rs!=null)
{
42
rs.close();
43
}
44data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (SQLException e)
{
45
throw new MyRuntimeException(e.getMessage(),e);
46
}
47
48data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
49data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(pstm!=null)
{
50
pstm.close();
51
}
52data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (SQLException e)
{
53
throw new MyRuntimeException(e.getMessage(),e);
54
}
55
56data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
57data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(conn!=null)
{
58
conn.close();
59
}
60data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (SQLException e)
{
61
throw new MyRuntimeException(e.getMessage(),e);
62
}
63
}
64data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public boolean RegUser(User user)
{
65
Connection conn = Factory.getMySQLCONN().getConnection();
66
boolean isreg = false;
67
PreparedStatement pstm = null;
68
ResultSet rs = null;
69data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
70
pstm = conn.prepareStatement(INSERTUSER);
71
pstm.setString(1, user.getUsername());
72
pstm.setString(2, user.getPassword());
73
int i = pstm.executeUpdate();
74data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(i > 0)
{
75
isreg = true;
76
}
77data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (SQLException e)
{
78
throw new MyRuntimeException(e.getMessage(),e);
79data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
}finally
{
80
close(rs, pstm, conn);
81
}
82
83
return isreg;
84
}
85data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
86
}