java代码获取数据库表里数据的总数操作

 更新时间:2020年8月15日 17:22  点击:1587

在访问数据库时,特别是新手,可能会需要查询表中数据总数,以下这段代码可以非常简便的获取到数据数目

//先建立数据库连接,执行查询语句
Connection conn = DriverManager.getConnection(URL, USER, PassWord);
Statement st=conn.createStatement();
ResultSet rs =st.executeQuery("select count(*) as result from tablename");
//创建变量存取个数
int count=0;
while(rs.next())
{
count=getInt(1);
}

补充知识:JavaWeb 之 Listener监听器及Session的钝化与活化

概念

监听器用于监听web应用中某些对象、信息的创建、销毁、增加,修改,删除等动作的

发生,然后作出相应的响应处理。当范围对象的状态发生变化的时候,服务器自动调用

监听器对象中的方法。

常用于统计在线人数和在线用户,系统加载时进行信息初始化,统计网站的访问量等。

创建步骤

创建类

实现指定的监听器接口中的方法

在web.xml文件中配置监听/在类上标注@WebListener 注解

第一类:域对象监听器

监听域对象 创建与销毁的监听器

监听器接口 描述
ServletContextListener 监听Servlet上下文对象的创建、销毁
HttpSessionListener 监听会话对象的创建、销毁
ServletRequestListener 监听请求对象的创建、销毁

Servlet上下文对象 创建和销毁的监听器

public class ApplicationListener implements ServletContextListener {	
	//Servlet上下文对象创建的时候被调用
	@Override
	public void contextInitialized(ServletContextEvent contextEvent) {
		System.out.println("Servlet上下文对象被创建啦...");
		
    //项目一旦启动,此处代码运行!
		Timer timer=new Timer();
		//5秒钟之后开始执行,以后每间隔2秒发送一封邮件!
		timer.schedule(new TimerTask() {
			@Override
			public void run() {
				//System.out.println("发邮件...."+new Date());
			}
		}, 5000, 2000);
	}
	//Servlet上下文对象销毁的时候被调用
	@Override
	public void contextDestroyed(ServletContextEvent contextEvent) {
		System.out.println("Servlet上下文对象被销毁啦...");
		//服务器在停止的时候,要执行某些动作,那么就可以把代码写在这个位置!!!	
	}
}

<!-- web.xml中配置 -->
<listener>
	<listener-class>com.dream.listener.ApplicationListener</listener-class>
</listener>

会话对象 创建和销毁的监听器

@WebListener
public class SessionListener implements HttpSessionListener{
 @Override
 public void sessionCreated(HttpSessionEvent event) {
 HttpSession session = event.getSession();
 System.out.println("session对象创建啦...."+session.getId());
 }
 @Override
 public void sessionDestroyed(HttpSessionEvent event) {
 HttpSession session = event.getSession();
 System.out.println("session对象销毁啦...."+session.getId());
 }
}

请求对象的创建和销毁的监听器

@WebListener
public class RequestListener implements ServletRequestListener{

 @Override
 public void requestInitialized(ServletRequestEvent event) {
 ServletRequest request = event.getServletRequest();
 System.out.println("Request对象的创建...."+request);
 }
 @Override
 public void requestDestroyed(ServletRequestEvent event) {
 ServletRequest request = event.getServletRequest();
 System.out.println("Request对象的销毁...."+request);
 }

}

案例:统计网站在线人数

@WebListener
public class ApplicationListener implements ServletContextListener{
 @Override
 public void contextInitialized(ServletContextEvent event) {
 //项目启动,向application对象中存一个变量,初始值0
 ServletContext application = event.getServletContext(); 
 application.setAttribute("count", 0);
 }
 @Override
 public void contextDestroyed(ServletContextEvent event) {
 }
}

@WebListener
public class SessionListener implements HttpSessionListener {

 @Override
 public void sessionCreated(HttpSessionEvent event) {
 // 有人访问了 count++
 HttpSession session = event.getSession();
 ServletContext application = session.getServletContext();

 int count =(Integer) application.getAttribute("count");
 count++;
 application.setAttribute("count", count);
 }
 @Override
 public void sessionDestroyed(HttpSessionEvent event) {
 // 有人离开了 count--
 HttpSession session = event.getSession();
 ServletContext application = session.getServletContext();
 
 Integer count =(Integer) application.getAttribute("count");
 count--;
 application.setAttribute("count", count);
 }
}

第二类:属性监听器

监听域对象属性变化的监听器

监听器接口 描述
ServletContextAttributeListener 监听Servlet上下文对象属性的创建、删除、替换
HttpSessionAttributeListener 监听会话对象属性的创建、删除、替换
ServletRequestAttributeListener 监听请求对象属性的创建、删除、替换

Servlet上下文对象属性变化的监听器

@WebListener
public class ApplicationAttributeListener implements ServletContextAttributeListener{

