程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> JSP編程 >> 關於JSP >> jsp連接MySQL實現插入insert操作功能示例

jsp連接MySQL實現插入insert操作功能示例

編輯:關於JSP
    本文將為大家展示下jsp連接MySQL執行插入操作的功能,具體的示例及代碼如下,感興趣的朋友可以了解下  

    下午終於實現了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數據庫時的亂碼問題:
    在 輸入數據的頁面的編碼方式要使用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>

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved