jsp连接MySQL实现插入insert操作功能示例

  下午终于实现了jsp连接MySQL执行插入操作的功能。在index.jsp页面输入数据,提交到mysql——insert.jsp页面进行插入数据库的操作。

jsp连接MySQL实现插入insert操作功能示例

  index.jsp页面代码如下:

  

复制代码 代码如下:

  <%@ page language="java" pageEncoding="utf-8"%>

  <%@ page contentType="text/html;charset=utf-8"%>

  <%

  request.setCharacterEncoding("UTF-8");

  response.setCharacterEncoding("UTF-8");

  response.setContentType("text/html; charset=utf-8");

  %>

  <html>

  <head>

  </head>

  <body>

  <form action="mysql_insert.jsp" method="post">

  ID :<input type = "text" name="id" value="0"/>

  姓名 :<input type = "text" name="name" value="aaa"/>

  性别 :<input type = "text" name="sex" value="female"/>

  年龄 :<input type = "text" name="age" value="20"/>

  </br>

  <input type = "submit" value="提交"/>

  </form>

  </body>

  </html>

  mysql——insert.jsp的代码如下:

  

复制代码 代码如下:

  <%@ page language="java" import="java.util.*,java.sql.*" pageEncoding="utf-8"%>

  <%@ page contentType="text/html;charset=utf-8"%>

  <%

  request.setCharacterEncoding("UTF-8");

  response.setCharacterEncoding("UTF-8");

  response.setContentType("text/html; charset=utf-8");

  %>

  <html>

  <head>

  <title>add message into table </TITLE>

  </head>

  <body>

  <%

  String id=request.getParameter("id"); //从表单获得

  String name=request.getParameter("name"); //从表单获得

  String sex=request.getParameter("sex"); //从表单获得

  String age=request.getParameter("age"); //从表单获得

  java.util.Date date=new java.util.Date();

  String datetime=new Timestamp(date.getTime()).toString();

  try

  {

  /** 连接数据库参数 **/

  String driverName = "com.mysql.jdbc.Driver"; //驱动名称

  String DBUser = "root"; //mysql用户名

  String DBPasswd = "123456"; //mysql密码

  String DBName = "html_db"; //数据库名

  String connUrl = "jdbc:mysql://localhost/" + DBName + "?user=" + DBUser + "&password=" + DBPasswd;

  Class.forName(driverName).newInstance();

  Connection conn = DriverManager.getConnection(connUrl);

  Statement stmt = conn.createStatement();

  stmt.executeQuery("SET NAMES UTF8");

  String insert_sql = "insert into person_tb values('" + id + "','" + name + "','" + sex + "','" + age + "')";

  String query_sql = "select * from person_tb";

  try {

  stmt.execute(insert_sql);

  }catch(Exception e) {

  e.printStackTrace();

  }

  try {

  ResultSet rs = stmt.executeQuery(query_sql);

  while(rs.next()) {

  %>

  ID:<%=rs.getString("id")%> </br>

  姓名:<%=rs.getString("name")%> </br>

  性别:<%=rs.getString("sex")%> </br>

  年龄:<%=rs.getString("age")%> </br> </br>

  <%

  }

  }catch(Exception e) {

  e.printStackTrace();

  }

  //rs.close();

  stmt.close();

  conn.close();

  }catch (Exception e) {

  e.printStackTrace();

  }

  %>

  </body>

  </html>

  访问index.jsp后的页面:

jsp连接MySQL实现插入insert操作功能示例

  输入测试数据,提交后得到如下页面:

jsp连接MySQL实现插入insert操作功能示例

  数据库的变化情况如下:

jsp连接MySQL实现插入insert操作功能示例

  关于jsp连接MySQL数据库时的乱码问题:

  在输入数据的页面的编码方式要使用GB2312或者GBK、同时在接收数据的页面的编码方式要使用UTF-8,才能保证完全不会出现乱码。如上面的例子,在index.jsp输入数据,所以其使用<%@ page contentType="text/html;charset=gb2312"%>语句指明使用GB2312编码,而mysql_insert.jsp接收数据,所以其使用<%@page language="java" pageEncoding="UTF-8"%>语句指明使用UTF-8编码。

  而对于从MySQL中拿出数据并显示的页面,其编码方式也要使用GB2312,如下面的mysql_query.jsp文件例子就使用了<%@ page contentType="text/html;charset=gb2312"%>语句指明了编码方式。

  tomcat默认按照iso-8859-1对url进行编码所以要进行相应转换。

  

复制代码 代码如下:

  <%@ page contentType="text/html;charset=gb2312"%>

  <%@ page import="java.sql.*"%>

  <html>

  <body>

  <%

  Connection con=null;

  String url="jdbc:mysql://localhost/html_db?user=root&password=123456&useUnicode=true&characterEncoding=8859_1";

  //html_db为数据库名

  Class.forName("org.gjt.mm.mysql.Driver").newInstance();//新建实例

  Connection conn= DriverManager.getConnection(url);//建立连接

  Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);

  String sql="select * from person_tb";

  ResultSet rs=stmt.executeQuery(sql);

  while(rs.next()) {%>

  ID:<%=rs.getString("id")%> </br>

  姓名:<%=rs.getString("name")%> </br>

  性别:<%=rs.getString("sex")%> </br>

  年龄:<%=rs.getString("age")%> </br> </br>

  <%}%>

  <%out.print("数据库操作成功,恭喜你!");%>

  <%

  rs.close();

  stmt.close();

  conn.close();

  %>

  </body>

  </html>