entity bean的作用是将与数据库交互的过程封装成对象,在servelet编写的过程中,只需要会写java,不必考虑与数据库交互细节。

实体类:

基本与数据库的表相对应,表示一个实在的对象。

例子:User类:

成员变量:私有属性

方法实现的功能:获取属性(可自动生成)、修改属性(可自动生成)

 package entity;
public class User { //定义private属性。
private String username;
private String password;
private String realname;
private int userType;
private int sex; public User() {
super();
} //user构造函数,创建一个新user对象
public User(String username, String password, String realname, int userType,
int sex) {
super();
this.username = username;
this.password = password;
this.realname = realname;
this.userType = userType;
this.sex = sex;
} //获取属性
public String getUsername() {
return username;
} //修改属性
public void setUsername(String usrname) {
this.username = usrname;
} //获取属性
public String getPassword() {
return password;
} //修改属性
public void setPassword(String password) {
this.password = password;
} //获取属性
public String getRealname() {
return realname;
} //修改属性
public void setRealname(String realname) {
this.realname = realname;
} //获取属性
public int getUserType() {
return userType;
} //修改属性
public void setUserType(int userType) {
this.userType = userType;
} //获取属性
public int getSex() {
return sex;
} //修改属性
public void setSex(int sex) {
this.sex = sex;
} }

管理类:

成员变量: 主键-对象 对应的哈希表,表示一个结果集。

方法:每个方法与一个sql语句相对应

因此new一个管理类的对象,可用于得到某条查询的结果集。

常见方法:

查询(select)语句:

JDBC:ResultSet rset = stmt.executeQuery(sql);

1、传入查询条件,返回一个对象结果集。(如查询所有用户)

2、如果是通过主键找唯一对象,则返回对象。(如通过user_id找唯一用户)

本函数也可用来判断是否已经存在此对象。

判断:JDBC:bool result = DBBean.hasRecord(sql);

3、判断结果集是否为空,从而判断是否满足给定条件。

插入(insert)语句:

JDBC:bool success=DBBean.update(sql);

1、传入user对象,插入user对象的所有信息。

因为数据库中主键不能重复,因此可能插入失败。(必须为新用户)

更新(update)语句:

JDBC:bool success = DBBean.update(sql);

1、传入user对象,传出是否更新成功信息。

要更新记录必须在数据库有原始记录,否则会更新失败。

删除(delete)语句:

JDBC:bool success = DBBean.delete(sql);

1、传入删除条件,传出删除是否成功信息

