新博客地址https://www.jianshu.com/u/8e54644eafae

1.创建数据库表myuser

DROP TABLE IF EXISTS `myuser`;
CREATE TABLE `myuser` (
`user_name` varchar(255) NOT NULL COMMENT '姓名',
`id` int(11) NOT NULL AUTO_INCREMENT,
`age` int(11) DEFAULT NULL,
`password` varchar(255) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;

2.实体类

package yang.mybatis.domain;

public class User {
  //实体类的成员变量和数据库表的字段名称和类型一致
private int id;
private String user_name;
private int age;
private String password; public User(){}
public User(String name,int id, int age,String password) {
super();
this.id = id;
this.user_name = name;
this.age = age;
this.password = password;
}
  //创建每个成员变量的set和get方法
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getUser_name() {
return user_name;
}
public void setUser_name(String name) {
this.user_name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public void setPassword(String password) {
this.password = password;
} public String getPassword() {
return password;
}
@Override
public String toString() {
return "User [id=" + id + ", name=" + user_name + ", age=" + age + "]";
} }

3.1UserDao,连接数据库,查询数据库表中所有的记录

package yang.mybatis.dao;

import yang.mybatis.domain.User;

import java.sql.*;
import java.util.ArrayList;
import java.util.List; /**
* Created by yangshijing on 2017/11/10 0010.
*/
public class UserDaoTest {
public List<User> getAll(){
    
List<User> Users = new ArrayList<User>(); Connection connection = null;
PreparedStatement preparedStatement = null;
ResultSet resultSet = null; try {
String driverClass = "com.mysql.jdbc.Driver";
String url = "jdbc:mysql:///mydb";
String user = "root";
String pass= "1234"; Class.forName(driverClass);
connection = DriverManager.getConnection(url, user, pass); String sql = "SELECT user_name, id, age, password FROM myuser";
preparedStatement = connection.prepareStatement(sql); resultSet = preparedStatement.executeQuery();
while(resultSet.next()){
String user_name = resultSet.getString(1);
int id = resultSet.getInt(2);
int age = resultSet.getInt(3);
String password = resultSet.getString(4);
User userl= new User(user_name,id,age,password);
Users.add(userl);
}
} catch (Exception e) {
e.printStackTrace();
} finally{
try {
if(resultSet != null){
resultSet.close();
}
} catch (SQLException e) {
e.printStackTrace();
} try {
if(preparedStatement != null){
preparedStatement.close();
}
} catch (SQLException e) {
e.printStackTrace();
} try {
if(connection != null){
connection.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
} return Users;
}
}

3.2根据用户Id删除用户数据

   public void deleteById(int id) {
Connection connection = null;
PreparedStatement preparedStatement = null;
try {
String driverClass = "com.mysql.jdbc.Driver";
String url = "jdbc:mysql:///mydb";
String user = "root";
String pass= "1234"; Class.forName(driverClass);
connection = DriverManager.getConnection(url, user, pass); String sql = "DELETE FROM myuser WHERE id=?";
preparedStatement = connection.prepareStatement(sql);
preparedStatement.setInt(1,id);
int i = preparedStatement.executeUpdate();
} catch (Exception e) {
e.printStackTrace();
} finally{
try {
if(preparedStatement != null){
preparedStatement.close();
}
} catch (SQLException e) {
e.printStackTrace();
} try {
if(connection != null){
connection.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
}

4.1编写查询Servlet

package yang.mybatis.servlet;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import yang.mybatis.dao.UserDaoImp;
import yang.mybatis.dao.UserDaoTest;
import yang.mybatis.domain.User; import java.io.IOException;
import java.util.List; /**
* Created by yangshijing on 2017/11/10 0010.
*/
@Controller
public class ListAllStudent extends javax.servlet.http.HttpServlet {
@Override
protected void doPost(javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response) throws javax.servlet.ServletException, IOException {
doGet(request,response);
} @Override
protected void doGet(javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response) throws javax.servlet.ServletException, IOException {
try {
UserDaoTest userDaoTest = new UserDaoTest();
List<User> list = userDaoTest.getAll();
//将从数据库中查询到的数据方法request域中
request.setAttribute("list",list);
//利用请求转发的方式,将这次请求域中的数据传到另一个页面进行显示
    request.getRequestDispatcher("/jsp/hello1.jsp").forward(request,response);
} catch (Exception e) {
e.printStackTrace();
}
}
}

4.2删除Servlet

package yang.mybatis.servlet;

import yang.mybatis.dao.UserDaoTest;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException; /**
* Created by yangshijing on 2017/11/10 0010.
*/
public class DeleteServlet extends HttpServlet {
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request,response);
} @Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
     //从request域中获取的数据是String类型
String id = request.getParameter("id");
UserDaoTest userDaoTest = new UserDaoTest();
     //通过Interger.parseInt()方法,将String类型转换为int类型
userDaoTest.deleteById(Integer.parseInt(id));
request.getRequestDispatcher("/listAllStudent").forward(request,response);
}
}

5.Web应用根目录下/jsp/hello1.jsp页面对数据进行显示

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<html>
<head>
<title>用户列表</title>
</head>
<body>
<a href="/myAction/listAllStudent.action">SpringMvc</a>
<a href="/listAllStudent">Servlet</a>
<br>
  <!--设置表格边框的宽度-->
<table border="1" cellpadding="10" cellspacing="0">
<tr>
<th>编号</th>
<th>姓名</th>
<th>年龄</th>
<th>密码</th>
<th>删除</th>
</tr>
<c:forEach items="${list}" var="user">
<tr>
<td> ${user.id}</td>
<td> ${user.user_name}</td>
<td> ${user.age}</td>
<td> ${user.password}</td>
<td><a href="/deleteServlet?id=${user.id}">Delete</a></td>
</tr>
</c:forEach>
</table> </body>
</html>

6.结果

JDBC方式从数据库中查询数据并显示的更多相关文章

  1. 使用JDBC从数据库中查询数据的方法

    * ResultSet 结果集:封装了使用JDBC 进行查询的结果 * 1. 调用Statement 对象的 executeQuery(sql) 方法可以得到结果集 * 2. ResultSet 返回 ...

  2. flask再学习-思考之怎么从数据库中查询数据在页面展示!

    看别人视频觉得很简单,要自己做蒙蔽了!这样子.NO! 1. 流程: 首先要有和数据库连接的驱动!一般有PYMySQL mysqlclient 等 使用扩展Flask-SQLAlchemy 获得orm对 ...

  3. MongoDB数据库中查询数据(下)

    MongoDB数据库中查询数据(下) 在find中,options参数值为一个对象,用来设置查询数据时使用的选项,下面我们来对该参数值对象中可以使用的属性进行介绍: 1. fields; 该属性值为一 ...

  4. 在MongoDB数据库中查询数据(上)

    在MongoDB数据库中查询数据(上) 在MongoDB数据库中,可以使用Collection对象的find方法从一个集合中查询多个数据文档,find方法使用方法如下所示: collection.fi ...

  5. 使用JDBC从数据库中查询数据

    * ResultSet 结果集:封装了使用JDBC 进行查询的结果 * 1. 调用Statement 对象的 executeQuery(sql) 方法可以得到结果集 * 2. ResultSet 返回 ...

  6. C#Web从0到1—创建一个web并从VS集成的SQLlocalDB数据库中查询数据

    软件说明: VS2017,腾讯云服务器10元1个月,系统Win2012 R2标准版 第一步:建立第一个网页 建立工程 建好后,可以打开View选项打开项目资源浏览器和工具箱,后文会多次用到这两个版面 ...

  7. SAP 从数据库中查询数据,带有where 条件。

    数据库表 代码 *& Report ZSELECT_DATA_FROM_ZMAST_CUST *&------------------------------------------- ...

  8. 向mysql数据库中插入数据时显示“Duplicate entry '1′ for key ‘PRIMARY' ”错误

    错误情况如题,出现这个错误的原因十分简单: 很明显,这是主键的问题. 在一张数据表中是不能同时出现多个相同主键的数据的 这就是错误的原因,解决的方法: 1.可以将这张表设置成无主键(mysql支持,其 ...

  9. C#-WinForm-ListView-表格式展示数据、如何将数据库中的数据展示到ListView中、如何对选中的项进行修改

    在展示数据库中不知道数量的数据时怎么展示最好呢?--表格 ListView - 表格形式展示数据 ListView 常用属性 HeaderStyle - "详细信息"视图中列标头的 ...

随机推荐

  1. LG2865 [USACO06NOV]路障Roadblocks

    题意 Bessie has moved to a small farm and sometimes enjoys returning to visit one of her best friends. ...

  2. RabbitMQ用户角色及权限控制(不错)

    ########################用户角色####################### RabbitMQ的用户角色分类:none.management.policymaker.moni ...

  3. Cache缓存优化

    降低数据库压力 <appSettings><add key="/></appSettings> //设置实体缓存时间 public RupengWang. ...

  4. install命令和cp命令的区别

    基本上,在Makefile里会用到install,其他地方会用cp命令. 它们完成同样的任务——拷贝文件,它们之间的区别主要如下: 1.最重要的一点,如果目标文件存在,cp会先清空文件后往里写入新文件 ...

  5. Generate web.xml deployment descriptor

    eclipse 使用tomcat7.0建立Dynamic Web Project 时,next至步骤“Web Module”,此时勾选选项“Generate web.xml deployment de ...

  6. python 继承进阶

    继承进阶 面向对象 1.类:具有相同属性和方法 的一类事物 类名可以实例化一个对象 类名可以调用类属性,(静态属性 和(方法)动态属性) 2.对象:也就是实例    对象名:调用对象属性 调用方法 3 ...

  7. SqlServer——判断对象是否存在

    对以下对象判断是否存在:database.table.proc.触发器.临时表.索引.对于这些对象的判断是通过数据表 SysObjects来获得的. 一.基础知识 1.SysObjects系统表 对于 ...

  8. C语言学习笔记--指针和数组的关系

    1.数组的本质 (1)数组是一段连续的内存空间 (2)数组的空间大小:sizeof(array_type)*array_size; (3)数组名可看做指向数组第一个元素的常量指针 (4)数组声明时编译 ...

  9. C#封装CRUD到SqlHelper类解读

    1.简单说明一下,一般情况下,数据库连接字符串是在App.config文件中进行配置,然后再在代码中进行引用.因此,我们在这里先看一下App.config文件. 首先看需要添加的内容: 参数说明: n ...

  10. eclipse配置hadoop location的端口号

    在eclipse下配置hadoop location的时候 hadoop端口号应该与conf文件夹下的core-site.xml以及mapred-site.xml保持一致 前者对应dfs master ...