mysql+jsp+servlet 增删改查实例

2024-09-01 01:38

本文主要是介绍mysql+jsp+servlet 增删改查实例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

采用简单的MVC设计模式,M(模型层) -> Address.java 里面包含id,name,street,city,state,zip 等相关属性和set,get方法

     V(视图层) -> 主要指jsp页面,包含list.jsp,add.jsp,edit.jsp

     C(控制层) -> 这里只用一个servlet实现其增删改查(简单明了,方便理解),并没有用业务层的那套          service+serviceImp

 

项目目录:

 

 

 

相关的mysql数据库代码:

create database addr;
use addr;
create table address(
id int primary key auto_increment,
name varchar(20),
street varchar(20),
city varchar(20),
state varchar(20),
zip varchar(20)
);

insert into address(name,street,city,state,zip) values ('AAA','永宁街','西安','aa','1101');
insert into address(name,street,city,state,zip) values ('BBB','嘉定街','上海','bb','1102');
insert into address(name,street,city,state,zip) values ('CCC','福寿街','天津','cc','1103');
insert into address(name,street,city,state,zip) values ('DDD','回民街','北京','dd','1104');
insert into address(name,street,city,state,zip) values ('EEE','健康街','武汉','ee','1105');

 

根据数据库表,我们首先创建一个实体(domain)类:Address.java, 。这里我们就不贴图展示了

 

然后创建JdbcUtil.java 主要用来连接mysql数据库:

public class JdbcUtil {
static{
try {
Class.forName("com.mysql.jdbc.Driver");
} catch (Exception e) {
e.printStackTrace();
}
}
public static Connection getConnection() throws SQLException{

String dbUrl="jdbc:mysql://localhost:3306/addr?useUnicode=true&characterEncoding=utf8";
String dbUser="root";
String dbPassword="1101";

return DriverManager.getConnection(dbUrl,dbUser,dbPassword);

}

public static void close(Statement stmt,Connection conn) throws SQLException{
stmt.close();
conn.close();
}
}

当然代码JdbcUtil的代码可进行适当优化

注意:要修改成你们mysql的用户名和密码,

 

Dao层(数据访问层)代码编写

public class AddressDao {
//增加
public void add(Address address){
try {
   Connection conn = JdbcUtil.getConnection();
   PreparedStatement pstmt = conn.prepareStatement("insert into address(name,street,city,state,zip) values(?,?,?,?,?)");
   pstmt.setString(1,address.getName());
   pstmt.setString(2,address.getStreet());
   pstmt.setString(3,address.getCity());
   pstmt.setString(4,address.getState() );
   pstmt.setString(5,address.getZip() );
   pstmt.executeUpdate();
  JdbcUtil.close(pstmt, conn);

   } catch (SQLException e) {
  e.printStackTrace();
  }
}

//删除
public void delete(int id){
try{
    Connection conn = JdbcUtil.getConnection();
    PreparedStatement pstmt = conn.prepareStatement("delete from address where id = ?");
    pstmt.setInt(1, id);
    pstmt.executeUpdate();
   JdbcUtil.close(pstmt, conn);
   }catch(SQLException e){
   e.printStackTrace();
   throw new RuntimeException();
  }
}

//修改
public void update(Address address){
try {
   Connection conn = JdbcUtil.getConnection();
   PreparedStatement pstmt = conn.prepareStatement("update address set name = ?,street = ?,city =? ,state =?,zip= ? where id = ?");
   pstmt.setInt(6, address.getId());
   pstmt.setString(1,address.getName());
   pstmt.setString(2,address.getStreet());
   pstmt.setString(3,address.getCity());
   pstmt.setString(4,address.getState());
   pstmt.setString(5,address.getZip());

   pstmt.executeUpdate();
  JdbcUtil.close(pstmt, conn);

  } catch (SQLException e) {
 e.printStackTrace();
 throw new RuntimeException();
 }
}

//查询
public List<Address> findAll(){
List<Address> list = new ArrayList<Address>();
try{
  Connection conn = JdbcUtil.getConnection();
   PreparedStatement pstmt = conn.prepareStatement("select * from address");
   ResultSet rs = pstmt.executeQuery();
   while(rs.next()){
   Address address = new Address();
   address.setId(rs.getInt(1));
   address.setCity(rs.getString(4));
   address.setStreet(rs.getString(3));
   address.setState(rs.getString(5));
   address.setName(rs.getString(2));
   address.setZip(rs.getString(6));
   list.add(address);
  }
   JdbcUtil.close(pstmt, conn);
  }catch(SQLException e){
  e.printStackTrace();
   throw new RuntimeException();
  }
 return list;
}

//根据id查询
public Address findById(int id){
Address address = new Address();
try{
   Connection conn = JdbcUtil.getConnection();
   PreparedStatement pstmt = conn.prepareStatement("select * from address where id="+id);
   ResultSet rs = pstmt.executeQuery();
  if(rs.next()){
   address.setId(rs.getInt(1));
   address.setCity(rs.getString(4));
   address.setStreet(rs.getString(3));
   address.setState(rs.getString(5));
   address.setName(rs.getString(2));
   address.setZip(rs.getString(6));
  }
  JdbcUtil.close(pstmt, conn);
  }catch(SQLException e){
  e.printStackTrace();
  throw new RuntimeException();
   }
   return address;
 }
}

 

servlet代码编写

