首页
Web开发
Windows程序
编程语言
数据库
移动开发
系统相关
微信
其他好文
会员
首页
>
数据库
> 详细
jdbcTemplate 获取数据表结构
时间:
2016-03-02 09:28:40
阅读:
250
评论:
0
收藏:
0
[点我收藏+]
标签:
jdbcTemplate 操作方法
Java代码
/**
*1.方法一:
*/
String sql =
"select * from "+ tableName;
//RowCountCallbackHandler rcch = new RowCountCallbackHandler();
//this.jdbcTemplateDao.query(sql, rcch);
//String[] coloumnName = rcch.getColumnNames();
//int[] coloumnType = rcch.getColumnTypes();
SqlRowSet sqlRowSet =
this.jdbcTemplateDao.queryForRowSet(sql);
SqlRowSetMetaData sqlRsmd = sqlRowSet.getMetaData();
int columnCount = sqlRsmd.getColumnCount();
for (
int i =
1; i <= columnCount; i++) {
Map<String,String> fieldMap =
new HashMap<String,String>();
fieldMap.put(
"name", sqlRsmd.getColumnName(i));
fieldMap.put(
"fieldType", String.valueOf(sqlRsmd.getColumnType(i)));
tableFieldList.add(fieldMap);
}
/**
*方法二:
*/
String sql =
"select * from "+ tableName;
RowCountCallbackHandler rcch =
new RowCountCallbackHandler();
this.jdbcTemplateDao.query(sql, rcch);
String[] coloumnName = rcch.getColumnNames();
int[] coloumnType = rcch.getColumnTypes();
下面这里是JDBC的操作方法
Java代码
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import com.mysql.jdbc.Connection;
import com.mysql.jdbc.ResultSetMetaData;
public
class OperateDB {
public
static
void main(String[] args) {
try {
Class.forName(
"com.mysql.jdbc.Driver");
String url =
"jdbc:mysql://192.168.11.211/education?useUnicode=true&characterEncoding=utf-8";
String user =
"root";
String password =
"12345678";
Connection con = (Connection) DriverManager.getConnection(url, user, password);
Statement statement = con.createStatement();
ResultSet result = statement.executeQuery(
"select * from t_sys_user");
注意,这里,完全可以操作视图,操作表的sql语句 与操作视图的sql语句一样,
ResultSetMetaData metadata = (ResultSetMetaData) result.getMetaData();
List<String> metadataList =
new ArrayList<String>();
System.out.println(
"====================表结构=============================");
for(
int i =
1; i <= metadata.getColumnCount();i++){
metadataList.add(metadata.getColumnName(i));
System.out.print(metadata.getColumnName(i) +
" ");
//name
System.out.print(metadata.getColumnTypeName(i) +
" ");
//type
System.out.print(metadata.isNullable(i) +
" ");
//null
System.out.print(metadata.getColumnCharacterSet(i) +
" ");
//encode
System.out.println();
//key
}
System.out.println(
"====================表数据=============================");
Iterator<String> i =
null;
String oneKey =
null;
while(result.next()){
i = metadataList.iterator();
while(i.hasNext()){
oneKey = i.next();
System.out.print(oneKey +
":" + result.getString(oneKey) +
" ");
}
System.out.println();
}
result.close();
statement.close();
con.close();
}
catch (ClassNotFoundException e) {
e.printStackTrace();
}
catch (SQLException e) {
e.printStackTrace();
}
}
}
jdbcTemplate 获取数据表结构
标签:
原文地址:http://www.cnblogs.com/toSeeMyDream/p/5233547.html
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年07月29日 (22)
2021年07月28日 (40)
2021年07月27日 (32)
2021年07月26日 (79)
2021年07月23日 (29)
2021年07月22日 (30)
2021年07月21日 (42)
2021年07月20日 (16)
2021年07月19日 (90)
2021年07月16日 (35)
周排行
更多
数据库进阶
2021-07-29
在 Oracle 数据库中执行 SQL 语句遇到特殊字符的转义方式
2021-07-28
Windows Logstash同步 Sqlserver 到Elasticsearch
2021-07-26
mysql数据库(11):恢复数据
2021-07-26
mysql数据库(9):常用查询的例子
2021-07-26
SQLAlchemy 多对多
2021-07-26
ClickHouse的JDBC连接
2021-07-26
Apache HBase 1.7.1 发布,分布式数据库
2021-07-26
数据库常用架构和同步工作原理
2021-07-26
MySQL数据库设计规范(仅供参考)
2021-07-26
友情链接
兰亭集智
国之画
百度统计
站长统计
阿里云
chrome插件
新版天听网
关于我们
-
联系我们
-
留言反馈
© 2014
mamicode.com
版权所有 联系我们:gaon5@hotmail.com
迷上了代码!