java oracle 连接字符串函数_通过shell来比较oracle和java中的字符串使用

这些准备工作齐了之后,我们来从Java中的字符串使用入手来比较一下oracle中对于字符串的处理。

java中有如下的一些函数,我会依次来做比较。

public char charAt(int index)

返回字符串中第index个字符;

oracle中可以使用substr来简单实现,需要注意两种方式的下标,在java的charAt中是以0开始,而在oracle中的substr中则是以1开始计数的。

[ora11g@rac1 ~]$ ksh test1.sh 'new String("abcd").charAt(2)'

c

[ora11g@rac1 ~]$ ksh test2.sh "substr('abcd',3,1)"

S

-

c

public int length()

返回字符串的长度;

oracle中可以使用length函数,使用方式也是很类似的。

[ora11g@rac1 ~]$ ksh test1.sh 'new String("abcd").length()'

4

[ora11g@rac1 ~]$ ksh test2.sh "length('abcd')"

LENGTH('ABCD')

--------------

4

public int indexOf(String str)

返回字符串中第一次出现str的位置;

oracle中可以使用instr来模拟实现,而且oracle可以更加的灵活。注意下标的不同

ksh test1.sh 'new String("abcdc").indexOf("c")'

2

[ora11g@rac1 ~]$ ksh test2.sh "instr('abcdc','c',1,1)"

INSTR('ABCDC','C',1,1)

----------------------

3

顺便扩展一下,oracle中如果要得到某个字符串第几次出现的下标,相对就更直接了,比如字符串“abcdc"中第二次出现字符c的下标

[ora11g@rac1 ~]$ ksh test2.sh "instr('abcdc','c',1,2)"

INSTR('ABCDC','C',1,2)

----------------------

5

public int indexOf(String str,int fromIndex)

返回字符串从fromIndex开始第一次出现str的位置;

oracle中还是使用Instr,而且使用方法和上例类似。

我们对字符串abcd从下标为1,即字符b所对应的下标开始。

[ora11g@rac1 ~]$ ksh test1.sh 'new String("abcdc").indexOf("c",1)'

2

[ora11g@rac1 ~]$ ksh test2.sh "instr('abcdc','c',2,1)"

INSTR('ABCDC','C',2,1)

----------------------

3

public boolean equalsIgnoreCase(String another)

比较字符串与another是否一样(忽略大小写);

oracle中实现方式略有不同,不过可以直接转换为大写或者小写即可。

[ora11g@rac1 ~]$ ksh test1.sh 'new String("abcd").equalsIgnoreCase("abcD")'

true

SQL> select 1 from dual where upper('abcD')='ABCD';

1

----------

1

public String replace(char oldchar,char newChar)

在字符串中用newChar字符替换oldChar字符

oracle中的使用也有replace函数,用法也是一致的。

[ora11g@rac1 ~]$ ksh test1.sh 'new String("abcd").replace("c","g")'

abgd

[ora11g@rac1 ~]$ ksh test2.sh "replace('abcd','c','g')"

REPL

----

abgd

public boolean startsWith(String prefix)

判断字符串是否以prefix字符串开头;

public boolean endsWith(String suffix)

判断一个字符串是否以suffix字符串结尾;

oracle中的实现可以通过匹配符%来实现,也可以使用正则表达式。

[ora11g@rac1 ~]$ ksh test1.sh 'new String("abcd").startsWith("a")'

true

[ora11g@rac1 ~]$ ksh test1.sh 'new String("abcd").endsWith("d")'

true

SQL> select 1 from dual where 'abcd' like 'a%';

1

----------

1

SQL> select 1 from dual where 'abcd' like '%d';

1

----------

1

public String toUpperCase()

返回一个字符串为该字符串的大写形式;

public String toLowerCase()

返回一个字符串为该字符串的小写形式

oracle中有upper()和lower()方法,用法效果是一致的。

[ora11g@rac1 ~]$ ksh test1.sh 'new String("abcd").toUpperCase()'

ABCD

[ora11g@rac1 ~]$ ksh test1.sh 'new String("ABcd").toLowerCase()'

abcd

[ora11g@rac1 ~]$ ksh test2.sh "upper('abcd')"

