Oracle截取字符串和查找字符串

oracle 截取字符(substr),检索字符位置(instr) case when then else end语句使用 收藏
常用函数:substr和instr
1.SUBSTR(string,start_position,[length])    求子字符串,返回字符串
解释:string 元字符串
       start_position   开始位置(从0开始)
       length 可选项,子字符串的个数
For example:
substr("ABCDEFG", 0); //返回:ABCDEFG,截取所有字符
substr("ABCDEFG", 2); //返回:CDEFG,截取从C开始之后所有字符
substr("ABCDEFG", 0, 3); //返回:ABC,截取从A开始3个字符
substr("ABCDEFG", 0, 100); //返回:ABCDEFG,100虽然超出预处理的字符串最长度,但不会影响返回结果,系统按预处理字符串最大数量返回。
substr("ABCDEFG", 0, -3); //返回:EFG,注意参数-3,为负值时表示从尾部开始算起,字符串排列位置不变。

2.INSTR(string,subString,position,ocurrence)查找字符串位置
解释:string:源字符串
      subString:要查找的子字符串
      position:查找的开始位置
      ocurrence:源字符串中第几次出现的子字符串
For example:
INSTR(‘CORPORATE FLOOR’,’OR’, 3, 2)中,源字符串为’CORPORATE FLOOR’, 目标字符串为’OR’,起始位置为3,取第2个匹配项的位置;返回结果为 14 ‘

 

_______________________________

示例:

A#B#C#D
我想用sql截取得到C怎么写?
首先说下的市这个字符串也可能是AB#B#C#DE#EF#G
我想取到的是第二个‘#’和第三个‘#’之间的字符窜?

 select SUBSTR(module_tree,
              INSTR(module_tree, ‘#’, 1, 2) + 1,
              INSTR(module_tree, ‘#’, 1, 3) – INSTR(module_tree, ‘#’, 1, 2) – 1) as module_id
  from sys_modules sm
 where sm.module_id = ‘wdcs04’

 

FlexViewer2.3 最小化显示问题

因为在4.0中Resize 是用的<s:Resize  到4.5后又用回到<mx:Resize所以在WidgetTemplateSkin.mxml中

  <s:Resize heightTo="30"
                          target="{hostComponent}"
                          widthTo="100"/>

改为

 <mx:Resize heightTo="30"
                          target="{hostComponent}"
                          widthTo="100"/>

suse11不能用ssh登陆的解决-实战

现象:
VMware启动进入系统后,XP通过SecureCRT进行SSH进行登陆,结果怎么都登不上去。。。
在虚拟机里面用netstat看了一下,Suse上的22端口已经在侦听了,可是就是从XP上登不上去,ping都没问题。

root 身份执行:

linux-jvm6:/home/jackxiang/桌面 # telnet  localhost 22

Trying ::1…

Connected to localhost.

Escape character is ‘^]’.

SSH-2.0-OpenSSH_5.2

Protocol mismatch.

Connection closed by foreign host.

原来是防火墙的原因!

首先,打开/etc/sysconfig/SuSEfirewall2 文件,FW_SERVICES_EXT_TCP="ssh"可以定义开放ssh的服务。
然后,打开root登陆权限,如下:
决办法:
ssh默认不支持密码方式验证.
修改/etc/ssh/sshd_config文件,把
PasswordAuthentication no
修改为:
PasswordAuthentication yes
再重启ssh服务即可:
/etc/init.d/sshd restart

防火墙设置也可以执行yast 程式,于 firewall 项目内设定允许 ssh port 22 登入存取。

后记:
如果想控制仅允许某一IP或某一网段来使用这个SSH服务呢?
修改配置文件中的FW_SERVICES_ACCEPT_EXT参数即可实现.

—————————————————————————-
补充:
使用yast查看sshd服务的状态,在命令行输入yast回车,启动yast界面,选择 “System>SystemServices(Runlevel)”,打开SystemServices(Runlevel):Services 界面,检查sshd状态已经是Enabled。使用功能键Alt E转到ExpertMode,观察到当前sshd运行在Runlevel5, (Fullmultiuserwithnetworkanddisplaymanager),这都没有问题。

注意:service sshd restart 这样也可以启动!