java web开发(mysql开发)
Posted 嵌入式-老费
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java web开发(mysql开发)相关的知识,希望对你有一定的参考价值。
【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】
选择了java作为项目开发语言,一般就不再会选择商业数据库了,比如说sql server,oracle之类的,除非是项目有特殊需求。大多数情况下,开发者都会选择mysql作为应用数据库。前面谈到了mvc中的c和v,即servlet和jsp,那么现在就应该说一说m了,也就是model。
model,美其名曰模型,大多数情况下就是数据库。而数据库本身大多数又是和业务绑定在一起,比如说电商网站、教育网站、企业信息网站、工业互联网等等,这些要求都是不一样的。所以,趁着学习java web,看看servlet下面是怎么调用数据库的。
下面示例中部分代码参考这篇文章的内容,在此首先表示感谢,链接在这,https://www.runoob.com/servlet/servlet-database-access.html,大家可以对比着学。
1、利用maven+idea创建maven-archetype-webapp项目
2、创建main/java和main/resources目录
3、安装mysql软件,创建mysql数据库java_web,导入sql表,
CREATE TABLE `websites` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` char(20) NOT NULL DEFAULT '' COMMENT '站点名称',
`url` varchar(255) NOT NULL DEFAULT '',
`alexa` int(11) NOT NULL DEFAULT '0' COMMENT 'Alexa 排名',
`country` char(10) NOT NULL DEFAULT '' COMMENT '国家',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;
INSERT INTO `websites` VALUES ('1', 'Google', 'https://www.google.cm/', '1', 'USA'), ('2', '淘宝', 'https://www.taobao.com/', '13', 'CN'), ('3', '菜鸟教程', 'http://www.runoob.com', '5892', ''), ('4', '微博', 'http://weibo.com/', '20', 'CN'), ('5', 'Facebook', 'https://www.facebook.com/', '3', 'USA');
4、编写DatabaseAccess.java代码
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.*;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* Servlet implementation class DatabaseAccess
*/
@WebServlet("/DatabaseAccess")
public class DatabaseAccess extends HttpServlet
private static final long serialVersionUID = 1L;
// JDBC 驱动名及数据库 URL
static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";
static final String DB_URL = "jdbc:mysql://localhost:3306/java_web";
// 数据库的用户名与密码,需要根据自己的设置
static final String USER = "root";
static final String PASS = "123456";
/**
* @see HttpServlet#HttpServlet()
*/
public DatabaseAccess()
super();
// TODO Auto-generated constructor stub
/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
Connection conn = null;
Statement stmt = null;
// 设置响应内容类型
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
String title = "Servlet Mysql 测试 - 菜鸟教程";
String docType = "<!DOCTYPE html>\\n";
out.println(docType +
"<html>\\n" +
"<head><title>" + title + "</title></head>\\n" +
"<body bgcolor=\\"#f0f0f0\\">\\n" +
"<h1 align=\\"center\\">" + title + "</h1>\\n");
try
// 注册 JDBC 驱动器
Class.forName("com.mysql.jdbc.Driver");
// 打开一个连接
conn = DriverManager.getConnection(DB_URL,USER,PASS);
// 执行 SQL 查询
stmt = conn.createStatement();
String sql;
sql = "SELECT id, name, url FROM websites";
ResultSet rs = stmt.executeQuery(sql);
// 展开结果集数据库
while(rs.next())
// 通过字段检索
int id = rs.getInt("id");
String name = rs.getString("name");
String url = rs.getString("url");
// 输出数据
out.println("ID: " + id);
out.println(", 站点名称: " + name);
out.println(", 站点 URL: " + url);
out.println("<br />");
out.println("</body></html>");
// 完成后关闭
rs.close();
stmt.close();
conn.close();
catch(SQLException se)
// 处理 JDBC 错误
se.printStackTrace();
catch(Exception e)
// 处理 Class.forName 错误
e.printStackTrace();
finally
// 最后是用于关闭资源的块
try
if(stmt!=null)
stmt.close();
catch(SQLException se2)
try
if(conn!=null)
conn.close();
catch(SQLException se)
se.printStackTrace();
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
// TODO Auto-generated method stub
doGet(request, response);
代码中有三处比较重要的地方需要注意下。第一,需要适时导入JDBC_DRIVER驱动;第二,DB_URL一定要引用正确;第三,USER和PASS一定要和实际的用户、密码相匹配。只要做到这一点,数据库的访问就问题不大了。
5、更新pom文件
除了和之前一样导入servlet包之外,还需要继续导入mysql驱动包,依赖包内容如下,
<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.47</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.2</version>
<scope>provided</scope>
</dependency>
添加后,立即用maven reinstall重新更新下,为编译做准备。
6、更新web.xml文件,将url和class文件做绑定
<servlet>
<servlet-name>DatabaseAccess</servlet-name>
<servlet-class>DatabaseAccess</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>DatabaseAccess</servlet-name>
<url-pattern>/DatabaseAccess</url-pattern>
</servlet-mapping>
7、创建tomcat配置
和之前一样,做好tomcat配置,一是端口不冲突,二是deployment选择正确。正常启动绿色三角按钮,准备调试,首先跳出来的网页是这个,
这明显不是我们想要的,重新修改下url,即 http://localhost:8090/Hello_war_exploded/DatabaseAccess
通过阅读网页内容得知,显示的部分就是数据库里面存储的数据。这说明了,整个servlet的数据库访问是很成功的。至此,mvc的最后一个model部分,也算是完整地补上了。
以上是关于java web开发(mysql开发)的主要内容,如果未能解决你的问题,请参考以下文章