目录

  • 1 阶段1模块一Java Web编程准备
    • 1.1 学习导航
    • 1.2 任务一进行系统需求分析与总体设计
    • 1.3 任务二搭建开发环境
    • 1.4 任务三制作静态页面
    • 1.5 任务四部署并运行第一个JSP文件
    • 1.6 模块一课件
    • 1.7 模块一习题
  • 2 阶段1模块二Java Web编程入门
    • 2.1 学习导航
    • 2.2 任务一认识JSP页面组成元素
    • 2.3 任务二认识JSP的内置对象
    • 2.4 任务三使用out对象输出信息
    • 2.5 任务四获取客户端请求数据
    • 2.6 任务五实现页面跳转
    • 2.7 任务六实现访问控制
    • 2.8 任务七制作网页计数器
    • 2.9 模块二 课件
    • 2.10 模块二习题
  • 3 阶段1模块三JavaWeb数据库编程
    • 3.1 学习导航
    • 3.2 任务一使用MySQL
    • 3.3 任务二使用SQL操作数据
    • 3.4 任务三认识连接数据库的步骤
    • 3.5 任务四使用Statement处理数据
    • 3.6 任务五使用PreparedStatement处理数据
    • 3.7 模块三课件
    • 3.8 模块三习题
  • 4 阶段1模块四JavaWeb基础阶段实训
    • 4.1 课件
    • 4.2 IT新闻资讯系统
  • 5 阶段2模块五Java Web应用优化
    • 5.1 学习导航
    • 5.2 任务一认识软件设计分层架构
    • 5.3 任务二使用分层架构实现管理员登录
    • 5.4 模块五课件
    • 5.5 模块五习题
  • 6 阶段2模块六Java Web开发业务应用
    • 6.1 学习导航
    • 6.2 任务一实现页面的分页显示
    • 6.3 任务二使用SmartUpload组件实现文件上传下载
    • 6.4 任务三使用图表组件显示动态数据图表
    • 6.5 模块六课件
    • 6.6 模块六习题
  • 7 阶段2模块七Servlet技术基础
    • 7.1 学习导航
    • 7.2 任务一认识Servlet
    • 7.3 任务二创建并运行一个简单的Servlet
    • 7.4 任务三使用Filter解决中文乱码问题
    • 7.5 模块七课件
    • 7.6 模块七习题
  • 8 阶段2模块八MVC开发模式
    • 8.1 学习导航
    • 8.2 任务一认识MVC模式
    • 8.3 任务二使用MVC模式实现用户登录
    • 8.4 模块八课件
    • 8.5 模块八习题
  • 9 阶段2模块九  Java Web进阶阶段实训
    • 9.1 模块九课件
    • 9.2 在线收藏夹
  • 10 阶段3模块十学生会网站项目开发
    • 10.1 模块十课件
  • 11 实训题库
    • 11.1 网络留言板系统1
    • 11.2 网络留言板系统2
    • 11.3 猜数游戏
    • 11.4 学生成绩查询系统
    • 11.5 场馆管理系统
    • 11.6 物资管理系统
    • 11.7 网络书签
    • 11.8 商品库存系统
    • 11.9 火车车次管理系统
    • 11.10 会议室预定系统
    • 11.11 人员档案管理系统
    • 11.12 新闻资讯系统
任务五使用PreparedStatement处理数据
  • 1 知识链接
  • 2 任务实现
  • 3 同步实训

【问题引入】

前面使用Statement对象执行静态的SQL语句实现了CRUD操作,但静态SQL语句比较繁琐,不灵活,易写错。为提高程序的灵活性和效率,可以通过PreparedStatement对象执行动态的SQL语句来实现。那么动态的SQL语句如何写?如何使用PreparedStatement对象处理数据呢?

【实现思路】

在获得数据库连接后,通过创建PreparedStatement对象,然后用动态SQL语句中的参数赋值,最后使用PreparedStatement对象执行增、删、查、改相关动态SQL语句实现数据操作。

【知识链接】

insert intoMESSAGE(message,author,postTime) values (?,?,?),这就是一条动态SQL语句,简洁,可读性强,使用占位符?来代替SQL语句(前面任务中使用Statement时执行的)中的参数。

StatementPreparedStatement的用法比较如表3-12所示。

3-12  StatementPreparedStatement的比较

                                         

 

项目

 
 

使用Statement

 
 

使用PreparedStatement

 
 

SQL语句

 
 

String sql="insert into  MESSAGE(message,author,postTime) values  ('"+messagestr+"','"+author+"','"+new  SimpleDateFormat ("yyyy-MM-dd").format(new  Date())+"')";

 
 

String sql="insert into  MESSAGE(message,author,postTime) values (?,?,?)";

 
 

对象创建

 
 

stmt=con.createStatement();

 
 

ptmt=con.prepareStatement(sql);

 
 

参数赋值

 
 

不需要

 
 

需要通过setXXX方法给参数赋值,对于不同类型的参数可以使用不同类型的setXXX方法。ptmt.setString(1,messagestr);

 
 

执行

 
 

增、删、改操作:

 

stmt.executeUpdate(sql);

 

查询操作:

 

stmt.executeQuery(sql);

 
 

增、删、改操作:

 

ptmt.executeUpdate();

 

查询操作:

 

ptmt.executeQuery();

 
 

用法复杂

 
 

简单

 
 

复杂

 
 

适用情况

 
 

单次执行

 
 

重复执行多次