jdbcTemplate 操作方法

  1. /**
  2. *1.方法一:
  3. */
  4. String sql = "select * from "+ tableName;
  5. //RowCountCallbackHandler rcch = new RowCountCallbackHandler();
  6. //this.jdbcTemplateDao.query(sql, rcch);
  7. //String[] coloumnName = rcch.getColumnNames();
  8. //int[] coloumnType = rcch.getColumnTypes();
  9. SqlRowSet sqlRowSet = this.jdbcTemplateDao.queryForRowSet(sql);
  10. SqlRowSetMetaData sqlRsmd = sqlRowSet.getMetaData();
  11. int columnCount = sqlRsmd.getColumnCount();
  12. for (int i = 1; i <= columnCount; i++) {
  13. Map<String,String> fieldMap = new HashMap<String,String>();
  14. fieldMap.put("name", sqlRsmd.getColumnName(i));
  15. fieldMap.put("fieldType", String.valueOf(sqlRsmd.getColumnType(i)));
  16. tableFieldList.add(fieldMap);
  17. }
  18. /**
  19. *方法二:
  20. */
  21. String sql = "select * from "+ tableName;
  22. RowCountCallbackHandler rcch = new RowCountCallbackHandler();
  23. this.jdbcTemplateDao.query(sql, rcch);
  24. String[] coloumnName = rcch.getColumnNames();
  25. int[] coloumnType = rcch.getColumnTypes();

下面这里是JDBC的操作方法

  1. import java.sql.DriverManager;
  2. import java.sql.ResultSet;
  3. import java.sql.SQLException;
  4. import java.sql.Statement;
  5. import java.util.ArrayList;
  6. import java.util.Iterator;
  7. import java.util.List;
  8. import com.mysql.jdbc.Connection;
  9. import com.mysql.jdbc.ResultSetMetaData;
  10. public class OperateDB {
  11. public static void main(String[] args) {
  12. try {
  13. Class.forName("com.mysql.jdbc.Driver");
  14. String url = "jdbc:mysql://192.168.11.211/education?useUnicode=true&characterEncoding=utf-8";
  15. String user = "root";
  16. String password = "12345678";
  17. Connection con = (Connection) DriverManager.getConnection(url, user, password);
  18. Statement statement = con.createStatement();
  19. ResultSet result = statement.executeQuery("select * from t_sys_user");
  20. 注意,这里,完全可以操作视图,操作表的sql语句 与操作视图的sql语句一样,
  21. ResultSetMetaData metadata = (ResultSetMetaData) result.getMetaData();
  22. List<String> metadataList = new ArrayList<String>();
  23. System.out.println("====================表结构=============================");
  24. for(int i = 1; i <= metadata.getColumnCount();i++){
  25. metadataList.add(metadata.getColumnName(i));
  26. System.out.print(metadata.getColumnName(i) + "   ");   //name
  27. System.out.print(metadata.getColumnTypeName(i) + "   ");  //type
  28. System.out.print(metadata.isNullable(i) + "   ");    //null
  29. System.out.print(metadata.getColumnCharacterSet(i) + "   "); //encode
  30. System.out.println();   //key
  31. }
  32. System.out.println("====================表数据=============================");
  33. Iterator<String> i = null;
  34. String oneKey = null;
  35. while(result.next()){
  36. i = metadataList.iterator();
  37. while(i.hasNext()){
  38. oneKey = i.next();
  39. System.out.print(oneKey + ":" + result.getString(oneKey) + "    ");
  40. }
  41. System.out.println();
  42. }
  43. result.close();
  44. statement.close();
  45. con.close();
  46. } catch (ClassNotFoundException e) {
  47. e.printStackTrace();
  48. } catch (SQLException e) {
  49. e.printStackTrace();
  50. }
  51. }
  52. }
 
 

