高分请问下,如何通过一个值查找到值所在的SQL数据库表??
由于没有系统的源码和开发文档,系统的表有200多个,所有可猜测到的表命名规则都找了都找不到。有没有什么方法可以通过一个已知的值,找到这个值所在的表?http://zhidao.baidu.com/question/48726567.html#irelatelink
这里搜到一个方法,但我没有执行成功,应该是要建一个存储过程吧?
高分请问下,如何通过一个值查找到值所在的SQL数据库表??
由于没有系统的源码和开发文档,系统的表有200多个,所有可猜测到的表命名规则都找了都找不到。有没有什么方法可以通过一个已知的值,找到这个值所在的表?2024-10-17 13:48:08
1、首先新建一张最简单的数据库表,id自增长。
2、然后在表中插入重复值。
3、接着新建视图,首先要确定自己的删除规则是什么样的,删除编号id比较大的还是比较小的。
4、然后将视图select语句粘贴到删除语句后面,执行删除语句。
5、最后查看删除后结果,就完成了。
2024-10-17 08:39:40
1、当这个数据为数据库中的某一列的列名的时候,我们如何通过该列名获取到表名呢?登录mysql的客户端,并输入sql语句select * from columns where column_name='DEPT_NAME';其中DEPT_NAME为查找的列名。
2、点击上图的运行按钮,执行该命令,可以看到运行结果如下所示,列名为DEPT_NAME的表为department。
2024-10-17 12:35:49
可用如下代码实现:
declare @cloumns varchar(40)
declare @tablename varchar(40)
declare @str varchar(40)
declare @counts int
declare @sql nvarchar(2000)
declare MyCursor Cursor For
Select a.name as Columns, b.name as TableName from syscolumns a,sysobjects b,systypes c
where a.id = b.id
and b.type = 'U'
and a.xtype=c.xtype
and c.name like '%char%'
set @str='张三'
Open MyCursor
Fetch next From MyCursor Into @cloumns,@tablename
While(@@Fetch_Status = 0)
Begin
set @sql='select @tmp_counts=count(*) from ' +@tablename+ ' where ' +@cloumns+' = ''' +@str+ ''''
execute sp_executesql @sql,N'@tmp_counts int out',@counts out
if @counts>0
begin
print '表名为:'+@tablename+',字段名为'+@cloumns
end
Fetch next From MyCursor Into @cloumns,@tablename
End
Close MyCursor
Deallocate MyCursor
如本题,是查找库中,包含“张三”的数据的表。
结果如图:
2024-10-17 11:58:46
2024-10-17 11:22:38