通过JDBC向数据库中添加数据,可以使用INSERT语句实现插入数据SQL语句,对于SQL语句中的参数可以只用占位符“?”代替,然后通过PreparedStatement对其赋值以及执行SQL。代码如下:

(1)添加图书页面,并不复杂,只是一个简单的表单,页面采用UTF-8编码方式。

 <html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>添加图书</title>
<script type="text/javascript">
function check(form){
with(form){
if(name.value==""){
alert("图书名称不能为空!");
return false;
}
if(price.value==""){
alert("图书价格不能为空!");
return false;
}
if(author.value==""){
alert("图书作者不能为空!");
return false;
}
return true;
}
}
</script>
</head>
<body>
<form action="AddBook.jsp" method="post" onSubmit="return check(this)">
<div style="background:red;text-align:center;margin:0 auto;">
<div>添加图书信息 </div>
<div>
图书名称:<input type="text" name="name"><br><br>
图书价格:<input type="text" name="price"><br><br>
图书数量:<input type="text" name="bookCount"><br><br>
图书作者:<input type="text" name="author"><br><br>
<input type="submit" value="添 加">
</div>
</div>
</form>
</body>
</html>

(2)结果展示页面,引入了一个javaBean类,同样采用UTF-8编码方式

 <%@ page import="java.sql.Connection" %>
<%@ page import="java.sql.PreparedStatement" %>
<%@ page import="java.sql.DriverManager" %>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>添加结果页</title>
</head>
<body>
<jsp:useBean id="book" class="com.bean.Book"></jsp:useBean>
<jsp:setProperty property="*" name="book"/>
<%
String url = "jdbc:mysql://localhost:3306/test";
String username = "root";
String password = "123456";
String driver = "com.mysql.jdbc.Driver";
String sql = "insert into book(name,price,bookCount,author) values(?,?,?,?)";
Connection conn = null;
PreparedStatement ps = null; try{
Class.forName(driver);
}catch(ClassNotFoundException e){
out.print("Class.forName(driver)出错");
e.printStackTrace();
}
try{
conn = DriverManager.getConnection(url,username,password); ps = conn.prepareStatement(sql); ps.setString(1, book.getName()); ps.setDouble(2, book.getPrice());
ps.setInt(3, book.getBookCount());
ps.setString(4, book.getAuthor()); int row = ps.executeUpdate();
if(row > 0){
out.print("图书添加成功!");
}
ps.close();
conn.close(); }catch(Exception e){
out.print("图书添加失败");
e.printStackTrace();
} %>
<br>
<a href="index.jsp">返回添加页面</a>
</body>
</html>

(3)后台javaBean类(Book.java)

 package com.bean;

 public class Book {
private String name;
private double price;
private int bookCount;
private String author;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public double getPrice() {
return price;
}
public void setPrice(double price) {
this.price = price;
}
public int getBookCount() {
return bookCount;
}
public void setBookCount(int bookCount) {
this.bookCount = bookCount;
}
public String getAuthor() {
return author;
}
public void setAuthor(String author) {
this.author = author;
} }

(4)由于从数据是从页面要传送到数据库的,所以这里会涉及到中文乱码的问题;所以我们的数据库表中的字段编码方式也是采用和网页同样的编码方式UTF-8,但是光就这样还是会出现中文乱码的,为了解决乱码的问题,我们在后台代码中加入一个字符过滤器。字符过滤器代码如下:

 package com.filter;

 import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.annotation.WebFilter; /**
* 编码选择器
* Servlet Filter implementation class CharactorFilter
*/
@WebFilter("/CharactorFilter")
public class CharactorFilter implements Filter {
//字符串编码
String encoding = null;
public CharactorFilter() { } /**
* @see Filter#destroy()
*/
public void destroy() {
encoding = null;
} /**
* @see Filter#doFilter(ServletRequest, ServletResponse, FilterChain)
*/
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
//判断字符编码是否为空
if(encoding != null) {
//设置request的编码方式
request.setCharacterEncoding(encoding);
//设置response字符编码
response.setCharacterEncoding(encoding);
response.setContentType("text/html;charset"+encoding);
} chain.doFilter(request, response);
} /**
* @see Filter#init(FilterConfig)
*/
public void init(FilterConfig fConfig) throws ServletException {
encoding = fConfig.getInitParameter("encoding");//初始化字符过滤器,getInitParameter("encoding")中的encoding为配置在web.xml文件中的参数
} }

字符过滤器完成后,最后一步还要配置web.xml文件,需要在<web-app></web-app>之间添加如下配置代码具体如下:

 <filter>