例子:UserMgr类

 package entity;

 import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.HashMap; import db.DBBean; public class UserMgr { private HashMap<String, User> userList; public UserMgr() {
super();
} /**
* 得到所有用户的列表
*
* @return
*/ //查询:传入查询条件,返回一个对象结果集。(如查询所有用户)
public HashMap getUserList() {
HashMap userList = new HashMap();
Connection conn = null;
Statement stmt = null;
ResultSet rset = null;
User user = null;
try {
conn = DBBean.getConnection();
String sql = "select * from Table_user";
stmt = conn.createStatement();
rset = stmt.executeQuery(sql);
while (rset.next()) {
user = new User(rset.getString("username"), "888888",
rset.getString("realname"), rset.getInt("userType"),
rset.getInt("sex")); userList.put(rset.getString("username"), user);
} } catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace(); } finally {
try {
rset.close();
stmt.close();
conn.close();
} catch (Exception e) {
e.printStackTrace();
}
}
return userList;
} //插入:传入user对象,插入user对象的所有信息。
//因为数据库中主键不能重复,因此可能插入失败。(必须为新用户)
public int addUser(User newUser) {
int result = 0; //
if (findUser(newUser)) {
result = 1; //
} else {
String sql = "insert into Table_user(username,password,realname,userType,sex)values('"
+ newUser.getUsername()
+ "','"
+ newUser.getPassword()
+ "','"
+ newUser.getRealname()
+ "','"
+ newUser.getUserType() + "','" + newUser.getSex() + "')"; if (DBBean.update(sql)) {
result = 2; //
}
}
return result;
} public boolean findUser(User user) {
boolean result = false;
String sql = "select * from Table_user where username=('"
+ user.getUsername() + "')";
result = DBBean.hasRecord(sql);
return result;
} //删除:传入删除条件,传出删除是否成功信息
public boolean deleteUser(String username) {
boolean result = false;
String sql = "delete from Table_user where username=('" + username
+ "')";
result = DBBean.delete(sql);
System.out.println("delete user:" + sql);
return result;
} //查询:如果是通过主键找唯一对象,则返回对象。(如通过user_id找唯一用户)
//判断:本函数也可用来判断是否已经存在此对象。
public User getUser(String username) {
String sql = "select * from Table_user where username=('" + username
+ "')";
User user = null;
Connection conn = null;
Statement stmt = null;
ResultSet rset = null; try {
conn = DBBean.getConnection();
stmt = conn.createStatement();
rset = stmt.executeQuery(sql);
int i = 0;
while (rset.next()) {
user = new User(rset.getString("username"),
rset.getString("password"), rset.getString("realname"),
rset.getInt("userType"), rset.getInt("sex")); } } catch (SQLException e) {
e.printStackTrace(); } finally {
DBBean.clean(conn, stmt, rset);
}
return user;
} public int editUser(User user) {
int result = 1;
String sql = "update Table_user set username ='" + user.getUsername()
+ "',realname='" + user.getRealname() + "',userType='"
+ user.getUserType() + "' " + "where username=('"
+ user.getUsername() + "')";
//System.out.println("edit user:" + sql);
if (DBBean.update(sql)) {
result = 2;
}
return result;
} //判断:结果集是否为空,从而判断是否满足给定条件。
public int verifyUser(String username, String password) {
Connection conn = null;
Statement stmt = null;
ResultSet rset = null;
int result = -1;// 用户名密码不对
try {
conn = DBBean.getConnection();
String sql = "select * from table_user where username='" + username
+ "' and password='" + password + "'";
stmt = conn.createStatement();
rset = stmt.executeQuery(sql);
if (rset.next()) {
result = rset.getInt("userType");
System.out.println("user type: " + result);
}
} catch (SQLException e) {
System.out.println("SQLException inside verify user");
e.printStackTrace(); } finally {
try {
rset.close();
stmt.close();
conn.close();
} catch (Exception e) {
e.printStackTrace();
}
}
return result;
} }

javaWeb开发中entityBean的习惯用法的更多相关文章

  1. Javaweb开发中URL路径的使用

    看到博客园孤傲苍狼的web系列文章中有关于URL路径的使用文章后,感觉自己对URL的使用清楚了很多,自己再对着动手写一遍以加深记忆. JavaWeb开发中常看到URL以"/"开头, ...

  2. 【详细】总结JavaWeb开发中SSH框架开发问题(用心总结,不容错过)

    在做JavaWeb的SSH框架开发的时候,遇到过很多的细节问题,这里大概记录下 我使用的IDE是Eclipse(老版本)三大框架:Spring4.Struts2.Hibernate5 1.web.xm ...

  3. JavaWeb开发中的分层思想(一)

    JavaWeb开发分层思想(一) 一.认识DAO.Service.Controller层 DAO(Data Access Object) 1.直接看英文意思就是"数据访问对象",也 ...

  4. javaWeb开发中的中文编码问题

    常规解决乱码问题的方法是: a.把所有的jsp页面的charset设置为UTF-8.   b.添加过滤器,在filter内调用request.setCharacterEncoding("ut ...

  5. javaweb开发中的常见错误

    Javaweb中的最常见错误及其解决方法 1.200:表示成功处理业务. 2.400 请求出错: 由于语法格式有误,服务器无法理解此请求.不作修改,客户程序就 无法重复此请求. 解决办法:,遇到400 ...

  6. javaWeb开发中关于eclipse等ide重新部署或重启项目等原因造成上传文件丢失问题解决方案

    在开发项目时,有时候需要用到上传功能,比如头像上传等,其文件会保存到服务器中.但是我发现在用eclipse做项目的过程中,每次重新部署项目,原来上传的文件就会丢失. 其原因是因为每次项目修改后,ecl ...

  7. Java开发中的高频Collections用法总结与Java平台实现源代码查看方式

    一生二,二生三,三生万物,基础永远是一个计算机人的立身之本,相信看到这篇文章的人一般都知道数据结构这门课程,要不也不会找到我的这篇文章.数据结构这门课程的分析奠定了工程师对各种平台中的容器类,集合类的 ...

  8. JavaWeb开发中采用FreeMarker生成Excel表格

            最近做了一个需求,要求导出一个采购合同的Excel表格,这个表格样式比较多.由于是合同,这个Excel表格里面有好多格式要求,比如结尾处签字那部分就有格式要求.这里介绍种采用FreeM ...

  9. Javaweb开发中关于不同地方出现的绝对路径和相对路径

    1.转发和包含路径 a)以“/”开头:相对当前项目路径,即默认为http://localhost:8080/项目名/ b)不以“/”开头:相对当前Servlet路径. eg:在Aservlet中写“B ...

