sqlonlike
① sql 的like语句
like后面的匹配字符不加通配符 % 的话就跟 = 是一样的。
② SQL交叉表On条件是否可以用like连接
select
a.ID,a.DEP,
sum(casewhenb.WENJIAN_LEIXING='文件'then1else0end)文件,
sum(casewhenb.WENJIAN_LEIXING='通知'then1else0end)通知
fromDEPaleftjoinWENJIANbona.id=b.DEP_ID
groupbya.ID,a.DEP
;
③ SQL 语句 inner join的用法,想用like,不用“=”。我想模糊查询,请高手指点。
输入SELECT * FROM dbo.employers a INNER JOIN dbo.JobseekeSortingCompany b ON a.company_name LIKE '%'+b.companykw+'%'即可。
④ mysql 左连接 on 后面条件用like
当我创建一个新项目时(我用的是RadRails IDE),选中连接mysql并出现欢迎(not necessary on OS X Leopard) development: adapter: sqlite3 database:
⑤ SQL中like的用法
LIKE是另一个在WHERE子句中会用到的指令。基本上,LIKE能让我们依据一个套(pattern) 来找出我们要的资料。相对来说,在运用IN的时候,我们完全地知道我们需要的条件;在运用BETWEEN的时候,我们则是列出一个范围。LIKE的语法如下:
⑥ SQL语句like怎么使用多个like条件...
方法和详细的操作步骤如下:
1、第一步,新建测试表,见下图,转到下面的步骤。
⑦ sql查询 =和like的区别
很奇怪的现象。
07年的时候,数据库是9.2.0.8,我们数据库出过1次不可思议的问题,要like才能出来,=出不来的怪现象。找了metalink,也觉得是不可能的事情,不了了之。不过,数据库重启后,没有了此现象。
⑧ sql语句中的like可以用什么代替
可以使用CHARINDEX 和 PATINDEX两种函数,但是速度不一定快,这要分情况的。
以下引用自SQL使用帮助:
CHARINDEX
返回字符串中指定表达式的起始位置。
语法
CHARINDEX ( expression1 , expression2 [ , start_location ] )
参数
expression1
一个表达式,其中包含要寻找的字符的次序。expression1 是一个短字符数据类型分类的表达式。
expression2
一个表达式,通常是一个用于搜索指定序列的列。expression2 属于字符串数据类型分类。
start_location
在 expression2 中搜索 expression1 时的起始字符位置。如果没有给定 start_location,而是一个负数或零,则将从 expression2 的起始位置开始搜索。
PATINDEX
返回指定表达式中某模式第一次出现的起始位置;如果在全部有效的文本和字符数据类型中没有找到该模式,则返回零。
语法
PATINDEX ( '%pattern%' , expression )
参数
pattern
一个字符串。可以使用通配符,但 pattern 之前和之后必须有 % 字符(搜索第一个和最后一个字符时除外)。pattern 是短字符数据类型类别的表达式。
expression
一个表达式,通常为要在其中搜索指定模式的列,expression 为字符串数据类型类别。
比较
CHARINDEX 和 PATINDEX
CHARINDEX 和 PATINDEX 函数都返回指定模式的开始位置。PATINDEX 可使用通配符,而 CHARINDEX 不可以。
这两个函数都带有两个参数:
希望获取其位置的模式。使用 PATINDEX,模式是可以包含通配符的字面字符串。使用 CHARINDEX,模式是字面字符串(不能包含通配符)。
字符串值表达式(通常为列名),Microsoft® SQL Server™ 在其中搜索指定的模式。
例如,查找模式"wonderful"在 titles 表中 notes 列的某一特定行中的开始位置。
USE pubs
SELECT CHARINDEX('wonderful', notes)
FROM titles
WHERE title_id = 'TC3218'
下面是结果集:
----------------
46
(1 row(s) affected)
如果未限制搜索的行,查询将返回表中的所有行,并对在其中查找到该模式的所有行报告非零值,对其它行报告零值。
例如,使用通配符查找模式"candies"在 Categories 表中的 Description 列的任一行中的开始位置:
USE Northwind
GO
SELECT CategoryID, PATINDEX('%candies%', Description)AS POSITION
FROM Categories
WHERE PATINDEX('%candies%', Description) <> 0
如果没有限制要搜索的行,查询将返回表中的所有行,对在其中找到该模式的所有行报告非零值。
PATINDEX 对 text 数据类型很有用;除 IS NULL、IS NOT NULL 和 LIKE(这些是 WHERE 子句中对 text 类型有效的仅有的其它比较运算)外,PATINDEX 也可用于 WHERE 子句中。
⑨ SQL LIKE模糊查询
--下面这个应该是可以的!
create proc procget --[存储过程名]
@proc1 varchar(50),--这个是一定要存在的参数
@proc2 varchar(50),
@proc3 varchar(50)
as
--定义一个要执行的字符串语句
declare @aa varchar(200)
set @aa = 'select * from TA where ' + '[表中的列名] like ' + '''%' + @proc1 + '%'''
--组合要执行的语句
--如果参数为空,就加上字符空串,否则就加上相应的条件语句
set @aa = @aa + case when @proc2 is null then '' else ' and [表中列名] like'+'''%'+@proc2+ '%''' end
set @aa = @aa + case when @proc3 is null then '' else ' and [表中列名] like'+'''%'+@proc3+ '%''' end
--执行语句
exec(@aa)