  //Servlet上下文对象新增值的时候被调用
 @Override
 public void attributeAdded(ServletContextAttributeEvent event) {
 String str = "Servlet上下文对象中添加了属性:"+event.getName()
      +",属性值是:"+event.getValue();
 System.out.println(str);
 }
 //Servlet上下文对象删除值的时候被调用
 @Override
 public void attributeRemoved(ServletContextAttributeEvent event) {
 String str = "Servlet上下文对象中删除了属性:"+event.getName()
      +",属性值是:"+event.getValue();
 System.out.println(str);
 }
 //Servlet上下文对象替换值的时候被调用
 @Override
 public void attributeReplaced(ServletContextAttributeEvent event) {
 String str = "Servlet上下文对象中替换了属性:"+event.getName()
      +",属性值是:"+event.getValue();
 System.out.println(str);
 }
}

第三类:监听HttpSession中的对象(JavaBean)

前两类监听器是作用在 ServletContext HttpSession ServletRequest上

第三类监听器是作用在JavaBean上的。

注意:这类监听器不需要在web.xml中配置

监听器接口 描述
HttpSessionBindingListener 监听会话对象中JavaBean对象的绑定、删除
HttpSessionActivationListener 监听会话对象中JavaBean对象的钝化、活化

会话对象中JavaBean对象的绑定和删除的监听器

实现了HttpSessionBindingListener接口的JavaBean对象可以感知自己被绑定到Session中和 Session中删除的事件

当对象被绑定到HttpSession对象中时,web服务器调用该对象的

void valueBound(HttpSessionBindingEvent event)方法

当对象从HttpSession对象中解除绑定时,web服务器调用该对象的

void valueUnbound(HttpSessionBindingEvent event)方法

public class User implements HttpSessionBindingListener {
 private int id;
 private String name;

 public User() {
 }
 public User(int id, String name) {
 this.id = id;
 this.name = name;
 }
 public int getId() {
 return id;
 }
 public void setId(int id) {
 this.id = id;
 }
 public String getName() {
 return name;
 }
 public void setName(String name) {
 this.name = name;
 }
 public void valueBound(HttpSessionBindingEvent event) {
 System.out.println("对象绑定到了Session中");
 }
 public void valueUnbound(HttpSessionBindingEvent event) {
 System.out.println("对象从Session中移除");
 }
}

<%@ page import="com.dream.vo.User"%>
<%@ page language="java" pageEncoding="UTF-8"%>
<!DOCTYPE HTML>
<html>
<head>
<title>ServletContextAttributeListener监听器测试</title>
</head>
<body>
 <%
 User user = new User(1, "aaa");
 session.setAttribute("user", user);
 session.removeAttribute("user");
 %>
</body>
</html>

会话对象中JavaBean对象的钝化和活化的监听器

实现了HttpSessionActivationListener接口的JavaBean对象可以感知自己被活化(反序列化)和钝化(序列化)的事件

钝化(序列化):在内存中JavaBean对象通过Session存储硬盘的过程

活化(反序列化):从硬盘中通过Session取出JavaBean对象到内存的过程

javabean对象将要随Session对象被钝化(序列化)之前,web服务器调用该对象的

void sessionWillPassivate(HttpSessionEvent event) 方法

这样javabean对象就可以知道自己将要和Session对象一起被钝化到硬盘中

javabean对象将要随Session对象被活化(反序列化)之后,web服务器调用该对象的void sessionDidActive(HttpSessionEvent event)方法

这样javabean对象就可以知道自己将要和Session对象一起被活化回到内存中

注意: 想要随着Session 被钝化、活化的对象它的类必须实现Serializable 接口,放在

Session中没有实现Serilizable接口的对象,在Session钝化时,不会被序列化到磁盘上。

public class User implements Serializable, HttpSessionActivationListener{
 private static final long serialVersionUID = -1566395353697458460L;
 private int id;
 private String name;
 public User() {
 }
 public User(int id, String name) {
 this.id = id;
 this.name = name;
 }
 public int getId() {
 return id;
 }
 public void setId(int id) {
 this.id = id;
 }
 public String getName() {
 return name;
 }
 public void setName(String name) {
 this.name = name;
 }
 //钝化
 @Override
 public void sessionWillPassivate(HttpSessionEvent event) {
 System.out.println("对象被钝化......." + event.getSource());
 }
 //活化
 @Override
 public void sessionDidActivate(HttpSessionEvent event) {
 System.out.println("对象被活化......");
 }
}

在WebContent\META-INF文件夹下创建一个context.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<Context>
 <!-- 
 maxIdleSwap:"1": session如果1分钟没有使用就序列化
 directory: 序列化后文件所保存的路径 
 -->
 <Manager className="org.apache.catalina.session.PersistentManager"
 maxIdleSwap="1">
 <Store className="org.apache.catalina.session.FileStore"  
  directory="C:\\text" />
 </Manager>
</Context> 

面试题:Session 的钝化与活化

钝化:当服务器正常关闭时,还存活着的session(在设置时间内没有销毁) 会随着服务

器的关闭被以文件(“SESSIONS.ser”)的形式存储在tomcat 的work 目录下,这个过程叫

做Session 的钝化。

活化:当服务器再次正常开启时,服务器会找到之前的“SESSIONS.ser” 文件,从中恢

复之前保存起来的Session 对象,这个过程叫做Session的活化。

