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

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

//先建立数据库连接,执行查询语句
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代码获取数据库表里数据的总数操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • java中ResultSet遍历数据操作

    1.查找数据库中表的列名 <pre name="code" class="html">String sql = "select *from tblmetadatainfo"; ResultSet rs = MySqlHelper.executeQuery(sql, null); String str=""; try { ResultSetMetaData rsmd = rs.getMetaData(); for (

  • Java如何利用POI读取Excel行数

    这篇文章主要介绍了java如何利用POI读取Execel行数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 java 利用poi 读excel文件的操作,读取总的数据行数一般是通过调用 sheet.getLastRowNum() ;可是这样有时候会出现一些问题,例如,当其中一行的数据的确都为空,可是其原本的格式还在,并没有连带删除,这样计算出来的行数就不真实(比真实的大),还有当出现空白行时(也即某一行没有任何数据,通过Row row = sh

  • java提取json中某个数组的所有值方法

    实例如下所示: public class JsonExtracter { public static void main(String[] args) { String s = "{\"name\":\"a\",\"family\":[\"张三\",\"李四\"]}"; JSONObject jsonObject = JSON.parseObject(s); //注意:family中的内

  • Java mysql数据库并进行内容查询实例代码

    Java  mysql数据库并进行内容查询 最近用框架做了几个项目,感觉当初底层的东西有点忘了,写一个JDBC的简单的连接代码来熟悉回顾一下,也希望对刚接触的新手能有所帮助.这也是我的第一篇随笔,废话不多说,直接上代码: public Connection getCon() { //数据库连接名称 String username="root"; //数据库连接密码 String password=""; String driver="com.mysql.j

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

    在访问数据库时,特别是新手,可能会需要查询表中数据总数,以下这段代码可以非常简便的获取到数据数目 //先建立数据库连接,执行查询语句 Connection conn = DriverManager.getConnection(URL, USER, PassWord); Statement st=conn.createStatement(); ResultSet rs =st.executeQuery("select count(*) as result from tablename")

  • java代码获取jenkins数据,构建历史等信息方式

    本篇文章主要介绍如何获取jenkins构建历史数据等信息,不包含java构建等操作. 1.jenkins所需jar,后续如有缺少可百度自行补齐. <!--jenkins所需jar包开始--> <!-- https://mvnrepository.com/artifact/org.apache.httpcomponents/httpclient --> <dependency> <groupId>org.apache.httpcomponents</gr

  • php获取数据库中数据的实现方法

    废话不多说,直接上代码 <?php header("Content-type:text/html;charset=utf-8");//字符编码设置 $servername = "localhost"; $username = "root"; $password = "root"; $dbname = "web"; // 创建连接 $con =mysqli_connect($servername, $u

  • 使用java代码获取新浪微博应用的access token代码实例

    本文实例为大家分享了java代码获取新浪微博应用的access token的具体代码,供大家参考,具体内容如下 package test; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.net.URI; import java.net.URISyntaxException; im

  • Java连接Sql数据库经常用到的操作

    废话不多说了,直接给大家分享java操作sql数据库常见的连接问题. 1.连接,查询,更新,关闭 这几个数据基础操作,所以放到一起,写成一个工具类的模式,也就是model2模式的sql工具.这里本想把其他操作都加进去,比如事务处理,但是目前还没想到比较完美的方法,具体看代码吧,注释很详细 import java.sql.*; import java.util.Iterator; import java.util.Map; import java.util.Set; /** * Created b

  • 编写Java代码对HDFS进行增删改查操作代码实例

    本文实例为大家分享了Java代码对HDFS进行增删改查操作的具体代码,供大家参考,具体内容如下 import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.net.URI; import org.apache.commons.compress.utils.IOUtils; import org.apache.hadoop.conf.Configuration; impo

  • 基于JAVA代码 获取手机基本信息(本机号码,SDK版本,系统版本,手机型号)

    老风格,废话不多说了,直接给大家贴java代码了. 代码如下: package com.zzw.getPhoneInfos; import android.app.Activity; import android.content.Context; import android.os.Build; import android.os.Bundle; import android.telephony.TelephonyManager; import android.util.Log; public

  • 使用Java代码获取服务器性能信息及局域网内主机名

    最近做个项目,就是要取得cpu占有率等等的系统信息,一开始以为要用动态链接库了,但后来发现可以像下面这样做,不去调用jni,这样省去了很多看新技术的时间o(∩_∩)o... 在Java中,可以获得总的物理内存.剩余的物理内存.已使用的物理内存等信息,下面例子可以取得这些信息,并且获得在Windows下的内存使用率.      首先编写一个MonitorInfoBean类,用来装载监控的一些信息,包括物理内存.剩余的物理内存.已使用的物理内存.内存使用率等字段,该类的代码如下: package c

  • java URL 获取PHP JSON 数据

    1:php地址  http://127.0.0.6/?c=json 2:java 输出的结果是 [{"id":1,"name":"zhdc"},{"id":2,"name":"\u5c0f\u6731"}] index.php <?php if(isset($_REQUEST['c'])){ $c = $_REQUEST['c']; if($c == "json"

  • java反射获取包下所有类的操作

    我就废话不多说了,大家还是直接看代码吧~ public static void main(String[] args) { try { // 获取包名下所有类 Set<Class<?>> classes = getClasses("com"); for(Class c:classes){ // 打印有RestController 的类 if(c.isAnnotationPresent(RestController.class)){ System.out.prin

随机推荐