jsp連接MySQL實(shí)現(xiàn)插入insert操作功能示例
更新時(shí)間:2013年08月01日 16:29:49 作者:
本文將為大家展示下jsp連接MySQL執(zhí)行插入操作的功能,具體的示例及代碼如下,感興趣的朋友可以了解下
下午終于實(shí)現(xiàn)了jsp連接MySQL執(zhí)行插入操作的功能。在index.jsp頁(yè)面輸入數(shù)據(jù),提交到mysql——insert.jsp頁(yè)面進(jìn)行插入數(shù)據(jù)庫(kù)的操作。
index.jsp頁(yè)面代碼如下:
<%@ 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
{
/** 連接數(shù)據(jù)庫(kù)參數(shù) **/
String driverName = "com.mysql.jdbc.Driver"; //驅(qū)動(dòng)名稱
String DBUser = "root"; //mysql用戶名
String DBPasswd = "123456"; //mysql密碼
String DBName = "html_db"; //數(shù)據(jù)庫(kù)名
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>
訪問(wèn)index.jsp后的頁(yè)面:
輸入測(cè)試數(shù)據(jù),提交后得到如下頁(yè)面:

數(shù)據(jù)庫(kù)的變化情況如下:
關(guān)于jsp連接MySQL數(shù)據(jù)庫(kù)時(shí)的亂碼問(wèn)題:
在輸入數(shù)據(jù)的頁(yè)面的編碼方式要使用GB2312或者GBK、同時(shí)在接收數(shù)據(jù)的頁(yè)面的編碼方式要使用UTF-8,才能保證完全不會(huì)出現(xiàn)亂碼。如上面的例子,在index.jsp輸入數(shù)據(jù),所以其使用<%@ page contentType="text/html;charset=gb2312"%>語(yǔ)句指明使用GB2312編碼,而mysql_insert.jsp接收數(shù)據(jù),所以其使用<%@page language="java" pageEncoding="UTF-8"%>語(yǔ)句指明使用UTF-8編碼。
而對(duì)于從MySQL中拿出數(shù)據(jù)并顯示的頁(yè)面,其編碼方式也要使用GB2312,如下面的mysql_query.jsp文件例子就使用了<%@ page contentType="text/html;charset=gb2312"%>語(yǔ)句指明了編碼方式。
tomcat默認(rèn)按照iso-8859-1對(duì)url進(jìn)行編碼所以要進(jìn)行相應(yīng)轉(zhuǎn)換。
<%@ 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為數(shù)據(jù)庫(kù)名
Class.forName("org.gjt.mm.mysql.Driver").newInstance();//新建實(shí)例
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("數(shù)據(jù)庫(kù)操作成功,恭喜你!");%>
<%
rs.close();
stmt.close();
conn.close();
%>
</body>
</html>

index.jsp頁(yè)面代碼如下:
復(fù)制代碼 代碼如下:
<%@ 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的代碼如下:
復(fù)制代碼 代碼如下:
<%@ 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
{
/** 連接數(shù)據(jù)庫(kù)參數(shù) **/
String driverName = "com.mysql.jdbc.Driver"; //驅(qū)動(dòng)名稱
String DBUser = "root"; //mysql用戶名
String DBPasswd = "123456"; //mysql密碼
String DBName = "html_db"; //數(shù)據(jù)庫(kù)名
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>
訪問(wèn)index.jsp后的頁(yè)面:

輸入測(cè)試數(shù)據(jù),提交后得到如下頁(yè)面:

數(shù)據(jù)庫(kù)的變化情況如下:

關(guān)于jsp連接MySQL數(shù)據(jù)庫(kù)時(shí)的亂碼問(wèn)題:
在輸入數(shù)據(jù)的頁(yè)面的編碼方式要使用GB2312或者GBK、同時(shí)在接收數(shù)據(jù)的頁(yè)面的編碼方式要使用UTF-8,才能保證完全不會(huì)出現(xiàn)亂碼。如上面的例子,在index.jsp輸入數(shù)據(jù),所以其使用<%@ page contentType="text/html;charset=gb2312"%>語(yǔ)句指明使用GB2312編碼,而mysql_insert.jsp接收數(shù)據(jù),所以其使用<%@page language="java" pageEncoding="UTF-8"%>語(yǔ)句指明使用UTF-8編碼。
而對(duì)于從MySQL中拿出數(shù)據(jù)并顯示的頁(yè)面,其編碼方式也要使用GB2312,如下面的mysql_query.jsp文件例子就使用了<%@ page contentType="text/html;charset=gb2312"%>語(yǔ)句指明了編碼方式。
tomcat默認(rèn)按照iso-8859-1對(duì)url進(jìn)行編碼所以要進(jìn)行相應(yīng)轉(zhuǎn)換。
復(fù)制代碼 代碼如下:
<%@ 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為數(shù)據(jù)庫(kù)名
Class.forName("org.gjt.mm.mysql.Driver").newInstance();//新建實(shí)例
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("數(shù)據(jù)庫(kù)操作成功,恭喜你!");%>
<%
rs.close();
stmt.close();
conn.close();
%>
</body>
</html>
您可能感興趣的文章:
- jsp和servlet操作mysql中文亂碼問(wèn)題的解決辦法
- JSP+ MySQL中文亂碼問(wèn)題post提交亂碼解決方案
- jsp中文亂碼 jsp mysql 亂碼的解決方法
- MySQL插入中文不亂碼的5種方法
- C# mysql 插入數(shù)據(jù),中文亂碼的解決方法
- Linux下進(jìn)行MYSQL編程時(shí)插入中文亂碼的解決方案
- jsp操作MySQL實(shí)現(xiàn)查詢/插入/刪除功能示例
- JSP 連接MySQL配置與使用
- 如何使用JSP訪問(wèn)MySQL數(shù)據(jù)庫(kù)
- JSP MySQL插入數(shù)據(jù)時(shí)出現(xiàn)中文亂碼問(wèn)題的解決方法
相關(guān)文章
SSM框架整合JSP中集成easyui前端ui項(xiàng)目開(kāi)發(fā)示例詳解
這篇文章主要介紹了SSM框架JSP中集成easyui前端ui項(xiàng)目開(kāi)發(fā)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2021-10-10JSP多種web應(yīng)用服務(wù)器導(dǎo)致JSP源碼泄漏漏洞
JSP多種web應(yīng)用服務(wù)器導(dǎo)致JSP源碼泄漏漏洞...2006-10-10JSP使用Servlet過(guò)濾器進(jìn)行身份驗(yàn)證的方法
這篇文章主要介紹了JSP使用Servlet過(guò)濾器進(jìn)行身份驗(yàn)證的方法,結(jié)合實(shí)例形式分析了Servlet過(guò)濾器的實(shí)現(xiàn)方法及jsp身份驗(yàn)證的具體使用技巧,需要的朋友可以參考下2015-12-12