1. oracle数据库中的instr的具体用法,在网上搜了很多,最终还是不明白,请教高手解释。
首先,你运行下这句
sql">selectinstr('123,456',',')fromal
这个就是要查找逗号在123,456中的位置,结果是4,这个你应该明白吧,就是左数第4位是逗号
然后。这句
selectinstr('123,456,789',',')fromal
结果还是4,因为后边不加参数的话,就代表oracle要从最左端起,找第一个逗号,所以还是4,当你想查第二个逗号的位置的时候
selectinstr('123,456,789',',',5)fromal
后边多了一个5,也就是以5为起始位,开始找第一个逗号,所以最后结果就是8,也就是你要找的第二个逗号的位置了
4个参数
selectinstr('123,456,789',',',1,2)fromal
就是代表从第一位开始取,取第二个逗号的位置,结果是8,如果2换成3的话,因为不存在第三个逗号,所以返回0
2. 请讲解一下IIf函数和InStr函数
iif(拿到结婚证=TURE,“可以结婚”,“不可以结婚”)
instr(“你”,“哥你弟”)结果是2,因为你在其中排行老二,在第二个位置。
3. access中InStr作为文本值查询条件时,是什么意思
Access数据库支持VB内置函数InStr,该函数返回一个变体型Variant (Long)值,指定一字符串在另一字符串中最先出现的位置。
在ACCESS SQL查询语句里使用InStr函数作为筛选条件,可以起到类似“Like”运算符加“通配符”那样的模糊查询的效果、甚至更多的其他作用。下面两个例子有助理解InStr函数在查询条件中的作用:
例一,列出学生表中名字里含有“霞”字的学生的详细资料
select*from学生表whereInStr(姓名,"霞")>0;
例二,此例是稍微复杂两表模糊连接查询。要求列出”公司信息表“里”从事行业“字段内含有与”标准行业称呼表“里”行业“字段相同行业的各个公司信息
selecta.*from公司信息表a,标准行业称呼表bwhereinstr(a.从事行业,b.行业)>0;
关于InStr函数的详细说明请见附图
4. instr的用法.谢谢
InStr([start, ]string1, string2[, compare])
其中:
start:设置开始查找的位置,可以省略,省略时默认从第一个字符开始查找,
string1是源字符
string2可以说是关键字
最后一个compare别管他啥2进制,一般找字符串就理解为是否区分大小写,如你的例题,返回6的那句,把他的值设为1,就是不区分大小写,因为是从第四个字符开始往后找,而且不区分大小写,所以返回值才是6
还如你的例子,返回值是9的那句,
MyPos = Instr(1, SearchString, SearchChar, 0)
这句的意思是,从第一个字符开找,并且compare是0,就是区分大小写,所以第9个字符是大写P,所以返回值是9。
(4)数据库instr扩展阅读
instr( string1, string2, start_position,nth_appearance )
参数
string1:源字符串,要在此字符串中查找。
string2:要在string1中查找的字符串 。
start_position:代表string1 的哪个位置开始查找。此参数可选,如果省略默认为1. 字符串索引从1开始。如果此参数为正,从左到右开始检索,如果此参数为负,从右到左检索,返回要查找的字符串在源字符串中的开始索引。
nth_appearance:代表要查找第几次出现的string2. 此参数可选,如果省略,默认为 1.如果为负数系统会报错。