本文介绍的是怎样使用MVC架构去实现jsp+servlet+javabean连接数据库
首先我们应该了解什么是MVC:
MVC包含三个部分 :
①View:由各种JSP页面组成。
②Controller:由各种Servlet组成,Controller就是将View和Model来进行匹配,用什么Model实现,调用哪个View来显示。
③Model:由各种javabean组成,也是MVC的核心,
以下就是简单的用MVC架构去实现一个JSP(View)+Servlet(Controller)+javabean(Model)实现MySql查询功能的Demo。
安装好例如以下软件:
1.MySQL
2.MyEclipse
3.下载好MySQL 的JDBC 的连接驱动jar url:http://pan.baidu.com/s/1sjBCfZR
一、创建数据库。
1.我们使用MySQL中的test数据库来创建须要測试的表:
在test数据库下创建名字为testTable的表,设置ID为主键,name等属性。点击apply,至此就完毕了数据库的创建。然后给定一些值例如以下4所看到的:
二、创建Web Project
1.打开MyEclipse -> File-> new -> Web Project 创建完后在src下创建包beans和ServletDB最后得到例如以下的文件结构:
2.编写beans
在beans包下创建两个javabeans分别为DAL.java 和 DB.java
DB.java 注意MySqlusername和password是你本机MySql的 username和password与下面的代码可能不一样须要改动。
package beans;import java.sql.*;public class DB { static String driver = "com.mysql.jdbc.Driver"; static String url = "jdbc:mysql://127.0.0.1:3306/test"; static String user = "root";//连接时的username static String password = "root";//连接时的密码 static Connection aConnection; public static Connection connectDB(){ try{ Class.forName(driver); aConnection = DriverManager.getConnection(url,user,password); if(aConnection.isClosed()) { System.out.print("Succeeded!"); } }catch(ClassNotFoundException e){ System.out.println(e); } catch (SQLException e) { e.printStackTrace(); } return aConnection; } public static ResultSet executeQuery(String sqlx) throws SQLException{ connectDB(); ResultSet rs = null; Statement stmt = aConnection.createStatement(); try { rs = stmt.executeQuery(sqlx); } catch (SQLException e) { e.printStackTrace(); } return rs; }}
DAL.java
package beans;import java.sql.ResultSet;import java.sql.SQLException;public class DAL { public static String sqlx=""; public static String testQueryByID(String ID){ ResultSet rs = null; String result = ""; sqlx = "SELECT * FROM testtable where ID = '"+ID+"'"; try { rs = DB.executeQuery(sqlx); } catch (SQLException e) { e.printStackTrace(); } try { while(rs.next()){ result = result +"ID:"+rs.getString("ID")+" Name:"+rs.getString("name")+""; } } catch (SQLException e) { e.printStackTrace(); } return result; } }3.编写servlet
File-> new -> servlet->确定包名为servletDB然后取名为test即可了 重要的是在本test方法中增加调用beans方法的语句。
test.java
package servletDB;import java.io.IOException;import java.io.PrintWriter;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import beans.DAL;public class test extends HttpServlet { /** * Constructor of the object. */ public test() { super(); } /** * Destruction of the servlet. */ public void destroy() { super.destroy(); // Just puts "destroy" string in log // Put your code here } public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html"); String ID = request.getParameter("ID");//获取传过来的ID String result = ""; result = DAL.testQueryByID(ID);//调用DAL中的testQueryByID方法而且将get过来的ID传过去 PrintWriter out = response.getWriter(); out.println(""); out.println(""); out.println("4.配置ServletA Servlet "); out.println(" "); out.print(result); out.println(" "); out.println(""); out.flush(); out.close(); } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html"); PrintWriter out = response.getWriter(); out.println(""); out.println(""); out.println("A Servlet "); out.println(" "); out.print(" This is "); out.print(this.getClass()); out.println(", using the POST method"); out.println(" "); out.println(""); out.flush(); out.close(); } public void init() throws ServletException { // Put your code here }}
进入WebRoot-〉Web-INF -〉web.xml加入例如以下代码
5.加入MySQL的Driver的jar支持test servletDB.test test /servletDB/test
将下载好的mysql-connector-java-5.1.30-bin.jar 放在好找的地方
右击项目->Properties->Java Build Path->Libraries->Add External 选择下载好的jar即可了
6.写index.jsp
将body中的代码替换为例如以下代码
三、測试
1.点击Run
2.输入測试ID 1
成功的获取到了test数据库testtable中ID为1的数据。