在sql中不知道表名,但是知道字段名,怎么根据这个字段名来查询出这张表
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在sql中不知道表名,但是知道字段名,怎么根据这个字段名来查询出这张表相关的知识,希望对你有一定的参考价值。
select a.name as TableName,b.name as ColName From sysobjects ainner join syscolumns b on (a.id=b.id)
where a.xtype='U' and b.name=字段名
这里面的是根据字段名来查询的,如果要想根据字段值来查询,需要在此基础上用游标来查了 参考技术A 提供下是哪个数据库
oracle的话可以根据
select table_name,column_name from dba_tab_cols where owner='用户名' and column_name='字段名'; 参考技术B 如果你用的oracle;
SELECT table_name FROM user_tab_columns WHERE column_name = ‘字段' 。
4楼好像写的跟我一样啊。 参考技术C 是什么语句 参考技术D 什么数据库?
hibernate 直接通过表名,获取字段名及字段类型??
hibernate是一个orm面向对象操作的框架,将表映射成一个PO实体类,表的字段映射为PO的字段,表的每一条记录映射为PO的实例。 但是hibernate也是支持原生态的SQL,也是可以通过select t.name from T_User t where t.id = ? 这种方式获取结果 参考技术A /*** 功能描述:根据实体类得到对应的表名、主键名、字段名工具类
* </p>
* 注:po类名须与对应映射文件名一致,即Student.java与Student.hbm.xml
*
* @Date:Nov 10, 2008
* @Time:3:13:07 PM
*
*/
public class HibernateConfigurationHelper
private static Configuration hibernateConf;
@SuppressWarnings("unused")
private static Configuration getHibernateConf()
if (hibernateConf == null)
return new Configuration();
return hibernateConf;
@SuppressWarnings("unchecked")
private static PersistentClass getPersistentClass(Class clazz)
synchronized (HibernateConfigurationHelper.class)
PersistentClass pc = getHibernateConf().getClassMapping(
clazz.getName());
if (pc == null)
hibernateConf = getHibernateConf().addClass(clazz);
pc = getHibernateConf().getClassMapping(clazz.getName());
return pc;
/**
* 功能描述:获取实体对应的表名
*
* @param clazz
* 实体类
* @return 表名
*/
@SuppressWarnings("unchecked")
public static String getTableName(Class clazz)
return getPersistentClass(clazz).getTable().getName();
/**
* 功能描述:获取实体对应表的主键字段名称
*
* @param clazz
* 实体类
* @return 主键字段名称
*/
@SuppressWarnings("unchecked")
public static String getPkColumnName(Class clazz)
return getPersistentClass(clazz).getTable().getPrimaryKey()
.getColumn(0).getName();
/**
* 功能描述:通过实体类和属性,获取实体类属性对应的表字段名称
*
* @param clazz
* 实体类
* @param propertyName
* 属性名称
* @return 字段名称
*/
@SuppressWarnings("unchecked")
public static String getColumnName(Class clazz, String propertyName)
PersistentClass persistentClass = getPersistentClass(clazz);
Property property = persistentClass.getProperty(propertyName);
Iterator it = property.getColumnIterator();
if (it.hasNext())
Column column = (Column) it.next();
return column.getName();
return null;
/**
* @param args
*/
public static void main(String[] args)
System.out.println(getTableName(IntelligenceNetVPNAndSCP.class));
System.out.println(getColumnName(IntelligenceNetVPNAndSCP.class,
"vsCode"));
参考技术B hibernate是将数据库中的表与类进行关联的OR Mapping映射,将数据库中的表映射到实体类中了。 参考技术C 不是表名,映射过来的类名, 参考技术D hibernate 没有表名的概念 只有类名的概念
以上是关于在sql中不知道表名,但是知道字段名,怎么根据这个字段名来查询出这张表的主要内容,如果未能解决你的问题,请参考以下文章
oracle中已经知道一个具体值,如何根据该值查询出含有该值的表名和列名?