sql语句包含可写成:select * from table1 where field1 like ’%value1%’(所有包含‘value1’这个模式的字符串)。
sql语句用于数据库查询和程序设计,比如查询表中某字段值“包含”某字符串的所有记录的方法如下:
如果表中有一个name字段,查询name包含“张三”的所有记录,就可以这样写:Stirng strsql="SELECT * FROM 表名 WHERE name LIKE ’%"+"张三"+"%’"。
扩展资料
sql语句包含的关联词
据了解,sql语句查询某字段值“包含于”某个字符串的所有记录的方法如下:
如果查询表中name字段包含于字符串“张三是个好学生”的所有记录,就可以这样写:String strsql="SELECT * FROM 表名 WHERE INSTR(’张三是个好学生’,name)>0"(记录中的name字段值中包括张、三、是、个、好、学、生、张三等所有记录)。
参考资料来源:百度百科-sql语句。
SQL数据库,查询包含列(字段,如名称)的数据库中的所有表的步骤如下:需要准备的材料是:计算机,sql finder。
1,首先,打开sql查询器并连接到相应的数据连接,例如测试库。
2,单击“查询”按钮并键入:select table_name来自information_schema.columns,其中table_schema =“test”和column_name =“name”;。
3,单击“运行”按钮,将查询符合条件的表名称。
4,将查询调整为:选择'store'作为table_name,`name`来自商店,其中`name` =“A”union all选择'stu'作为table_name,`name`来自stu where`name` =“A”Union所有选择'test'作为table_name,`name`来测试`name` =“A”,单击“运行”按钮查找名称为'A'的表的名称。
这种情况需要写存储过程,进行全库搜索。代码如下:
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 '%varchar%'。
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。
注意:其中“张三”为要查找的字符串,可以替换成其他的,如果查询的字符串超长,需要在定义变量时适当扩大长度。
可以替换成其他的,如果查询的字符串超长,需要在定义变量时适当扩大长度。
结构化查询语言(StructuredQueryLanguage)简称SQL(发音:/ˈeskjuːˈel/"S-Q-L"),是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。
结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作。它不要求用户指定对数据的存放方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统,可以使用相同的结构化查询语言作为数据输入与管理的接口。结构化查询语言语句可以嵌套,这使它具有极大的灵活性和强大的功能。
1986年10月,美国国家标准协会对SQL进行规范后,以此作为关系式数据库管理系统的标准语言(ANSIX3.135-1986),1987年得到国际标准组织的支持下成为国际标准。不过各种通行的数据库系统在其实践过程中都对SQL规范作了某些编改和扩充。所以,实际上不同数据库系统之间的SQL不能完全相互通用。
--我这里说的字段名跟列
是同一个意思
select
column_name,
table_name,data_type。
,data_length,data_precision,data_scale。
from
user_tab_columns。
where
column_name='字段名';。
--根据字段名查出相关的表名出来。记录下来。
--然后对查出来的表进行查询,找到含这内容字段的表。
select
from
表名
where
字段名='xiaoming'
我查出来的有800多个表,有没有什么方法能更便捷一些。
能查出来
内容
包含‘xiaoming’的
declare
l_cnt
varchar2(20);
v_sql
varchar2(4000);。
v_tablename
varchar(200);
cursor
cursor_jsdx
is
select
'select
count(*)
from
||
table_name
||
where
NAME=''xiaoming''',table_name。
from
user_tab_columns。
where
column_name='NAME';。
--注:这里的字段名要大写
begin
open
cursor_jsdx;
Loop
fetch
cursor_jsdx
into
v_sql,v_tablename;。
exit
when
cursor_jsdx%notfound;。
execute
immediate
v_sql
into
l_cnt;
if
l_cnt
>0
then
---如果该表有那内容的就打印那个表的名字。
dbms_output.put_line(v_tablename);。
end
if;
end
loop;
Close
cursor_jsdx;
end;
第一,你这个区分大小写不?看你a1是大写,b,c都小写了?
第二,什么数据库?每个数据库语法不同,有差别。
还有,你数据的图没看懂,好好重新说一遍。
原文地址:http://www.qianchusai.com/sql%E5%8C%85%E5%90%AB%E6%9F%90%E4%B8%AA%E5%AD%97%E6%AE%B5.html