OraclevsPostgreSQLDevelop(18)-Boolean

在Oracle和PG中都可以使用int类型模拟布尔类型,但通过JDBC接口(JDBC驱动,Oracle为11.2.0.4,PG为9.3)获取出来的值却不一致,这一点需要注意。
测试脚本

drop table tbl1;
create table tbl1(id int,c1 int);
insert into tbl1 values(1,1);
insert into tbl1 values(2,-1);
insert into tbl1 values(3,2);
insert into tbl1 values(4,0);

Java代码

创新互联公司自成立以来,一直致力于为企业提供从网站策划、网站设计、成都网站设计、做网站、电子商务、网站推广、网站优化到为企业提供个性化软件开发等基于互联网的全面整合营销服务。公司拥有丰富的网站建设和互联网应用系统开发管理经验、成熟的应用系统解决方案、优秀的网站开发工程师团队及专业的网站设计师团队。

/*
 *
 */
package testPG;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class TestBoolean {
  public static void main(String[] args) {
    System.out.println("---------- PG -----------");
    try (Connection conn = DriverManager.getConnection("jdbc:postgresql://192.168.26.28:5432/testdb", "pg12",
        "pg12")) {
      TestBool(conn);
    } catch (SQLException se) {
      System.out.println(se.getMessage());
    } catch (Exception e) {
      e.printStackTrace();
    } finally {
    } // end try
    System.out.println("---------- Oracle -----------");
    try (Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@192.168.1.18:1521:orcl", "test",
        "test")) {
      TestBool(conn);
    } catch (SQLException se) {
      System.out.println(se.getMessage());
    } catch (Exception e) {
      e.printStackTrace();
    } finally {
    } // end try
  }
  public static void TestBool(Connection conn) {
    try (PreparedStatement pstmt = conn.prepareStatement("SELECT id,c1 from tbl1");
        ResultSet rs = pstmt.executeQuery();) {
      conn.setAutoCommit(true);
      while (rs.next()) {
        int id = rs.getInt("id");
        int c1 = rs.getInt("c1");
        boolean b1 = rs.getBoolean("c1");
        System.out.println("id:" + id + ",c1:" + c1 + ",b1:" + b1);
      }
    } catch (SQLException se) {
      System.out.println(se.getMessage());
    } catch (Exception e) {
      e.printStackTrace();
    } finally {
    } // end try
  } // end
} // end Class

执行结果

---------- PG -----------
id:1,c1:1,b1:true
id:2,c1:-1,b1:false
id:3,c1:2,b1:false
id:4,c1:0,b1:false
---------- Oracle -----------
id:1,c1:1,b1:true
id:2,c1:-1,b1:true
id:3,c1:2,b1:true
id:4,c1:0,b1:false

标题名称:OraclevsPostgreSQLDevelop(18)-Boolean
当前地址:http://csdahua.cn/article/gpceec.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流