注意事项

想要随着Session 被钝化、活化的对象它的类必须实现Serializable 接口,还有的是只有在服务器正常关闭的条件下,还未超时的Session 才会被钝化成文件。当Session 超时、调用invalidate方法或者服务器在非正常情况下关闭时,Session 都不会被钝化,因此也就不存在活化。

在被钝化成“SESSIONS.ser” 文件时,不会因为超过Session 过期时间而消失,这个文件会一直存在,等到下一次服务器开启时消失。

当多个Session 被钝化时,这些被钝化的Session 都被保存在一个文件中,并不会为每个Session 都建立一个文件。

以上这篇java代码获取数据库表里数据的总数操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持猪先飞。

[!--infotagslink--]

相关文章

  • Java实现经典游戏复杂迷宫

    这篇文章主要介绍了如何利用java语言实现经典《复杂迷宫》游戏,文中采用了swing技术进行了界面化处理,感兴趣的小伙伴可以动手试一试...2022-02-01
  • PHP 数据库缓存Memcache操作类

    操作类就是把一些常用的一系列的数据库或相关操作写在一个类中,这样调用时我们只要调用类文件,如果要执行相关操作就直接调用类文件中的方法函数就可以实现了,下面整理了...2016-11-25
  • java 运行报错has been compiled by a more recent version of the Java Runtime

    java 运行报错has been compiled by a more recent version of the Java Runtime (class file version 54.0)...2021-04-01
  • C#连接SQL数据库和查询数据功能的操作技巧

    本文给大家分享C#连接SQL数据库和查询数据功能的操作技巧,本文通过图文并茂的形式给大家介绍的非常详细,需要的朋友参考下吧...2021-05-17
  • 在java中获取List集合中最大的日期时间操作

    这篇文章主要介绍了在java中获取List集合中最大的日期时间操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-08-15
  • php简单数据操作的实例

    最基础的对数据的增加删除修改操作实例,菜鸟们收了吧...2013-09-26
  • C#从数据库读取图片并保存的两种方法

    这篇文章主要介绍了C#从数据库读取图片并保存的方法,帮助大家更好的理解和使用c#,感兴趣的朋友可以了解下...2021-01-16
  • 解决Mybatis 大数据量的批量insert问题

    这篇文章主要介绍了解决Mybatis 大数据量的批量insert问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-01-09
  • Antd-vue Table组件添加Click事件,实现点击某行数据教程

    这篇文章主要介绍了Antd-vue Table组件添加Click事件,实现点击某行数据教程,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-11-17
  • 详解如何清理redis集群的所有数据

    这篇文章主要介绍了详解如何清理redis集群的所有数据,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-18
  • Intellij IDEA连接Navicat数据库的方法

    这篇文章主要介绍了Intellij IDEA连接Navicat数据库的方法,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借价值,需要的朋友可以参考下...2021-03-25
  • 在数据库里将毫秒转换成date格式的方法

    在开发过程中,我们经常会将日期时间的毫秒数存放到数据库,但是它对应的时间看起来就十分不方便,我们可以使用一些函数将毫秒转换成date格式。 一、 在MySQL中,有内置的函数from_unixtime()来做相应的转换,使用如下: 复制...2014-05-31
  • 教你怎么用Java获取国家法定节假日

    这篇文章主要介绍了教你怎么用Java获取国家法定节假日,文中有非常详细的代码示例,对正在学习java的小伙伴们有非常好的帮助,需要的朋友可以参考下...2021-04-23
  • Java如何发起http请求的实现(GET/POST)

    这篇文章主要介绍了Java如何发起http请求的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-03-31
  • 浅谈Java与C#的一些细微差别

    说起C#和Java这两门语言(语法,数据类型 等),个人以为,大概有90%以上的相似,甚至可以认为几乎一样。但是在工作中,我也发现了一些细微的差别...2020-06-25
  • vue 获取到数据但却渲染不到页面上的解决方法

    这篇文章主要介绍了vue 获取到数据但却渲染不到页面上的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-11-19
  • C#操作本地文件及保存文件到数据库的基本方法总结

    C#使用System.IO中的文件操作方法在Windows系统中处理本地文件相当顺手,这里我们还总结了在Oracle中保存文件的方法,嗯,接下来就来看看整理的C#操作本地文件及保存文件到数据库的基本方法总结...2020-06-25
  • 如何解决局域网内mysql数据库连接慢

    通过内网连另外一台机器的mysql服务, 确发现速度N慢! 等了大约几十秒才等到提示输入密码。 但是ping mysql所在服务器却很快! 想到很久之前有过类似的经验, telnet等一些服务在连接请求的时候,会做一些反向域名解析(如果...2015-10-21
  • mybatis-plus 处理大数据插入太慢的解决

    这篇文章主要介绍了mybatis-plus 处理大数据插入太慢的解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-12-18
  • php把读取xml 文档并转换成json数据代码

    在php中解析xml文档用专门的函数domdocument来处理,把json在php中也有相关的处理函数,我们要把数据xml 数据存到一个数据再用json_encode直接换成json数据就OK了。...2016-11-25