jsp连接MySQL实现插入insert操作功能示例
网络编程 2021-07-05 11:23www.168986.cn编程入门
本文将为大家展示下jsp连接MySQL执行插入操作的功能,具体的示例及代码如下,感兴趣的朋友可以了解下
下午终于实现了jsp连接MySQL执行插入操作的功能。在index.jsp页面输入数据,提交到mysql——insert.jsp页面进行插入数据库的操作。
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 = ".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,如狼蚁网站SEO优化的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(".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>
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 = ".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,如狼蚁网站SEO优化的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(".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>
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程