JDBC学习总结(三)
package com.yyq.resultset;
import com.yyq.factory.CloseFactory;
import com.yyq.factory.ConnectionFactory;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
/**
* Created by gao on 16-4-13.
*/
public class ResultSetTest {
public static void testPager(int firstResult, int maxResults) {
Connection conn = ConnectionFactory.getConnection();
PreparedStatement pstmt = null;
ResultSet rs = null;
String sql = "select id,name,score,class from student";
try {
//可滚动的,只读的结果集
pstmt = conn.prepareStatement(sql, ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
rs = pstmt.executeQuery();
//光标移到最后一行
rs.absolute(-1); //rs.last();
//获取总记录数
int count = rs.getRow();
System.out.println("Recorder SUM:" + count);
//光标移到指定行的前一行
rs.absolute(firstResult - 1);
for (int i = 0; i < maxResults; i++) {
if (rs.next()) {
System.out.println(rs.getInt(1) + ", " + rs.getString(2) + ", " + rs.getString(4) + ", " + rs.getInt(3));
} else {
break;
}
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
CloseFactory.close(pstmt, conn);
}
}
public static void main(String[] args) {
ResultSetTest.testPager(6, 12);
}
}
package com.yyq.resultset;
import com.yyq.factory.CloseFactory;
import com.yyq.factory.ConnectionFactory;
import java.sql.*;
/**
* Created by gao on 16-4-13.
*/
public class ResultSetMetaDataTest {
public static void test() {
Connection conn = ConnectionFactory.getConnection();
PreparedStatement pstmt = null;
ResultSet rs = null;
String sql = "select * from student";
try {
//可滚动的,只读的结果集
pstmt = conn.prepareStatement(sql);
rs = pstmt.executeQuery();
//在结果集上获取元数据
ResultSetMetaData rsmd = rs.getMetaData();
int count = rsmd.getColumnCount(); //获取总列(字段)数
System.out.println("ColumnCount:" + count);
for (int i = 1; i <= count; i++) {
System.out.println("No:" + i);
System.out.println("Catalog Name:" + rsmd.getCatalogName(i));
System.out.println("Data Type Class:" + rsmd.getColumnClassName(i));
System.out.println("ColumnDisplaySize:" + rsmd.getColumnDisplaySize(i));
System.out.println("ColumnLabel:" + rsmd.getColumnLabel(i));
System.out.println("Column Type:" + rsmd.getColumnType(i));
System.out.println("Column Type Name:" + rsmd.getColumnTypeName(i));
System.out.println("Precision:" + rsmd.getPrecision(i));
System.out.println("Scale"+rsmd.getScale(i));
System.out.println("SchemaName:"+rsmd.getSchemaName(i));
System.out.println("Table Name:"+rsmd.getTableName(i));
System.out.println("IsAutoIncrement:"+rsmd.isAutoIncrement(i));
System.out.println("IsCurrency:"+rsmd.isCurrency(i));
System.out.println("IsNullable:"+rsmd.isNullable(i));
System.out.println("IsReadOnly:"+rsmd.isReadOnly(i));
System.out.println("isSearchable:"+rsmd.isSearchable(i));
System.out.println();
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
CloseFactory.close(pstmt, conn);
}
}
public static void main(String[] args) {
ResultSetMetaDataTest.test();
}
}
JDBC学习总结(三)的更多相关文章
- JDBC学习笔记(三)
获取数据库的元信息metadata,里面有数据库特性的描述信息,如是否支持事务,是否支持批处理等. Connection conn = DriverManager.getConnection(url, ...
- Quartz定时任务学习(二)web应用/Quartz定时任务学习(三)属性文件和jar
web中使用Quartz 1.首先在web.xml文件中加入 如下内容(根据自己情况设定) 在web.xml中添加QuartzInitializerServlet,Quartz为能够在web应用中使用 ...
- MyBatis学习系列三——结合Spring
目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring MyBatis在项目中应用一般都要结合Spring,这一章主要把MyBat ...
- JDBC学习笔记(2)——Statement和ResultSet
Statement执行更新操作 Statement:Statement 是 Java 执行数据库操作的一个重要方法,用于在已经建立数据库连接的基础上,向数据库发送要执行的SQL语句.Statement ...
- JDBC学习笔记(1)——JDBC概述
JDBC JDBC API是一个Java API,可以访问任何类型表列数据,特别是存储在关系数据库中的数据.JDBC代表Java数据库连接. JDBC库中所包含的API任务通常与数据库使用: 连接到数 ...
- 【转】MyBatis学习总结(三)——优化MyBatis配置文件中的配置
[转]MyBatis学习总结(三)——优化MyBatis配置文件中的配置 一.连接数据库的配置单独放在一个properties文件中 之前,我们是直接将数据库的连接配置信息写在了MyBatis的con ...
- 【转】JDBC学习笔记(2)——Statement和ResultSet
转自:http://www.cnblogs.com/ysw-go/ Statement执行更新操作 Statement:Statement 是 Java 执行数据库操作的一个重要方法,用于在已经建立数 ...
- 【转】JDBC学习笔记(1)——JDBC概述
转自:http://www.cnblogs.com/ysw-go/ JDBC JDBC API是一个Java API,可以访问任何类型表列数据,特别是存储在关系数据库中的数据.JDBC代表Java数据 ...
- jdbc学习总结
jdbc学习总结: 一.简介: jdbc,直译为java连接数据库.实际为java为很好的操作数据库而提供的一套接口,接口的实现(即驱动)由各个数据库厂商提供. 二.知识要点: 连接5要素,3 ...
随机推荐
- ProgressDialog弹出时的底色变暗(转)
背景:在做一个进度条时,不想让它的背景变暗,以免影响其他区域的正常显示. 在网上搜索时,看到的方法多数是: 方法一 :在代码中 可以这么设置 Window mWindow = getWindow(); ...
- PVPGN 暗黑破坏神2 1.11b战网配置问题汇总
写了第一篇配置指南之后,很多人向我咨询有关战网搭建的问题.于是觉得很有必要把若干常见的问题,和常用的进阶配置汇总一下,以方便更多人. 1.游戏版本和PVPGN与D2GS版本的问题. PVPGN建议选择 ...
- php中的性能挖掘
搞php以后,感觉总是很别扭,因为我觉得php会很慢,因为array普遍,在Key的循环查找不是很浪费性能么!因为我以前搞.net和java,他们是用的大多是寻址和索引方式,而php中太多是使用Key ...
- oracle——merge
一.概述 使用merge声明从一个或者更多个表或视图中筛选记录,以用来更新或者插入到一个表或视图中.你可以指定条件以决定是执行update操作还是insert操作到目标表或视图中. 这个声明是一个 ...
- C#枚举注释实例
public enum 枚举名称 { /// <summary> /// 注释描述1 /// </summary> ...
- ural 1864
题意描述不清 而且还卡精度 ~~ #include <cstdio> #include <cstring> #include <iostream> using ...
- 无法将 lambda 表达式 转换为类型“System.Delegate”,因为它不是委托类型
this.BeginInvoke(() => { this.btnQuery.Enabled = false; //禁用查询 }); 跨线程调用时,编译上面的代码将提示 对于Control.In ...
- CentOS安装视频播放器SMPlayer
首先下载rpmforg,下载对应的版本,就是对应CentOS版本,还有32位与64位也要对应上.地址如下: http://wiki.centos.org/AdditionalResources/Rep ...
- Class Object
java.lang Class Object java.lang.Object public class Object Class Object is the root of the class hi ...
- 【好玩的应用】QQ连连看辅助工具
自己学了这么久的C语言,但没有写出过什么可以用的东西来,总觉得心里不爽.这几天实在是不想干正事,在网上瞎逛逛,结果发现有人写了连连看的外挂.顿时觉得这很有意思啊.于是把代码下载下来,捣鼓了捣鼓.发现还 ...