jdbcTemplate 获取数据表结构的更多相关文章

  1. jdbctemplate 获取数据表结构的方法&注意事项

    方法一 直接查询: SqlRowSet srcSqlRowSet = srcJdbcTemplate.queryForRowSet("SELECT * FROM tablename LIMI ...

  2. (笔记)Mysql命令desc:获取数据表结构

    desc命令用于获取数据表结构. desc命令格式:    desc 表名;同样    show columns from 表名;也能获取数据表结构. 举例如下:mysql> desc MyCl ...

  3. 【转】Informix数据表结构分析资料整理之约束查询代码

    原文地址:http://blog.csdn.net/xqf222/article/details/6271219 本文主要整理了Informix数据库相关系统表数据,已分析整个Informix数据表结 ...

  4. Zabbix的数据表结构

    看到Zabbix的数据表结构吧,就知道数据量大了 性能问题很让人担忧,不过基于Zabbix数据库导出报表,或自动跑报表的时候,就必须去了解一下zabbix的数据表结构了,得知道XX放在哪才能找到XX, ...

  5. 25 Zabbix系统数据表结构介绍

    点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 25 Zabbix系统数据表结构介绍 自学Zabbix之路15.1 Zabbix数据库表结构简单解 ...

  6. navicat如何导出mysql数据表结构

    我们在创建数据库时会对字段进行设置,比如类型.长度等,如果字段多的话一个个设置非常麻烦,可以从其他地方已有的表导入数据表结构,怎么操作呢?我们拿navicat导出mysql数据表结构为例: 1.点击“ ...

  7. phpmyadmin数据表结构没有显示注释列

    新开的一个项目,用phpmyadmin作为图形化操作数据库工具.创建数据表时为其每列添加好注释,浏览数据表内容有显示注释内容,但是查看数据表结构没有显示注释列,不方便直观查看数据表每列的意思. 上网搜 ...

  8. .net 调用Oracle.Data.Access 组件提供的用于批量操作的方法—获取数据库表结构方法和跟参数赋值方法

    1./// <summary> /// 获取当前目标表结构 /// </summary> /// <param name="tableName"> ...

  9. Activiti学习(二)数据表结构

    Activiti工作流引擎数据库表结构 数据库表的命名 Acitiviti数据库中表的命名都是以ACT_开头的.第二部分是一个两个字符用例表的标识.此用例大体与服务API是匹配的. l        ...

随机推荐

  1. C 语言 查找一个字符串2在字符串1中出现的次数

    #include <stdio.h> #include <windows.h> int main() { ], b[]; char *temp; ; memset( a, ); ...

  2. 二叉搜索的各种bugs——重复递增序列

    int binary_search(int* A, int value, int p, int r); int main(int argc, char *argv[]){ , , , , , , , ...

  3. 在Mac OS X中使用VIM开发STM32(3)

    本文原创于http://www.cnblogs.com/humaoxiao,非法转载者请自重!       在上一篇文章中,我们安装了ctags插件,ctags能对我们的源代码文件中的元素建立索引表, ...

  4. 网站开发常用jQuery插件总结(一)提示插件alertify

    1.alertify插件功能 主要实现提示功能,用于代替js中的alert,confirm,prompt,显示友好的提示框 2.alertify官方地址 http://fabien-d.github. ...

  5. .NET平台开源项目速览-最快的对象映射组件Tiny Mapper之项目实践

    心情小札:近期换了工作,苦逼于22:00后下班,房间一篇狼藉~ 小翠鄙视到:"你就适合生活在垃圾堆中!!!" 晚上浏览博客园 看到一篇非常实用的博客:.NET平台开源项目速览(14 ...

  6. js实现瀑布流的一种简单方法实例分享

    现在说瀑布流式布局似乎有点晚了,但是每一项技术都是向着“精”和“简”的方向在不断发展,在发展到极致之前,需要一个相当漫长的过程,因此,从这个角度来说,当瀑布流被应用得越来越多的时候,反而更应该讨论它, ...

  7. struts2 修改action的后缀

    struts2 修改action的后缀 struts2 的默认后缀是 .action 虽然很直观,但是很烦琐.很多人喜欢将请求的后缀改为 .do 在struts2中修改action后缀有两种比较简单的 ...

  8. 1.Bloom filter

    Bloom filter 是由 Howard Bloom 在 1970 年提出的二进制向量数据结构,它具有很好的空间和时间效率,被用来检测一个元素是不是集合中的一个成员,这种检测只会对在集合内的数据错 ...

  9. UNICODE编码表

    UNICODE简介 Unicode(统一码.万国码.单一码)是一种在计算机上使用的字符编码.Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进 ...

  10. JLOI 2013 卡牌游戏

    问题描述: N个人坐成一圈玩游戏.一开始我们把所有玩家按顺时针从1到N编号.首先第一回合是玩家1作为庄家.每个回合庄家都会随机(即按相等的概率)从卡牌堆里选择一张卡片,假设卡片上的数字为X,则庄家首先 ...