热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java简单增删改查_无框架JavaWeb简单增删改查,纯jsp小练习

刚入门javaweb,自己做个jsp小练习供以后参考,本文纯jsp与后台JDBC增删改查的操作,还有一些瑕疵需要修复(当然大佬就不要挑我这个小白的毛病了,小白正在不断学习中.

刚入门javaweb,自己做个jsp小练习供以后参考,本文纯jsp与后台JDBC增删改查的操作,还有一些瑕疵需要修复(当然大佬就不要挑我这个小白的毛病了,小白正在不断学习中....).

写这篇文章的目的是为了记录 怎样把数据从前台传输到后端数据库,也是对自己学习的一次小总结, 不足之处多多见谅~~~

好啦,开始整吧

(1) 数据库(mysql)只有一张表 emp

6a45da11d7f017677d8ca8a862ed2afc.png

(2) eclipse建立web项目(不使用maven)   具体结构如下:

60f48a5d4e34b52df5dd587b32c6b384.png

4e1a0581786d5dfb1cf4af982b35be58.png

(3)上代码

后台代码 :

(3.1) 先写好连接数据库的配置文件,配置文件的作用就是方便更改我们数据库的账户密码,数据库驱动等

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 jdbc.name =root2 jdbc.password =root3 jdbc.url = jdbc:mysql://localhost:3306/cust?useSSL=false

4 jdbc.driver = com.mysql.jdbc.Driver

jdbc.properties

(3.2) util包下的工具类

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 packagecn.ssq.util;2

3 importjava.io.IOException;4 importjava.io.InputStream;5 importjava.util.Properties;6

7 public classProsutil {8

9 private staticProperties properties;10

11 static{12 properties = newProperties();13 //引入配置文件

14 InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("jdbc.properties");15

16 try{17 properties.load(is);18 } catch(IOException e) {19 //TODO Auto-generated catch block

20 e.printStackTrace();21 }22

23 }24 public staticString getStringByKey(String key){25 return properties.getProperty(key,"");26 }27 }

Prosutil.java(调用配置文件)

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 packagecn.ssq.util;2

3 importjava.sql.Connection;4 importjava.sql.DriverManager;5 importjava.sql.PreparedStatement;6 importjava.sql.ResultSet;7 importjava.sql.SQLException;8

9 public classDButil {10 //通过配置文件读取数据库的相关配置

11 private static final String URL = Prosutil.getStringByKey("jdbc.url");12 private static final String DRIVER = Prosutil.getStringByKey("jdbc.driver");13 private static final String USERNAME = Prosutil.getStringByKey("jdbc.name");14 private static final String PASSWORD = Prosutil.getStringByKey("jdbc.password");15 //建立数据库连接

16 public staticConnection getConn(){17 Connection conn = null;18

19 try{20 Class.forName(DRIVER);21 conn =DriverManager.getConnection(URL,USERNAME,PASSWORD);22 } catch(ClassNotFoundException e) {23

24 e.printStackTrace();25 } catch(SQLException e) {26

27 e.printStackTrace();28 }29 returnconn;30 }31

32 //关闭数据库连接

33 public static voidCloseAll(ResultSet rs,PreparedStatement ps, Connection conn){34

35 try{36 if(rs != null){37 rs.close();38 rs = null;39 }40 if(ps !=null){41 ps.close();42 ps = null;43 }44 if(conn!=null){45 conn.close();46 conn = null;47 }48 } catch(SQLException e) {49

50 e.printStackTrace();51 }52

53 }54

55 //private static ResultSet rs;

56 private staticPreparedStatement ps;57 private staticConnection conn;58 /**

59 * 增删改60 *@return

61 */

62 public static intexecuUpdate(String sql ,Object...param){63 int num = 0;64 conn =getConn();65 try{66 PreparedStatement ps =conn.prepareStatement(sql);67 for (int i = 0; i

74 e.printStackTrace();75 }finally{76 CloseAll(null,ps,conn);77 }78 returnnum;79 }80 /**

81 * 通用查询82 */

83 public staticResultSet execuQuery(String sql,Object...param){84 ResultSet rs = null;85 conn =getConn();86 try{87 PreparedStatement ps =conn.prepareStatement(sql);88 for (int i = 0; i

95 e.printStackTrace();96 }97 returnrs;98

99 }100 }

DButil.java(数据库工具类)

(3.3)entity包下的实体类

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 packagecn.ssq.entity;2

3 public classEmp {4

5 private intid;6 privateString name;7 privateString gender;8 privateString tel;9 privateString username;10 privateString password;11 public intgetId() {12 returnid;13 }14 public void setId(intid) {15 this.id =id;16 }17 publicString getName() {18 returnname;19 }20 public voidsetName(String name) {21 this.name =name;22 }23 publicString getGender() {24 returngender;25 }26 public voidsetGender(String gender) {27 this.gender =gender;28 }29 publicString getTel() {30 returntel;31 }32 public voidsetTel(String tel) {33 this.tel =tel;34 }35 publicString getUsername() {36 returnusername;37 }38 public voidsetUsername(String username) {39 this.username =username;40 }41 publicString getPassword() {42 returnpassword;43 }44 public voidsetPassword(String password) {45 this.password =password;46 }47 publicEmp() {48 super();49

50 }51 public Emp(intid, String name, String gender, String tel, String username,52 String password) {53 super();54 this.id =id;55 this.name =name;56 this.gender =gender;57 this.tel =tel;58 this.username =username;59 this.password =password;60 }61

62 }

Emp.java

(3.4)dao包下的接口和接口实现类

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 packagecn.ssq.dao;2

3 importjava.util.List;4

5 importcn.ssq.entity.Emp;6

7 public interfaceEmpDao {8

9 intsave(Emp emp);10 int delete(intid);11 intupdate(Emp emp);12 ListfindAll();13 Emp getEmpById(intid);14

15 }

EmpDao.java

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 packagecn.ssq.dao.impl;2

3 importjava.sql.ResultSet;4 importjava.sql.SQLException;5 importjava.util.ArrayList;6 importjava.util.List;7

8 importcn.ssq.dao.EmpDao;9 importcn.ssq.entity.Emp;10 importcn.ssq.util.DButil;11

12 public class EmpDaoImpl implementsEmpDao {13

14 Emp emp = null;15 /**

16 * 添加17 */

18 @Override19 public intsave(Emp emp) {20 String sql = "insert into customer(id,name,gender,tel,username,password)values(?,?,?,?,?,?)";21 returnDButil.execuUpdate(sql, emp.getId(),emp.getName(),emp.getGender(),emp.getTel(),emp.getUsername(),emp.getPassword());22 }23

24 /**

25 * 删除26 */

27 @Override28 public int delete(intid) {29 String sql = "delete from customer where id = ?";30 returnDButil.execuUpdate(sql, id);31 }32

33 /**

34 * 修改35 */

36 @Override37 public intupdate(Emp emp) {38 String sql = "update customer set name = ?,gender=?,tel=?,username=?,password=? where id=?";39 returnDButil.execuUpdate(sql, emp.getName(),emp.getGender(),emp.getTel(),emp.getUsername(),emp.getPassword(),emp.getId());40 }41

42 /**

43 * 查询44 */

45 @Override46 public ListfindAll() {47 List list = new ArrayList();48 String sql = "select * from customer";49 ResultSet rs =DButil.execuQuery(sql);50 try{51 while(rs.next()){52 emp = newEmp();53 emp.setId(rs.getInt("id"));54 emp.setGender(rs.getString("gender"));55 emp.setName(rs.getString("name"));56 emp.setTel(rs.getString("tel"));57 emp.setUsername(rs.getString("username"));58 emp.setPassword(rs.getString("password"));59 list.add(emp);60 }61 } catch(SQLException e) {62

63 e.printStackTrace();64 }65

66 returnlist;67 }68

69 //根据id查询

70 @Override71 public Emp getEmpById(intid) {72 Emp emp=null;73 String sql = "select * from customer where id = ?";74 ResultSet rs =DButil.execuQuery(sql, id);75 try{76 while(rs.next()){77 emp = newEmp();78 emp.setGender(rs.getString("gender"));79 emp.setName(rs.getString("name"));80 emp.setPassword(rs.getString("password"));81 emp.setUsername(rs.getString("username"));82 emp.setTel(rs.getString("tel"));83 }84 } catch(SQLException e) {85

86 e.printStackTrace();87 }88

89

90 returnemp;91 }92

93 }

EmpDaoImpl.java

(3.5)service包下的业务层

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 packagecn.ssq.service;2

3 importjava.util.List;4

5 importcn.ssq.entity.Emp;6

7 public interfaceServiceDao {8

9 booleansave(Emp emp);10 boolean delete(intid);11 booleanupdate(Emp emp);12 ListfindAll();13 Emp getEmpById(intid);14 }

ServiceDao.java

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 packagecn.ssq.service.impl;2

3 importjava.util.List;4

5 importcn.ssq.dao.EmpDao;6 importcn.ssq.dao.impl.EmpDaoImpl;7 importcn.ssq.entity.Emp;8 importcn.ssq.service.ServiceDao;9 /**

10 * 业务调用11 *@author北城墨白12 *13 * 2018年12月13日14 */

15 public class ServiceDaoImpl implementsServiceDao {16

17 EmpDao dao = newEmpDaoImpl();18 @Override19 public booleansave(Emp emp) {20

21 return dao.save(emp)>0;22 }23

24 @Override25 public boolean delete(intid) {26

27 return dao.delete(id)>0;28 }29

30 @Override31 public booleanupdate(Emp emp) {32 return dao.update(emp)>0;33 }34

35 @Override36 public ListfindAll() {37 returndao.findAll();38 }39

40 @Override41 public Emp getEmpById(intid) {42

43 returndao.getEmpById(id);44 }45

46 }

ServiceDaoImpl.java

到这里,基本的底层代码已经结束了,剩下的就是前端jsp的编写了(记得导包,jar包的下载地址问度娘就可以了,在这我就不啰嗦了)

(3.6)WebContent文件夹下的jsp页面代码

前端代码:

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1

2

3

4

5

6

7 pageEncoding="UTF-8"%>

8

9

10

11

12

显示页面信息

13

14

15

16 request.setCharacterEncoding("UTF-8");17 response.setCharacterEncoding("utf-8");18 ServiceDao service = newServiceDaoImpl();19 List list =service.findAll();20 %>

21 添加新员工

22

23

24

员工编号

25

姓名

26

性别

27

电话

28

用户名

29

密码

30

操作

31

32

33 for(Emp e:list){34 %>

35

36

37

38

39

40

41

42

修改 删除

44

45

46

47

48

49

index.jsp(首页查询显示界面)

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1

2

3

4 pageEncoding="UTF-8"%>

5

6

7

8

9

Insert title here

10

11

12

13 request.setCharacterEncoding("UTF-8");14 response.setCharacterEncoding("utf-8");15 String did = request.getParameter("did");16 int empid =Integer.valueOf(did);17 ServiceDao service = newServiceDaoImpl();18

19 if(service.delete(empid)==true){20 response.sendRedirect("index.jsp");21 }else{22 response.sendRedirect("index.jsp");23 }24 %>

25

26

delete.jsp(删除处理)

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1

2

3

4

5 pageEncoding="UTF-8"%>

6

7

8

9

10

Insert title here

11

12

13

14

15 String nid = request.getParameter("nid");16 Emp e = null;17 ServiceDao service = newServiceDaoImpl();18 if(nid !=null){19 int eid =Integer.valueOf(nid);20 e =service.getEmpById(eid);21 }22

23 %>

24

25

员工信息

26

" method="post">

27 员工编号: ">(员工编号不可重复)

28 员工姓名: ">

29 员工性别: ">

30 员工电话: ">

31      用户名:">

32 员工密码: ">

33

34

35

36

insert_update.jsp(添加和修改共用一个显示页面)

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1

2

3

4

5 pageEncoding="UTF-8"%>

6

7

8

9

10

Insert title here

11

12

13

14 request.setCharacterEncoding("UTF-8");15 response.setCharacterEncoding("utf-8");16 String id = request.getParameter("nid");17 String name=request.getParameter("name");18 String gender=request.getParameter("gender");19 String tel = request.getParameter("tel");20 String username=request.getParameter("username");21 String password=request.getParameter("password");22

23 Emp emp = newEmp();24

25 int eid =Integer.valueOf(id);26

27 emp.setId(eid);28 emp.setName(name);29 emp.setGender(gender);30 emp.setTel(tel);31 emp.setUsername(username);32 emp.setPassword(password);33

34 ServiceDao service = newServiceDaoImpl();35 if(service.save(emp)==true){36 response.sendRedirect("index.jsp");37 }else{38 response.sendRedirect("insert_update.jsp");39 }40 %>

41

42

doadd.jsp(添加处理)

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1

2

3

4

5 pageEncoding="UTF-8"%>

6

7

8

9

10

Insert title here

11

12

13

14 request.setCharacterEncoding("UTF-8");15 response.setCharacterEncoding("utf-8");16 String id = request.getParameter("nid");17 String name=request.getParameter("name");18 String gender=request.getParameter("gender");19 String tel = request.getParameter("tel");20 String username=request.getParameter("username");21 String password=request.getParameter("password");22

23 Emp emp = newEmp();24

25 int eid =Integer.valueOf(id);26

27 emp.setId(eid);28 emp.setName(name);29 emp.setGender(gender);30 emp.setTel(tel);31 emp.setUsername(username);32 emp.setPassword(password);33

34 ServiceDao service = newServiceDaoImpl();35 if(service.update(emp)==true){36 response.sendRedirect("index.jsp");37 }else{38 response.sendRedirect("insert_update.jsp");39 }40 %>

41

42

doupdate.jsp(修改处理)

代码完毕!

(4)运行index.jsp页面就可以正常使用了,当然这个小练习没有实用性,只是对jsp知识点的一次小回顾,效果图如下 :

69b8d0d7e06a51df506b17cb36826bb3.png

e0501258e4d7755042e8ed23a0afe175.png

d71310c85f23e5e98482223d42be49e2.png

结束

小白希望能和大家多多交流,互相学习,毕竟学到老活到老嘛,啊不,活到老学到老,编程(码农)就是一步步慢慢来的,一起加油吧!



推荐阅读
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 在重复造轮子的情况下用ProxyServlet反向代理来减少工作量
    像不少公司内部不同团队都会自己研发自己工具产品,当各个产品逐渐成熟,到达了一定的发展瓶颈,同时每个产品都有着自己的入口,用户 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
  • Ihavethefollowingonhtml我在html上有以下内容<html><head><scriptsrc..3003_Tes ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 后台获取视图对应的字符串
    1.帮助类后台获取视图对应的字符串publicclassViewHelper{将View输出为字符串(注:不会执行对应的ac ... [详细]
  • 展开全部下面的代码是创建一个立方体Thisexamplescreatesanddisplaysasimplebox.#Thefirstlineloadstheinit_disp ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 标题: ... [详细]
  • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
author-avatar
手机用户2502912197
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有