public class AddressServlet extends HttpServlet {
// 注入dao
private AddressDao addressDao = new AddressDao();

protected void doGet(HttpServletRequest request, HttpServletResponse response) 
throws ServletException, IOException {
//设置编码,很重要,否则页面提交,中文会出现乱码
request.setCharacterEncoding("UTF-8");
response.setCharacterEncoding("utf-8");
//设置路径
String path = "list.jsp";
String method = request.getParameter("method");
//若请求的url有list
if (("list").equals(method)) {
List<Address> list = addressDao.findAll();
request.setAttribute("list", list);
}
else if (method.equals("add")) {

//注入Address实体类
Address address = new Address();
//获取参数
String name = request.getParameter("name");
String street = request.getParameter("street");
String city = request.getParameter("city");
String state = request.getParameter("state");
String zip = request.getParameter("zip");
//设置增加的属性
address.setName(name);
address.setStreet(street);
address.setCity(city);
address.setState(state);
address.setZip(zip);

addressDao.add(address);
<!--把新加入的数据重新加载

这点特别重要,否则刷新页面会报空指针异常

-->
path = "AddressServlet?method=list";
}

else if (method.equals("delete")) {

//根据id来删除
int id = Integer.parseInt(request.getParameter("id"));
addressDao.delete(id);
//要重新查询一遍,否则会报空指针
path = "AddressServlet?method=list";
}
//跳转编辑页面url请求如下:


else if (method.equals("toedit")) {
int id = Integer.parseInt(request.getParameter("id"));
Address address = addressDao.findById(id);
path = "edit.jsp";
request.setAttribute("address", address);
}

else if (method.equals("edit")) {

//根据id修改
int id = Integer.parseInt(request.getParameter("id"));

String name = request.getParameter("name");
String street = request.getParameter("street");
String city = request.getParameter("city");
String state = request.getParameter("state");
String zip = request.getParameter("zip");

Address address = new Address();
address.setId(id);
address.setName(name);
address.setStreet(street);
address.setCity(city);
address.setState(state);
address.setZip(zip);

addressDao.update(address);
//把新加入的数据重新加载
path = "AddressServlet?method=list";
 }
  request.getRequestDispatcher(path).forward(request, response);
}
 

add.jsp页面

 <form action="AddressServlet?method=add" method="post">
      Name:<input type="text" name="name"/><br>
      Street:<input type="text" name="street"/><br>
     City:<input type="text" name="city"/><br>
     State:<input type="text" name="state"/><br>
     Zip:<input type="text" name="zip"/><br>
    <input type="submit" name="add"/><br>
 </form>

 

edit.jsp页面

 

//获取request中的address对象
<% Address address = (Address)request.getAttribute("address"); %>
 <form action="AddressServlet?method=edit" method="post">

<input type="hidden"      name="id"value="<%=address.getId()%>"><br>
   Name:<input type="text"   name="name" value="<%=address.getName()%>"><br>
   Street:<input type="text"   name="street"  value="<%=address.getStreet()%>"><br>
   City:<input type="text"   name="city" value="<%=address.getCity()%>"><br>
   State:<input type="text"  name="state" value="<%=address.getState()%>"><br>
   Zip:<input type="text"    name="zip"    value="<%=address.getZip()%>"><br>
  <input type="submit"  name="Edit" value="编辑"/><br>
 </form>

list页面

<body><br>
<table border="1">
<tr>
<td>Name</td>
<td>Street</td>
<td>City</td>
<td>State</td>
<td>Zip</td>
<td><center>Options</center></td>
<tr>
<%
List<Address> list = (List<Address>)request.getAttribute("list");
for(Address a :list){

%>
<tr>
<td><%=a.getName()%></td>
<td><%=a.getStreet() %></td>
<td> <%=a.getCity()%></td>
<td><%=a.getState()%></td>
<td><%=a.getZip() %></td>
<td>
<a href="AddressServlet?method=delete&id=<%=a.getId() %>">Delete</a>&nbsp;
<a href="AddressServlet?method=toedit&id=<%=a.getId() %>">Edit</a>
</td>

</tr>
<%}%>
</table>
<a href="add.jsp">Add</a>

 

最后若觉得请求url名字过长,可在index.jsp页面设置默认跳转<jsp:forward page="AddressServlet?method=list"></jsp:forward>

 

主要重点在于增删改查的逻辑,方便对这些知识掌握不牢的同学进行理解,当然有兴趣的同学代可以继续优化代码,使之更加符合项目要求的MVC设计思想,增加service以及serviceImp,daoImp等等,以后会出基于ssh三层架构的javaWeb,欢迎批评指正

源代码下载

 

 

这篇关于mysql+jsp+servlet 增删改查实例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125588

相关文章

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

MySQL高性能优化规范

前言:      笔者最近上班途中突然想丰富下自己的数据库优化技能。于是在查阅了多篇文章后,总结出了这篇! 数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,并且最后不要超过32个字符 临时库表必须以tmp_为前缀并以日期为后缀,备份

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

[MySQL表的增删改查-进阶]

🌈个人主页:努力学编程’ ⛅个人推荐: c语言从初阶到进阶 JavaEE详解 数据结构 ⚡学好数据结构,刷题刻不容缓:点击一起刷题 🌙心灵鸡汤:总有人要赢,为什么不能是我呢 💻💻💻数据库约束 🔭🔭🔭约束类型 not null: 指示某列不能存储 NULL 值unique: 保证某列的每行必须有唯一的值default: 规定没有给列赋值时的默认值.primary key:

MySQL-CRUD入门1

文章目录 认识配置文件client节点mysql节点mysqld节点 数据的添加(Create)添加一行数据添加多行数据两种添加数据的效率对比 数据的查询(Retrieve)全列查询指定列查询查询中带有表达式关于字面量关于as重命名 临时表引入distinct去重order by 排序关于NULL 认识配置文件 在我们的MySQL服务安装好了之后, 会有一个配置文件, 也就

Java 连接Sql sever 2008

Java 连接Sql sever 2008 /Sql sever 2008 R2 import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class TestJDBC