随机推荐

  1. 026 SSM综合练习02--数据后台管理系统--数据库表创建及SSM环境搭建

    1.数据库准备 本项目我们Oracle数据库,Oracle 为每个项目创建单独user,oracle数据表存放在表空间下,每个用户有独立表空间. (1)采用数据库管理员账号:SYSTEM,再配合数据库 ...

  2. yzoj 2372 小B的数字 题解

    题意 判断是否存在一个序列 $ b_i $ 使得 $ \prod_{i = 1}^{n} b_i  | b_i^{a_i}$ 恒成立,其中 $ b_i $ 中的每个数都是2的正整数次幂. 样例输入 3 ...

  3. 53 容器(八)——TreeMap 红黑树

    红黑树是比较难以理解的一种数据结构.它能从10亿数据中进行10几次比较就能查找到需要的数据.效率非常高. 理解起内部结构也难. 现阶段我们知道有这种东西就行了. 参考文章: https://www.j ...

  4. python--osi七层模型

    OSI七层模型 OSI七层参考模型 学计算机的人想必都对OSI七层参考模型不陌生,OSI七层参考模型是国际标准化组织(ISO)制定的一个用于计算机或通信系统间互联的标准体系.它是一个七层的.抽象的模型 ...

  5. Android apk逆向:反编译,回编译,签名,打包。

    Android apk逆向:反编译,回编译,签名,打包流程. 第一步: apk 反编译. 1) 打开命令行窗口,输入java -version, 检测当前java版本,若版本较低, 则下载JAVA S ...

  6. win7下scrapy1.3.2安装

    刚开始学爬虫,网上搜了搜,目前最合适的是选scrapy. 先要安装scrapy. 很多的博客上用的教程都说,scrapy目前对python3支持不是很好.可是不能不学3啊. 先用anaconda最新版 ...

  7. pandas-10 pd.pivot_table()透视表功能

    pandas-10 pd.pivot_table()透视表功能 和excel一样,pandas也有一个透视表的功能,具体demo如下: import numpy as np import pandas ...

  8. AngularJS $http用法总结

    最近由于项目需要,在研究AngularJS $http的用法,查了很多资料,发现貌似没有一篇内容可以完整的满足我对$http的基本了解,为了下次方便自己查找,所以特意把最近查到的一些资料和自己的理解记 ...

  9. 设置vue-quill-editor禁止输入或编辑

    <quill-editor class="ql-editor" v-model="form.content" ref="myQuillEdito ...

  10. 二十五、sql中where条件在数据库中提取与应用浅析

    问题描述 一条SQL,在数据库中是如何执行的呢?相信很多人都会对这个问题比较感兴趣.当然,要完整描述一条SQL在数据库中的生命周期,这是一个非常巨大的问题,涵盖了SQL的词法解析.语法解析.权限检查. ...