首页 > 数据库 >JDBC连接openGauss6.0和PostgreSQL16.2性能对比

JDBC连接openGauss6.0和PostgreSQL16.2性能对比

时间:2024-05-14 08:59:28浏览次数:27  
标签:JDBC java String OGConnectDemo jar PostgreSQL16.2 version openGauss6.0 opengauss

本文分享自华为云社区《JDBC连接openGauss6.0和PostgreSQL16.2性能对比》,作者: Gauss松鼠会小助手。

PostgreSQL vs openGauss

01 前置准备

安装JDK:

详细安装步骤请问度娘,输入能正常返回即已安装

[root@db06 ~]# java -version
openjdk version "1.8.0_262"
OpenJDK Runtime Environment (build 1.8.0_262-b10)
OpenJDK 64-Bit Server VM (build 25.262-b10, mixed mode)
[root@db06 ~]# javac -version
javac 1.8.0_262

下载PostgreSQL驱动jar包:https://jdbc.postgresql.org/

下载openGuass驱动jar包:https://opengauss.org/zh/download/

02 Hello World

纯java代码,不涉及数据库层,编辑java文件代码,注意文件名需与类名同名

vi HelloWorld.java

public class HelloWorld{
    public static void main(String[] args){
        System.out.println("Hello World . . . ");
    }
}

编译运行:

javac HelloWorld.java
java HelloWorld

cde3e59d885d19f87ef1c5dfd69dfa0d_20240423-5920493a-8b73-4a89-8f8b-b28d64bc132b.png

03 连接数据库(PostgreSQL)

需要用到驱动jar包,测试PG版本是16.2

创建Demo文件,文件名与类名同名

vi DBConnectDemo.java

import java.sql.*;

public class DBConnectDemo {

    public static void main(String[] args){
        // 相关ip,port,database,user,password需进行替换
        String url = "jdbc:postgresql://172.16.107.156:54321/testdb";
        String username = "muser";
        String password = "Test@123";
        try {
            // 加载驱动
            Class.forName("org.postgresql.Driver");
            // 打印数据库版本
            Connection conn = DriverManager.getConnection(url, username, password);
            Statement stmt = conn.createStatement();
            ResultSet result = stmt.executeQuery("select version();");
            while (result.next()){
                System.out.println("DB version : " + result.getString("version"));
            }
            
            long avgtime = 0;
            int n = 10;        // 循环次数

            // 循环打印连接建立时间
            for(int i=0;i<n;i++){
                long start = System.nanoTime();
                Connection connection = DriverManager.getConnection(url, username, password);
                long end = System.nanoTime() - start;
                System.out.println("connect success: " + end + " 纳秒");
                connection.close();
                avgtime += end;
            }
            System.out.println("avg time: " + avgtime/n + " 纳秒");
        }  catch (Exception e){
            e.printStackTrace();
        }
    }

}

编译运行:需要在路径前面加上 .: 来指定路径

javac编译时在同目录下可以不指定驱动jar包

java运行时则需要指定

javac -cp "/tmp/postgresql-42.5.2.jar" DBConnectDemo.java
java -cp "/tmp/postgresql-42.5.2.jar" DBConnectDemo (有问题)
java -cp ".:/tmp/postgresql-42.5.2.jar" DBConnectDemo
java -cp ".:./*" DBConnectDemo

392884d7dcd32added9cc8032688fc57_20240425-c04ac173-ccd2-4bbf-af68-eb7751ab5402.png

04 连接数据库(openGauss)

openGauss出6.0了,下载个极简版来试试

be2aa89349f19d672e59a7b619c95be4_20240424-f4c3e609-b22a-4bc7-a0a7-fd5caf651e1b.png

opengauss连接需要调整驱动和数据库信息

String url = "jdbc:opengauss://172.16.107.156:15400/testdb";

            Class.forName("org.opengauss.Driver");

完整代码:

vi OGConnectDemo.java

import java.sql.*;

public class OGConnectDemo {

    public static void main(String[] args){
        // 相关ip,port,database,user,password需进行替换
        String url = "jdbc:opengauss://172.16.107.156:6543/testdb";
        String username = "muser";
        String password = "Test@1234";
        try {
                // 加载驱动
            Class.forName("org.opengauss.Driver");
            // 打印数据库版本
                Connection conn = DriverManager.getConnection(url, username, password);
            Statement stmt = conn.createStatement();
            ResultSet result = stmt.executeQuery("select version();");
            while (result.next()){
                System.out.println("DB version : " + result.getString("version"));
            }
                
            long avgtime = 0;
            int n = 10;        // 循环次数

                // 循环打印连接建立时间
            for(int i=0;i<n;i++){
                long start = System.nanoTime();
                Connection connection = DriverManager.getConnection(url, username, password);
                long end = System.nanoTime() - start;
                System.out.println("connect success: " + end + " 纳秒");
                connection.close();
                avgtime += end;
            }
            System.out.println("avg time: " + avgtime/n + " 纳秒");
        }  catch (Exception e){
            e.printStackTrace();
        }
    }

}

