struts2的增删改查

原struts2的增删改查

第一步:导jar包

第二步,因为struts2也是mvc模式,所以也要在web.xml里配置内,需要配置的内容如下:

<?xml version="1.0" encoding="UTF-8"?>


    <filter-name>struts2</filter-name>
    <!-- 过滤器支持的struts2类 -->
    <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>

<filter-mapping>
 <!-- 过滤器的名字 -->
    <filter-name>struts2</filter-name>
    <!-- 过滤器拦截文件路径的名字 -->
    <url-pattern>/*</url-pattern>
</filter-mapping>
index.jsp

第三步;

建vo 数据库中对应的字段,get set方法 并且在src目录下建一个struts.xml并且配置如下内容:

<?xml version="1.0" encoding="UTF-8" ?> user!findAll /list.jsp /update.jsp

第四步:写dao,所有的方法都没有作封装,为了复习以前的知识哦

package com.test.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 com.test.vo.User;

public class UserDao {

/**

  • 添加

  • @param user
    */
    public void add(User user){
    Connection conn = null;
    PreparedStatement ps =null;
    try {
    Class.forName(“com.mysql.jdbc.Driver”);
    conn = DriverManager.getConnection(“jdbc:mysql://localhost/test”, “root”, “root”);
    String sql = “insert into user values(null,?,?,?,?,?,?)”;
    ps = conn.prepareStatement(sql);
    ps.setString(1, user.getName());
    ps.setString(2, user.getPassword());
    ps.setInt(3, user.getAge());
    ps.setString(4, user.getPhone());
    ps.setString(5, user.getEmail());
    ps.setString(6, user.getQq());
    System.out.println(ps.executeUpdate()+“已保存”);
    } catch (ClassNotFoundException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    } catch (SQLException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    }finally{

    try {
    if(ps!=null){
    ps.close();
    }
    if(conn!=null){
    conn.close();
    }
    } catch (SQLException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();

}

}

}

public List findAll(){
Connection conn = null;
PreparedStatement ps =null;
ResultSet rs =null;
List list = new ArrayList();
try {
Class.forName(“com.mysql.jdbc.Driver”);
conn = DriverManager.getConnection(“jdbc:mysql://localhost/test”, “root”, “root”);
String sql=“select * from user”;
ps = conn.prepareStatement(sql);
rs = ps.executeQuery();

while(rs.next()){
User u = new User();
u.setId(rs.getInt(“id”));
u.setName(rs.getString(“name”));
u.setPassword(rs.getString(“password”));
u.setAge(rs.getInt(“age”));
u.setPhone(rs.getString(“phone”));
u.setEmail(rs.getString(“email”));
u.setQq(rs.getString(“qq”));
list.add(u);

}
}catch(Exception e){

e.printStackTrace();
}finally{

try {
if(rs!=null){
rs.close();
}
if(ps!=null){
ps.close();
}
if(conn!=null){
conn.close();
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();

}
}

return list;
}

/**

  • 删除
  • @param id
    */

public void del(int id){
Connection conn = null;
PreparedStatement ps = null;
try {
Class.forName(“com.mysql.jdbc.Driver”);
conn = DriverManager.getConnection(“jdbc:mysql://localhost/test”, “root”, “root”);
String sql = “delete from user where id=?”;
ps = conn.prepareStatement(sql);
ps.setInt(1, id);
System.out.println(ps.executeUpdate()+“条数据删除”);

} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
try {
if(ps!=null){
ps.close();
}
if(conn!=null){
conn.close();
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();

}
}

}

/**

  • 预查询
  • @param id
  • @return
    */
    public User perUpdate(int id){
    Connection conn = null;
    PreparedStatement ps = null;
    ResultSet rs = null;
    User u =null;
    try {
    Class.forName(“com.mysql.jdbc.Driver”);
    conn = DriverManager.getConnection(“jdbc:mysql://localhost/test”, “root”, “root”);
    String sql=“select * from user where id=?”;
    ps = conn.prepareStatement(sql);
    ps.setInt(1, id);
    rs = ps.executeQuery();
    while(rs.next()){
    u =new User();
    u.setId(rs.getInt(“id”));
    u.setName(rs.getString(“name”));
    u.setPassword(rs.getString(“password”));
    u.setAge(rs.getInt(“age”));
    u.setPhone(rs.getString(“phone”));
    u.setEmail(rs.getString(“email”));
    u.setQq(rs.getString(“qq”));
    }

} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

return u;
}

/**

  • 修改
  • @param id
    */
    public void update(User user){
    Connection conn = null;
    PreparedStatement ps = null;
    try {
    Class.forName(“com.mysql.jdbc.Driver”);
    conn = DriverManager.getConnection(“jdbc:mysql://localhost/test”, “root”, “root”);
    String sql=“update user set name=?,password=?,age=?,phone=?,email=?,qq=? where id=?”;
    ps = conn.prepareStatement(sql);
    ps.setString(1, user.getName());
    ps.setString(2, user.getPassword());
    ps.setInt(3,user.getAge());
    ps.setString(4, user.getPhone());
    ps.setString(5, user.getEmail());
    ps.setString(6, user.getQq());
    ps.setInt(7, user.getId());
    System.out.println(ps.executeUpdate()+“条数据修改”);
    } catch (ClassNotFoundException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    } catch (SQLException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    }

}

}

第五步:写action 记住action里面的属性一定要有get方法

package com.test.Action;

import java.util.List;

import com.test.Dao.UserDao;
import com.test.vo.User;

public class UserAction {

private UserDao us = new UserDao();
private User user;
private List list;
private int id;

/**

  • ����û�
  • @return
    */
    public String add(){
    us.add(user);
    return “list”;

}

/**

  • 查录所有记录
  • @return
    */
    public String findAll(){

list = us.findAll();
return “success”;
}

/**

  • 删除
  • @return
    */
    public String del(){
    us.del(id);
    return “list”;

}

/**

  • 预修改
  • @return
    */

public String perUpdate(){
user = us.perUpdate(id);
return “preUpdate”;
}
/**

  • 修改
  • @return
    */
    public String update(){
    us.update(user);
    return “list”;

}

public UserDao getUs() {
return us;
}

public void setUs(UserDao us) {
this.us = us;
}

public User getUser() {
return user;
}

public void setUser(User user) {
this.user = user;
}

public List getList() {
return list;
}

public void setList(List list) {
this.list = list;
}

public int getId() {
return id;
}

public void setId(int id) {
this.id = id;
}

}

第六步;写.jsp页面

添加页面:

用户名:
密码:
年龄:
电话:
Email:
QQ:

展示页面:

姓名年龄电话sEmailQQ详情

修改页面:

用户名:
密码:
年龄:
电话:
Email:
QQ:

1.2 运行机制
1)客户端在浏览器中输入一个url地址。
2)这个url请求通过http协议发送给tomcat。
3)tomcat根据url找到对应项目里面的web.xml文件。
4)在web.xml里面会发现有struts2的配置。
5)然后会找到struts2对应的struts.xml配置文件。
6)根据url解析struts.xml配置文件就会找到对应的class。
7)调用完class返回一个字String,根据struts.xml返回到对应的jsp。

想要学习的可以关注我一下哦,我一般写的比较仔细。因为我是一个菜鸟,希望大家多提意见,代码有什么可以优化的地方,希望多提意见~~~~

**

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值