在sql中不知道表名,但是知道字段名,怎么根据这个字段名来查询出这张表

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在sql中不知道表名,但是知道字段名,怎么根据这个字段名来查询出这张表相关的知识,希望对你有一定的参考价值。

select a.name as TableName,b.name as ColName From sysobjects a
inner 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中不知道表名,但是知道字段名,怎么根据这个字段名来查询出这张表的主要内容,如果未能解决你的问题,请参考以下文章

SQL 查表名?

sql语句怎么查询表的字段属性名

oracle中已经知道一个具体值,如何根据该值查询出含有该值的表名和列名?

编程中我只想获取SQL表字段名不要获取数据怎么做?

我知道字段内容,并不知道字段名,如何在数据库中快速找到或查询出所在的表?SQL SERVER 2000。

如何查询出一个数据库中的某个表中的某个字段?