JSP网站开发基础总结《四》
经过前几篇的摸爬滚打,下面我们就开始我们真正的数据库操作了,本篇重点在于如何在网站端编写数据库操作语句,内容不多,就是我们常见的增删改查。
0、数据库对象创建:
在JAVASE基础知识总结时,就为大家点明了,JAVA是一种面向对象编程语言,所以我们再进行数据库创建之前,要先创建一个对象类。
/*
* 实例化数据库中的对象
*/
public class Student {
private int id;//学生ID
private String name;//学生姓名
private int sex;//学生性别
private int year;//学生年龄
private String from;//学生故乡
private String school;//学生所在学校 //为属性添加set()、get()方法
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getSex() {
return sex;
}
public void setSex(int sex) {
this.sex = sex;
}
public int getYear() {
return year;
}
public void setYear(int year) {
this.year = year;
}
public String getFrom() {
return from;
}
public void setFrom(String from) {
this.from = from;
}
public String getSchool() {
return school;
}
public void setSchool(String school) {
this.school = school;
}
}
1、接口创建:
这里采用了面向接口编程,方便我们管理我们的数据库操作方法。
/*
* 数据库操作方法接口
*/
public interface StudentMa { public boolean add(Student student);//添加
public boolean del(int id);//删除
public boolean update(Student student);//修改
public Student getById(int id);//精确查询
public List<Student> getByName(String name);//模糊查询
public List<Student> getAll();//遍历 }
2、增加操作:
如何通过JAVA语句为数据库添加数据呢?下面就是具体的方法实现。
public boolean add(Student student) {
boolean flag = false;
Connection conn = null;
PreparedStatement pst = null;
conn = DBO.getConnection();
String sql = "insert into students (name,sex,year,from,school) values (?,?,?,?,?)";//'?'表示占位符
try {
pst = conn.prepareStatement(sql);
pst.setString(1, student.getName());
pst.setInt(2, student.getSex());
pst.setInt(3, student.getYear());
pst.setString(4, student.getFrom());
pst.setString(5, student.getSchool());
int n = pst.executeUpdate();
if(n>0){
flag = true;
}
} catch (SQLException e) {
e.printStackTrace();
}
return flag;
}
3、删除操作:
如何通过JAVA语句删除数据库中的数据呢?下面就是具体的方法实现。
public boolean del(int id) {
boolean flag = false;
Connection conn = null;
PreparedStatement pst = null;
conn = DBO.getConnection();
String sql = "delete from students where id="+id;
try {
pst = conn.prepareStatement(sql);
int n = pst.executeUpdate();
if(n>0){
flag = true;
}
} catch (SQLException e) {
e.printStackTrace();
}
return flag;
}
4、修改操作:
如何通过JAVA语句修改数据库中的数据呢?下面就是具体的方法实现。
public boolean update(Student student) {
boolean flag = false;
Connection conn = null;
PreparedStatement pst = null;
conn = DBO.getConnection();
String sql = "update students set name=?,sex=?,year=?,from=?,school=? where id=?";//'?'表示占位符
try {
pst = conn.prepareStatement(sql);
pst.setString(1, student.getName());
pst.setInt(2, student.getSex());
pst.setInt(3, student.getYear());
pst.setString(4, student.getFrom());
pst.setString(5, student.getSchool());
pst.setInt(6, student.getId());
int n = pst.executeUpdate();
if(n>0){
flag = true;
}
} catch (SQLException e) {
e.printStackTrace();
}
return flag;
}
5、查询操作:
a、精确查询:
如何通过JAVA语句精确查找数据库中的数据呢?下面就是具体的方法实现。
public Student getById(int id) {
Student student = new Student();
Connection conn = null;
Statement st = null;
ResultSet rs = null;
conn = DBO.getConnection();
String sql = "select * from students where id="+id;
try {
st = conn.createStatement();
rs = st.executeQuery(sql);
while(rs.next()){
student.setId(id);
student.setName(rs.getString("name"));
student.setSex(rs.getInt("sex"));
student.setYear(rs.getInt("year"));
student.setFrom(rs.getString("from"));
student.setSchool(rs.getString("school"));
}
} catch (SQLException e) {
e.printStackTrace();
}
return student;
}
b、模糊查询:
如何通过JAVA语句模糊查找数据库中的数据呢?下面就是具体的方法实现。
public List<Student> getByName(String name) {
List<Student> list = null;
Connection conn = null;
PreparedStatement pst = null;
ResultSet rs = null;
conn = DBO.getConnection();
String sql = "select * from students where name like ?";
try {
pst = conn.prepareStatement(sql);
pst.setString(1, "%"+name+"%");
rs = pst.executeQuery();
while(rs.next()){
Student student = new Student();
student.setId(rs.getInt("id"));
student.setName(rs.getString("name"));
student.setSex(rs.getInt("sex"));
student.setYear(rs.getInt("year"));
student.setFrom(rs.getString("from"));
student.setSchool(rs.getString("school"));
list.add(student);
}
} catch (SQLException e) {
e.printStackTrace();
}
return list;
}
6、遍历操作:
如何通过JAVA语句遍历数据库中的数据呢?下面就是具体的方法实现。
public List<Student> getAll() {
List<Student> list = new ArrayList<Student>();
Connection conn = null;
Statement st = null;
ResultSet rs = null;
conn = DBO.getConnection();
String sql = "select * from students";
try {
st = conn.createStatement();
rs = st.executeQuery(sql);
while(rs.next()){
Student student = new Student();
student.setId(rs.getInt("id"));
student.setName(rs.getString("name"));
student.setSex(rs.getInt("sex"));
student.setYear(rs.getInt("year"));
student.setFrom(rs.getString("from"));
student.setSchool(rs.getString("school"));
list.add(student);
}
} catch (SQLException e) {
e.printStackTrace();
}
return list;
}
好了到这里,关于数据库的增删改查操作的JAVA实现已经为大家总结完毕。下一篇select实现jsp页面与数据库交互。
JSP网站开发基础总结《四》的更多相关文章
- JSP网站开发基础总结《二》
有了上一篇的学习,我相信大家对于JSP一定有了一定的认识,从今天开始我们真正开启JSP模式,如果你有HTML的基础,那学起JSP来也就方便了很多了,首先JSP做为网站开发语言,它与HTML有很多相似的 ...
- JSP网站开发基础总结《一》
经过JAVASE的学习相信大家对JAVA已经不再陌生,那么JAVA都可以干什么呢?做算法.应用程序.网站开发都可以,从今天开始为大家奉上JAVAEE之JSP动态网站开发基础总结. 既然是动态网站开发, ...
- JSP网站开发基础总结《八》
JSP的学习总结到本篇已经八篇了,内容比较多,但都是实战,本篇最后为大家介绍一个小效果:百度分页.就是当我们遍历的数据对象较多时,这时我们就会看到了这个效果了,那他是如何实现的呢?下面我们就一起学习一 ...
- JSP网站开发基础总结《七》
按照计划本篇将为大家总结搜索功能的两种实现:确定搜索与模糊搜索.所谓精确搜索便是指,根据用户的输入的搜索内容,在数据库中寻找具有一一对应的关系的数据,一般都是用户在数据库中的主键值.而模糊搜索,是一种 ...
- JSP网站开发基础总结《十二》
前两篇已经简单为大家介绍了一下,有关Filter接口的知识,本篇就让我们以一个登录小功能,来具体实现一下过滤器的作用,便于大家掌握.具体为大家介绍一下如何使用Filter对访问进行过滤,及如何防止中文 ...
- JSP网站开发基础总结《十三》
继上一篇为大家补充过滤器类后,本篇为大家简单介绍一下如何实现验证码效果.验证码的作用是什么呢?1.防止恶意注册2.防止恶意提交3.防止盗取账户等等,总的来说验证码的存在就是为了,防止非人为的操作,不过 ...
- JSP网站开发基础总结《九》
本篇属于附加篇,在之前的总结中给大家提到过一个关于登录状态验证的效果,当时是通过Session对象完成的,今天我查了一下,JSP为我们封装了一个用于过滤用的过滤器类Filter,通过它我们就可以非常轻 ...
- JSP网站开发基础总结《六》
对于本篇需要总结的内容,量估计有点大,大家好好看哈,绝对全是干货,代码的已经运行测试,不存在问题,大家可以参考学习,下面开始本篇的内容. 1.添加数据到数据库: 如何用户在JSP页面的填写的信息输入到 ...
- JSP网站开发基础总结《九》(转)
本篇属于附加篇,在之前的总结中给大家提到过一个关于登录状态验证的效果,当时是通过Session对象完成的,今天我查了一下,JSP为我们封装了一个用于过滤用的过滤器类Filter,通过它我们就可以非常轻 ...
随机推荐
- 用UEFI安装ArchLinux 20140105
为了在E431上用UEFI安装Arch一个晚上重装了5,6次系统,整整做了一个通宵,还好是周六.今天刚好有时间正好 来总结一下.因为要用UEFI来安装,所以安装了两次之后发现UEFI环境变量不可用(用 ...
- 基于OpenCv的人脸检测、识别系统学习制作笔记之三
1.在windows下编写人脸检测.识别系统.目前已完成:可利用摄像头提取图像,并将人脸检测出来,未进行识别. 2.在linux下进行编译在windows环境下已经能运行的代码. 为此进行了linux ...
- [XAF] How to improve the application's performance
[自己的解决方案]数据量大时,可显著提升用户使用体验! 1.Root ListView 参考官方的E1554 点击导航菜单后首先跳出查询条件设置窗体进行设置 可设置查询方案或查询方案的查询条件,排序字 ...
- linux添加新LUN,无需重启
linux添加新LUN,无需重启 在给存储增加新的Lun时,在linux下一般是: A.重启操作系统B.重启HBA卡驱动 1. kudzu添加完新硬盘后,运行命令kudzu重新扫描新的硬件设备,类似a ...
- HTML5-属性
点击图片打开详细介绍页面
- Swift不同storyboard之间的交互
如何实现多个Storyboard之间的切换 正如大家所知道的,Main-board是·程序运行的入口,如果找不到就会抛出异常,打开plist文件可以看到关于Main-board的描述,特别的制定了其b ...
- 【转】java.lang.OutOfMemoryError: Java heap space的解决
原文地址:http://blog.sina.com.cn/s/blog_4b12778b0100v0bb.html Myeclipse下java.lang.OutOfMemoryError: Java ...
- 【转载】解决Windows 10 局域网内共享的问题
问题: 小米盒子,iPhone (OS 10.2) 无法访问 Win 1o共享 解决方案: 原文链接 http://www.dedoimedo.com/computers/windows-10-net ...
- dijit样式定制(三)Button、RadioButton、CheckBox
dijit.form.DropDownButton dijit的button中除了ComboButton使用table布局外,其他的button都是用span嵌套布局,下图中可看一下button的主要 ...
- 【转】EntityFramework(EF)贪婪加载和延迟加载的选择和使用
原谅:http://www.weixq.cn/Article/Detail/906 贪婪加载:顾名思议就是把所有要加载的东西一 次性读取 using (var context = new MyDbCo ...