<!--过滤器类名,必须和后台过滤器类名保持一致-->
<filter-name>CharactorFilter</filter-name>
<!--过滤器完整类名-->
<filter-class>com.filter.CharactorFilter</filter-class>
<!--开始配置初始化参数-->
<init-param>
<!--参数名称-->
<param-name>encoding</param-name>
<!--参数值-->
<param-value>UTF-8</param-value>
</init-param>
</filter>
<!--开始配置过滤器映射-->
<filter-mapping>
<!--过滤器名称-->
<filter-name>CharactorFilter</filter-name>
<映射到作用的url, /*表示作用到所有文件>
<url-pattern>/*</url-pattern>
</filter-mapping>

最后运行得到如下结果

JDBC数据库之添加数据的更多相关文章

  1. Eclipse中java向数据库中添加数据,更新数据,删除数据

    前面详细写过如何连接数据库的具体操作,下面介绍向数据库中添加数据. 注意事项:如果参考下面代码,需要 改包名,数据库名,数据库账号,密码,和数据表(数据表里面的信息) package com.ning ...

  2. 用PHP向数据库中添加数据

    显示页面(用户可见) <body><form action="chuli.php" method="post">  //将该页面接收的数 ...

  3. 向数据库中添加数据,通过se16 不能添加,通过 代码可以添加的原因

    1:  在向数据库中添加数据时,通过客户端se16 准备对 数据表进行添加数据,提示如下: 找了以下原因,如下: https://www.baidu.com/link?url=3yRtAfY1_9XG ...

  4. phpStudy3——往数据库中添加数据

    前言: 前边介绍了查询数据库的方法,这里介绍下往数据库中添加数据的方法. 项目需求: 用户在前端页面输入的用户名和手机号码,点击提交后后端判断手机号码是否已经存在.如果不存在,那么插入数据库到数据库, ...

  5. 在数据库中添加数据以后,使用Mybatis进行查询结果为空

    在数据库中添加数据以后,使用Mybatis进行查询结果为空,这是因为数据库中添加数据忘记commit的缘故.

  6. SqlServer 查看数据库、添加数据文件

    一.查看SqlServer实例的数据库列表 1).直接在SSMS(SqlServer Management Studio)管理工具里面 展开实例下面的所有数据库便可查看  2).使用Transact- ...

  7. JDBC连接mysql数据库,添加数据

    如下:其中添加/删除/修改只是sql字符串不同 //3.要执行的字符串 String sql="INSERT INTO t_student(NAME,age,email) VALUES('x ...

  8. MVC学习笔记(三)—用EF向数据库中添加数据

    1.在EFDemo文件夹中添加Controllers文件夹(用的是上一篇MVC学习笔记(二)—用EF创建数据库中的项目) 2.在Controllers文件夹下添加一个空的控制器(StudentsCon ...

  9. nhibernate操作sql2008数据库(添加数据失败)

    今天遇到一错误困了我一天,如此痛恨,遂记录于此: nhibernate框架+MVC模式搭的项目,添加数据时报错: "could not insert: [KXRMallManage.Mode ...

随机推荐

  1. 利用OpenCms9提供的模块创建新站点

    OpenCms 9中提供b一个Demo,Demo使用了alkacon的bootstrap模板.如果已经安装了OpenCms 9,可以登陆http://localhost:8080/opencms/op ...

  2. github+hexo搭建自己的博客网站(三)主题之外的一些基本配置(图片位置,文章目录功能)

    使用的yilia主题之后,还需要进行自己的定制配置 1.图片的位置 比如打赏的支付宝二维码图片,是在当前博客的source/assets/img/下 (不是当前主题) 配置:(在yilia主题下文件里 ...

  3. spring boot / cloud (十五) 分布式调度中心进阶

    spring boot / cloud (十五) 分布式调度中心进阶 在<spring boot / cloud (十) 使用quartz搭建调度中心>这篇文章中介绍了如何在spring ...

  4. Linux常见命令(五)——rmdir

      前  言 JRedu 今天我们来介绍第五个命令:rmdir . 命令英文原意:remove empty directories 命令用途: rmdir:删除空目录,非空的目录不能删除 本章内容将详 ...

  5. HTTP服务器

    1.项目介绍 HTTP协议是应用层的面向对象的协议,由于其简捷.快速的方式,适用于分布式超媒体信息系统.协议的详细内容,前面一篇HTTP协议详解已经详细介绍了,这里不再赘述. 项目总体描述:HTTP支 ...

  6. linux(十)配置ssh免密登录实现

    知道ssh的朋友应该知道它是用来干什么的,如果你不知道什么是ssh远程登录的话,可以去看一下我的上一篇博客,关于linux的网络基础的知识.备注:ssh是用于远端登入.执行ssh指令开启终端机阶段作业 ...

  7. 小爬新浪新闻AFCCL

    1.任务目标: 爬取新浪新闻AFCCL的文章:文章标题.时间.来源.内容.评论数等信息. 2.目标网页: http://sports.sina.com.cn/z/AFCCL/ 3.网页分析 4.源代码 ...

  8. 本地配置DNS服务器(MAC版)

    作为一个前端开发者,会遇到使用cookie的情况,常见的如:登录,权限控制,视频播放,图形验证码等,这时候本地开发者在PC上会使用修改hosts的方式添加指向本地的域名,来获取cookie的同域名.如 ...

  9. spring-session 共享

    Spring session 共享 一.引入依赖 <dependency> <groupId>redis.clients</groupId> <artifac ...

  10. java Io流中FileInputStream和BufferedInputStream的速度比较

    首先是对FileInputStream 加上 FileOutputStream 对文件拷贝的应用 我这里拷贝的是一个视频.当然,你们拷贝什么都可以,当文件越大时效果越明显 下面是对BufferedIn ...