UPPE

----

ABCD

[ora11g@rac1 ~]$ ksh test2.sh "lower('ABcd')"

LOWE

----

abcd

public String substring(int beginIndex)

返回该字符串从beginIndex开始到结尾的子字符串;

public String substring(int beginIndex,int endIndex)

返回该字符串从beginIndex开始到endsIndex结尾的子字符串

oracle中也有substring,相比来说功能要更丰富,注意在java中是substring,而在oracle是substr

[ora11g@rac1 ~]$ ksh test1.sh 'new String("ABcd").substring(1)'

Bcd

[ora11g@rac1 ~]$ ksh test2.sh "substr('ABcd',1)"

SUBS

----

ABcd

[ora11g@rac1 ~]$ ksh test1.sh 'new String("ABcd").substring(1,2)'

B

[ora11g@rac1 ~]$ ksh test1.sh 'new String("ABcd").substring(1,3)'     --注意这种用法的下标,当下标为(1,3)时,才会输出下标为1和2的字符。

Bc

[ora11g@rac1 ~]$ ksh test2.sh "substr('ABcd',1,2)"   --注意oracle中的小标是从1开始,最后的参数2代表需要截取的字符串长度为2,所以截取了AB

SU

--

AB

public String trim()

返回该字符串去掉开头和结尾空格后的字符串

oracle中有trim函数,而且还有ltrim,rtrim等支持的功能也要丰富一些。

[ora11g@rac1 ~]$ ksh test1.sh 'new String("abcd ").trim()'

abcd

[ora11g@rac1 ~]$ ksh test2.sh "trim('abcd ')"

TRIM

----

abcd

ltrim就是截取左边的空白字符,rtrim就是截取右边的空白字符。

[ora11g@rac1 ~]$ ksh test2.sh "ltrim(' abcd')"

LTRI

----

abcd

public String[] split(String regex)

将一个字符串按照指定的分隔符分隔,返回分隔后的字符串数组

oracle中目前没有发现有现成的方法实现,只能自己DIY通过pl/sql来实现,内部也是在使用substr来递归解析。

下面的例子会将字符串”abcd abcd"以空格分割,最后返回的是一个数组,我们来看看里面的内容。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用以下方式在 shell 脚本通过 JDBC 连接 Oracle 数据库: 1. 首先,需要下载并安装 Oracle JDBC 驱动程序,然后将其添加到 CLASSPATH 。 2. 在 shell 脚本使用以下命令来连接 Oracle 数据库: ```bash #!/bin/bash # 设置 Oracle 数据库连接参数 export ORACLE_SID=ORCL export ORACLE_HOME=/usr/lib/oracle/11.2/client64 export LD_LIBRARY_PATH=$ORACLE_HOME/lib export PATH=$PATH:$ORACLE_HOME/bin # 连接 Oracle 数据库 java -classpath path/to/ojdbc.jar:path/to/yourapp.jar your.package.Main ``` 其,`path/to/ojdbc.jar` 是 Oracle JDBC 驱动程序的路径,`your.package.Main` 是包含 JDBC 连接代码的 Java 类的完整路径。 3. 在 Java使用以下代码来连接 Oracle 数据库: ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; public class Main { public static void main(String[] args) { Connection conn = null; try { // 加载 Oracle JDBC 驱动程序 Class.forName("oracle.jdbc.driver.OracleDriver"); // 创建连接 String url = "jdbc:oracle:thin:@//localhost:1521/ORCL"; String user = "username"; String password = "password"; conn = DriverManager.getConnection(url, user, password); // 执行 SQL 查询 // ... } catch (ClassNotFoundException e) { System.err.println("无法加载 Oracle JDBC 驱动程序"); e.printStackTrace(); } catch (SQLException e) { System.err.println("无法连接Oracle 数据库"); e.printStackTrace(); } finally { // 关闭连接 try { if (conn != null) { conn.close(); } } catch (SQLException e) { System.err.println("无法关闭数据库连接"); e.printStackTrace(); } } } } ``` 其,`url` 是 Oracle 数据库的连接字符串,`user` 和 `password` 是连接 Oracle 数据库所需的用户名和密码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值