编译运行:OG会打印其他日志信息,这里我们把输出结果写到文件里

javac -cp ".:/tmp/opengauss-jdbc-6.0.0-RC1.jar" OGConnectDemo.java
java -cp .:/tmp/opengauss-jdbc-6.0.0-RC1.jar OGConnectDemo > OGConnectDemo.log
cat OGConnectDemo.log

012aef26a3c198bba8d6d221cd684756_20240425-baefea00-2d2e-49a2-b080-0feef391b58c.png

05 PG

标签:JDBC,java,String,OGConnectDemo,jar,PostgreSQL16.2,version,openGauss6.0,opengauss
From: https://www.cnblogs.com/huaweiyun/p/18190500

相关文章

  • JDBC
    JDBC:是JAVA提供的一套用来操作数据库的接口  【案例1】JDBCDemo/*JDBC:是JAVA提供的一套用来操作数据库的接口通过Java程序操作数据库:1.先确定MySQL是否可以正常使用(MySQL服务是否开启)2.确定MySQL和驱动包的版本是否匹配(MySQL5.7驱动包的版本5.1.37......
  • Spring6 的JdbcTemplate的JDBC模板类的详细使用说明
    1.Spring6的JdbcTemplate的JDBC模板类的详细使用说明@目录1.Spring6的JdbcTemplate的JDBC模板类的详细使用说明每博一文案2.环境准备3.数据准备4.开始4.1从数据表中插入(添加)数据4.2从数据表中修改数据4.3从数据表中删除数据4.4从数据表中查询一个对象4.5从数据表中......
  • Fastjson反序列化漏洞3:JdbcRowSetImpl利用链-JNDI注入
    第二条链Fastjson的三条链,现在我们来讲第二条com.sun.rowset.JdbcRowSetImplcom.sun.rowset.JdbcRowSetImplorg.apache.tomcat.dbcp.dbcp2.BasicDataSourceFastjson的三条链,现在我们来看第二条com.sun.rowset.JdbcRowSetImplsetAutoCommit、connect、setDataSourceNameset......
  • Springboot Data Jdbc中Contains和Containing的用法
    Contains和Containing的用法privateStringtitle;privateList<String>tags;//查询标题包含指定字符串的书籍List<Book>findByTitleContains(Stringtitle);//查询包含指定标签的书籍List<Book>findByTagsContaining(Stringtag);--查询标题包含"Spring"的书......
  • 10.JDBC事务
    要么都成功,要么都失败!ACID原则:保证数据的安全。开启事务事务提交事务回滚关闭事务转账:A:1000B:1000A(900)--100-->B(1100)publicclassTestJDBC2{@Testpublicvoidtest(){//配置信息Stringurl="jdbc:mysql://localhost:3306/jd......
  • 9.JDBC
    什么是JDBC:java连接数据库!添加jar包<dependencies><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.33</version>......
  • 多语言 JDBC SQL 发送
    多语言JDBCSQL发送记录各个语言使用JDBC发送SQL的代码片段。Pythonimportjaydebeapi#pipinstalljaydebeapi#JDBC驱动类名driver='com.mysql.jdbc.Driver'#数据库连接URLurl='jdbc:mysql://hostname:port/databasename?characterEncoding=UTF-8&serverT......
  • JDBC相关
    什么是JDBC,为什么要使用JDBC?在web开发中,不可避免的地要使用数据库来存储和管理数据。为了在java语言中提供数据库访问的支持,Sun公司于1996年提供了一套访问数据的标准Java类库,即JDBC。JDBC,全称是JavaDatabaseConnectivity,它是一套统一的、基于Java语言的关系数据库编程接口......
  • 异构数据源同步之表结构同步 → 通过 jdbc 实现,没那么简单
    开心一刻今天坐沙发上看电视,旁边的老婆拿着手机贴了过来老婆:老公,这次出门旅游,机票我准备买了哈我:嗯老婆:你、我、你爸妈、我爸妈,一共六张票老婆:这上面还有意外保险,要不要买?我:都特么团灭了,还买啥保险?异构数据源同步概念介绍数据源,不只是包含关系型数据库,还包括NoSQL、数......
  • ojdbc6jar包手动解压导入本地仓库
    报错Cannotresolvecom.oracle:ojdbc6:11.2.0.1.0<!--oracle驱动--><dependency><groupId>com.oracle</groupId><artifactId>ojdbc6</artifactId><version>11.2.0.1.0</version></dependency>解决方式:......