Java中Date,Timestamp,相互转换与关系

 

一、String与Date(java.util.Date)互转

 

     1.1 String -> Date

 

 

  1. String dateStr = "2019/03/04 15:34:23";  
            Date date = new Date();  
            //注意format的格式要与日期String的格式相匹配  
            DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");  
            try {  
                date = sdf.parse(dateStr);  
                System.out.println(date.toString());  
            } catch (Exception e) {  
                e.printStackTrace();  
            }  

     

 

 

  1.2 Date -> String

 

   日期向字符串转换,可以设置任意的转换格式format

 

  1. String dateStr = "";  
            Date date = new Date();  
        
            DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");  
      
            try {  
                dateStr = sdf.format(date);  
                System.out.println(dateStr);  
              
            } catch (Exception e) {  
                e.printStackTrace();  
            }  

     

 二、String与Timestamp互转

 

 

   2.1 String ->Timestamp

 

 

   使用Timestamp的valueOf()方法

 

  1. Timestamp ts = new Timestamp(System.currentTimeMillis());  
            String str = "2019-03-09 14:49:45";  
            try {  
                ts = Timestamp.valueOf(str);  
                System.out.println(ts);  
            } catch (Exception e) {  
                e.printStackTrace();  
            }  

     

   注:String的类型必须形如: yyyy-mm-dd hh:mm:ss[.f...] 这样的格式,中括号表示可选,否则报错!!!

    如果String为其他格式,可考虑重新解析下字符串,再重组~~

 

    2.2 Timestamp -> String

 

  使用Timestamp的toString()方法或者借用DateFormat

 

 

  1. Timestamp ts = new Timestamp(System.currentTimeMillis());  
            String str = "";  
            DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");  
            try {  
                //方法一  
               str = sdf.format(ts);  
                System.out.println(str);  
                //方法二  
                str = ts.toString();  
                System.out.println(str);  
            } catch (Exception e) {  
                e.printStackTrace();  
            }  

     

 很容易能够看出来,方法一的优势在于可以灵活的设置字符串的形式。

三、Date( java.util.Date )和Timestamp互转

 

  声明:查API可知,Date和Timesta是父子类关系

 

 

  3.1 Timestamp -> Date

 

 

Timestamp ts = new Timestamp(System.currentTimeMillis());  
        Date date = new Date();  
        try {  
            date = ts;  
            System.out.println(date);  
        } catch (Exception e) {  
            e.printStackTrace();  
        }  

 很简单,但是此刻date对象指向的实体却是一个Timestamp,即date拥有Date类的方法,但被覆盖的方法的执行实体在Timestamp中。

 

   3.2 Date -> Timestamp

 

   父类不能直接向子类转化,可借助中间的String~~~~

   注:使用以下方式更简洁

   Timestamp ts = new Timestamp(date.getTime());

 

Date和TimeStamps这两种时间类型都有一个相同的构造方法,就是通过毫秒数来转成日期或者时间戳格式,如此看来就非常简单了.


 

注意在java中毫秒的类型为long;
 

new Date(timestamp.getTime());  
new Timestamp(date.getTime()); 

 

要使用Java对PG库进行增量备份,你需要使用Java的JDBC API连接到PG数据库并执行备份操作。以下是一个基本的备份过程: 1. 使用JDBC连接到PG数据库:可以使用JDBC连接字符串来创建连接,例如: ``` String url = "jdbc:postgresql://localhost:5432/mydb"; Connection conn = DriverManager.getConnection(url, "myuser", "mypassword"); ``` 2. 执行备份命令:使用PG的pg_dump命令来备份数据库。以下是一个备份命令的示例: ``` pg_dump -U myuser -h localhost -p 5432 -F c -b -v -f backup_file.dump mydb ``` 在Java中,可以使用ProcessBuilder类来运行备份命令,例如: ``` ProcessBuilder pb = new ProcessBuilder("pg_dump", "-U", "myuser", "-h", "localhost", "-p", "5432", "-F", "c", "-b", "-v", "-f", "backup_file.dump", "mydb"); Process p = pb.start(); p.waitFor(); ``` 3. 执行增量备份:使用PG的pg_dump命令的--incremental选项来执行增量备份。以下是一个增量备份命令的示例: ``` pg_dump -U myuser -h localhost -p 5432 -F c -b -v -f backup_file.dump mydb --incremental ``` 要执行增量备份,你需要在备份文件名中指定一个唯一的标识符,例如时间戳。在Java中,你可以使用SimpleDateFormat类来创建时间戳,然后将其插入备份文件名中,例如: ``` SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmss"); String timestamp = sdf.format(new Date()); String backupFileName = "backup_file_" + timestamp + ".dump"; ``` 然后,你可以使用ProcessBuilder类来运行增量备份命令,例如: ``` ProcessBuilder pb = new ProcessBuilder("pg_dump", "-U", "myuser", "-h", "localhost", "-p", "5432", "-F", "c", "-b", "-v", "-f", backupFileName, "mydb", "--incremental"); Process p = pb.start(); p.waitFor(); ``` 注意:增量备份只适用于PG 10及以上版本。在PG 9.5及以下版本中,你需要使用pg_receivexlog和pg_basebackup命令来执行增量备份。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值