首页 > 数据库 >Java项目中Oracle数据库开发过程中相关内容

Java项目中Oracle数据库开发过程中相关内容

时间:2024-12-26 11:56:49浏览次数:4  
标签:Java NAME -- 数据库 VALUE BU Oracle FSZ ID

目录

1、连接数据库

2、创建用户和授权

3、统计的时候——把列变成行

4、Oracle12c数据库中,根据时间倒序返回最新一条数据

5、其他SQL相关记录


总结一些和Oracle相关的内容

1、连接数据库

使用oracle12c数据库自带的SQL Plus 链接数据库
打开SQL Plus工具,输入:

sqlplus /nolog

conn sys as sysdba

然后输入Oracle系统管理员(sysdba)的密码,即可成功登录SQL Plus

当然也是可以用其他工具连接的,如PLSQL、DataGrip 等也是可以的

2、创建用户和授权

具体代码如下:

--创建用户
CREATE USER1 gslzyt IDENTIFIED BY USER1;
--授权
GRANT CONNECT, RESOURCE TO USER1;
--授权这个用户所有权限
GRANT ALL PRIVILEGES TO USER1;

语法: grant connect, resource to 用户名;
例子: grant connect, resource to test;
-- 撤销权限
语法: revoke connect, resource from 用户名;
列子: revoke connect, resource from test;

--
--允许test用户查询任何其他用户的表
GRANT SELECT ANY TABLE TO test;
--为用户test授予无限制的表空间权限
GRANT UNLIMITED TABLESPACE TO test;

-- 删除用户
drop user test cascade ;
-- 创建用户、密码为test123
create user test identified by test123 ;
-- 授权dba 权限
grant dba to test ;

3、统计的时候——把列变成行

-- 同一个统计,一个是横着查询
select COUNT(CASE WHEN ALARM_GRADE IN ('0') THEN 'IV' END) IV,
        COUNT(CASE WHEN ALARM_GRADE IN ('1') THEN 'III' END) III,
        COUNT(CASE WHEN ALARM_GRADE IN ('2') THEN 'II' END) II,
        COUNT(CASE WHEN ALARM_GRADE IN ('3') THEN 'I' END) I
        from ALARM_WATER_RECORD
        WHERE ALARM_CATEGORY='技术预警';

-- 一个是竖着查询条数
SELECT COUNT(ID) AS SUM,
    CASE ALARM_GRADE
        WHEN '0' THEN 'IV'
        WHEN '1' THEN 'III'
        WHEN '2' THEN 'II'
        WHEN '3' THEN 'I'
    ELSE ALARM_GRADE
        END AS ALARM_GRADE
FROM ALARM_WATER_RECORD
WHERE ALARM_CATEGORY='技术预警'
GROUP BY ALARM_GRADE;

4、Oracle12c数据库中,根据时间倒序返回最新一条数据

-- 最后面添加,如下内容即可
ORDER BY DATE ASC
FETCH NEXT 1 ROW ONLY

5、其他SQL相关记录

-- SQL将多字段拼接返回
SELECT PIPELINE_ID || '~' || GATEWELLS_ID || '~' || STATION_ID AS CODE,
       PIPELINE_NAME || '~' || DEVICE_ID || '~' || DEVICE_NAME AS name
FROM SHARE_GATEWELLS_DEVICE 

6、查询新增

-- 将查询结果新增到其他表
INSERT INTO BU_JIANCEDIAN_FOTC (SENSOR_ID,PID , TYPE_NAME, SENSOR_POSITION,POSTITION_ID,STATION_ID,TUNNEL_ID)
SELECT DISTINCT SENSOR_ID,'CE21CCBC579047A6AB0BB0A0B54BCB8F' PID , TYPE_NAME, SENSOR_POSITION,POSTITION_ID,STATION_ID,TUNNEL_ID
FROM FOTC_BUSINESS
WHERE TO_CHAR(SENSOR_DATE, 'YYYY-MM-DD') = '2023-11-01'
AND TUNNEL_ID LIKE '%15#渡槽(76+128.03)%';

7、查询最新1小时的数据

-- 查询最新1小时
SELECT * FROM ALARM_WATER_RECORD
WHERE ALARM_TIME  > (SYSDATE - TO_DSINTERVAL('0 1:00:00')) AND ALARM_TIME  <  SYSDATE;

8、oracle中建表语句

语句一:建表时 主键使用UUID

--树结构表
-- DROP TABLE BU_TREE_NODE
CREATE TABLE BU_TREE_NODE(
  ID 			VARCHAR2(32) DEFAULT SYS_GUID() PRIMARY KEY,
  TNAME 		VARCHAR2(100),
  PARENT_ID 	VARCHAR2(255),
  DATA_CONTENT 	VARCHAR2(255),

  STATUS            VARCHAR2(10),
  REMARKS           VARCHAR2(255),
  RES_ONE           VARCHAR2(100),
  RES_TWO           VARCHAR2(100),
  RES_THREE         VARCHAR2(100),
  RES_FOUR          VARCHAR2(100),
  CREATE_BY         VARCHAR2(64),     
  CREATE_TIME 	    DATE,             
  UPDATE_BY         VARCHAR2(64),
  UPDATE_TIME       DATE
);
-- 建表字段注释
COMMENT ON TABLE  BU_TREE_NODE                  IS '树结构表';
COMMENT ON COLUMN BU_TREE_NODE.ID               IS '表主键ID';
COMMENT ON COLUMN BU_TREE_NODE.TNAME            IS '名称';
COMMENT ON COLUMN BU_TREE_NODE.PARENT_ID        IS '父ID';
COMMENT ON COLUMN BU_TREE_NODE.DATA_CONTENT     IS '数据内容';

COMMENT ON COLUMN BU_TREE_NODE.STATUS           IS '状态';					      
COMMENT ON COLUMN BU_TREE_NODE.REMARKS          IS '备注';
COMMENT ON COLUMN BU_TREE_NODE.RES_ONE          IS '预留字段一';
COMMENT ON COLUMN BU_TREE_NODE.RES_TWO          IS '预留字段二';
COMMENT ON COLUMN BU_TREE_NODE.RES_THREE        IS '预留字段三';
COMMENT ON COLUMN BU_TREE_NODE.RES_FOUR         IS '预留字段四';
COMMENT ON COLUMN BU_TREE_NODE.CREATE_BY        IS '创建者';
COMMENT ON COLUMN BU_TREE_NODE.CREATE_TIME      IS '创建时间';
COMMENT ON COLUMN BU_TREE_NODE.UPDATE_BY        IS '更新者';
COMMENT ON COLUMN BU_TREE_NODE.UPDATE_TIME      IS '更新时间';
/

建表语句二:主键使用序列ID

-- 创建表序列 
-- DROP SEQUENCE SEQ_BU_MACA_PLAN;
CREATE SEQUENCE SEQ_BU_MACA_PLAN
 INCREMENT BY 1
 START WITH 1
 NOMAXVALUE
 NOMINVALUE
 CACHE 20;

-- 创建表 DROP TABLE BU_MACA_PLAN;
DROP TABLE BU_MACA_PLAN CASCADE CONSTRAINTS;
CREATE TABLE BU_MACA_PLAN (
  ID                NUMBER(20)       NOT NULL,
  SCHEME_ID         VARCHAR2(64)     DEFAULT NULL,
  START_TIME        VARCHAR2(255)    DEFAULT '',
  END_TIME          VARCHAR2(255)    DEFAULT '',
  CAL_SETP          NUMBER(10)       DEFAULT '',
  OUT_ZJSZ_FLOW     CLOB,
  OUT_JZZ_FLOW      CLOB,
  OUT_FSZ_FLOW      CLOB,
  MODEL_NAME        VARCHAR2(255)    DEFAULT '',
  SCHEME_NAME       VARCHAR2(255)    DEFAULT '',
  
  RES_ONE           VARCHAR2(255)    DEFAULT NULL,
  RES_TWO           VARCHAR2(255)    DEFAULT '',
  CREATE_BY         VARCHAR2(64),
  CREATE_TIME 	    DATE,
  UPDATE_BY         VARCHAR2(64)     DEFAULT '',
  UPDATE_TIME       DATE
);
-- 指定表主键和序列关联
ALTER TABLE BU_MACA_PLAN ADD CONSTRAINT PK_BU_MACA_PLAN PRIMARY KEY (ID);

COMMENT ON TABLE  BU_MACA_PLAN                  IS '总干常规调度表';
COMMENT ON COLUMN BU_MACA_PLAN.ID               IS '表主键SEQ_BU_MACA_PLAN.NEXTVAL';
											      
COMMENT ON COLUMN BU_MACA_PLAN.SCHEME_ID        IS '方案号';
COMMENT ON COLUMN BU_MACA_PLAN.START_TIME       IS '开始时间';
COMMENT ON COLUMN BU_MACA_PLAN.END_TIME         IS '结束时间';
COMMENT ON COLUMN BU_MACA_PLAN.CAL_SETP         IS '计算步长';
COMMENT ON COLUMN BU_MACA_PLAN.OUT_ZJSZ_FLOW    IS 'ZJSZ';
COMMENT ON COLUMN BU_MACA_PLAN.OUT_JZZ_FLOW     IS 'JZZ';
COMMENT ON COLUMN BU_MACA_PLAN.OUT_FSZ_FLOW     IS 'FSZ';
COMMENT ON COLUMN BU_MACA_PLAN.MODEL_NAME       IS '模型名称';
COMMENT ON COLUMN BU_MACA_PLAN.SCHEME_NAME      IS '方案名称';
											      					      
COMMENT ON COLUMN BU_MACA_PLAN.RES_ONE          IS '创建者';
COMMENT ON COLUMN BU_MACA_PLAN.RES_TWO          IS '创建者';
COMMENT ON COLUMN BU_MACA_PLAN.CREATE_BY        IS '创建者';
COMMENT ON COLUMN BU_MACA_PLAN.CREATE_TIME      IS '创建时间';
COMMENT ON COLUMN BU_MACA_PLAN.UPDATE_BY        IS '更新者';
COMMENT ON COLUMN BU_MACA_PLAN.UPDATE_TIME      IS '更新时间';
/

上面建表中字段类型是clob,在Oracle中,可以使用CLOB(Character Large Object)数据类型来存储大文本数据,包括JSON字符串。以下是示例代码,演示如何将JSON数据以字符串形式存储到数据库:

-- 创建表
CREATE TABLE json_data (
  id NUMBER PRIMARY KEY,
  json_str CLOB
);

-- 插入数据
INSERT INTO json_data (id, json_str) VALUES (1, '{"name": "John", "age": 30}');

9、新增表字段(增加字段时,只能排在已有字段的后面,不能插到已有字段之间)
增加一个字段:

-- 语法:Alter Table 表名 Add 字段名称  字段类型;
ALTER   TABLE    BU_MACA_PLAN    ADD    SLCH_STATUS   VARCHAR2(255);
COMMENT ON COLUMN BU_MACA_PLAN.SLCH_STATUS   IS '状态';

ALTER   TABLE    BU_MACA_PLAN    ADD    LENGTH    NUMBER(8,2);
COMMENT ON COLUMN BU_MACA_PLAN.LENGTH   IS '长度';

ALTER   TABLE    BU_MACA_PLAN    ADD    STAGE    NUMBER(2);
COMMENT ON COLUMN BU_MACA_PLAN.STAGE   IS '阶段';

增加两个字段;

-- 语法:Alter Table 表名 Add (字段名称  字段类型,字段名称  字段类型);
Alter Table BU_MACA_PLAN Add (RES_ONE VARCHAR2(255),RES_TWO VARCHAR2(255));

各种实际SQL:

-- 从A 表中查询出 根据B 表的名称模糊搜索
SELECT A.SITE_NAME,A.SITE_ID, B.CAME_ALIAS AS NAME, B.SITE_ID AS ID
FROM BASE_SITE_GATE A
JOIN BAS_CAME_TREE B ON A.SITE_NAME LIKE '%' || B.CAME_ALIAS || '%';
-- 查询单个字段 多条件模糊查询
SELECT * FROM BASE_SITE_GATE
WHERE REGEXP_LIKE(SITE_NAME, '(香泉)七支渠旁下渠通道|13号庙坪下渠通道内|总干一干渠末端|17#安监房|2#总分水闸后水下球机|三干渠6#倒虹吸出口|三干渠6#倒虹吸进口');
-- 条件筛选出最大值、最小值、和平均值
SELECT FSZ_ID, FSZ_NAME, FSZ_VALUE, SCHEME_ID, MODEL_NAME, YOY_VALUE, QOQ_VALUE, RES_ONE, RES_TWO, MAX_VALUE, MIN_VALUE, AVG_VALUE
FROM (
    SELECT FSZ_ID, FSZ_NAME, FSZ_VALUE, SCHEME_ID, MODEL_NAME, YOY_VALUE, QOQ_VALUE, RES_ONE, RES_TWO,
           MAX(TO_NUMBER(FSZ_VALUE)) OVER () AS MAX_VALUE,
           MIN(TO_NUMBER(FSZ_VALUE)) OVER () AS MIN_VALUE,
           ROUND(AVG(TO_NUMBER(FSZ_VALUE)) OVER (), 3) AS AVG_VALUE
    FROM BU_OUT_FSZ_FLOW
    WHERE SCHEME_ID = 'c1a47cbd270a4ede89d6ecd5ec0aff4f' and FSZ_ID='15039'
    GROUP BY FSZ_ID, FSZ_NAME, FSZ_VALUE, SCHEME_ID, MODEL_NAME, YOY_VALUE, QOQ_VALUE, RES_ONE, RES_TWO
) t;

SELECT FSZ_NAME AS NAME, SCHEME_ID,FSZ_VALUE AS VALUE, CUR_DATE, MODEL_NAME, YOY_VALUE, QOQ_VALUE, RES_ONE,
        RES_TWO, MAX_VALUE AS ZUIDAZHI,
        MIN_VALUE AS ZUIXIAOZHI,
        AVG_VALUE AS PINJUNZHI
        FROM
        (SELECT distinct FSZ_NAME, SCHEME_ID, FSZ_VALUE,CUR_DATE, MODEL_NAME, YOY_VALUE, QOQ_VALUE, RES_ONE, RES_TWO,
        MAX(TO_NUMBER(FSZ_VALUE)) OVER () AS MAX_VALUE,
        MIN(TO_NUMBER(FSZ_VALUE)) OVER () AS MIN_VALUE,
        AVG(TO_NUMBER(FSZ_VALUE)) OVER () AS AVG_VALUE
        FROM BU_OUT_FSZ_FLOW
        where SCHEME_ID='c1a47cbd270a4ede89d6ecd5ec0aff4f'AND FSZ_NAME = '总干')

--
SELECT FSZ_NAME, SCHEME_ID, FSZ_VALUE,CUR_DATE, MODEL_NAME, YOY_VALUE, QOQ_VALUE, RES_ONE, RES_TWO, MAX_VALUE AS MAX_VALUE,
       MIN_VALUE AS MIN_VALUE,
       AVG_VALUE AS AVG_VALUE
FROM
  (SELECT distinct FSZ_NAME, SCHEME_ID, FSZ_VALUE,CUR_DATE, MODEL_NAME, YOY_VALUE, QOQ_VALUE, RES_ONE, RES_TWO,
          MAX(TO_NUMBER(FSZ_VALUE)) OVER () AS MAX_VALUE,
          MIN(TO_NUMBER(FSZ_VALUE)) OVER () AS MIN_VALUE,
          AVG(TO_NUMBER(FSZ_VALUE)) OVER () AS AVG_VALUE
   FROM BU_OUT_FSZ_FLOW)
ORDER BY CUR_DATE ASC;

把表中的两个字段拼接返回JSON结果:

SELECT JSON_OBJECT('demandQ' VALUE JSON_ARRAYAGG(DEMAND_Q),
                   'name' VALUE MAX(PLAN_NAME)) AS waterPlan
FROM BU_WATER_PLAN
GROUP BY PLAN_NAME;

示例:{"demandQ":[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],"name":"四干"}

对某个字段查询出平均值并保留4位小数:

SELECT ROUND(AVG(TO_NUMBER(FSZ_VALUE)) OVER () ,4) FROM BU_OUT_FSZ_FLOW Where FSZ_ID='15039';

查询不同时间的数据

SELECT
CUR_DATE,
(SELECT SUM(FSZ_VALUE)
FROM BU_OUT_FSZ_FLOW
WHERE SCHEME_ID ='3e2b89d1088d4aa0ae66c7f4cdf266f4'
AND CUR_DATE = t.CUR_DATE) AS OLD_SUM_DAY_VALUE,
(SELECT SUM(FSZ_VALUE)
FROM BU_OUT_FSZ_FLOW
WHERE SCHEME_ID ='682735a043e64d8fa5cb272cb4e64eff'
AND CUR_DATE = t.CUR_DATE) AS NEW_SUM_DAY_VALUE
FROM (SELECT DISTINCT CUR_DATE
FROM BU_OUT_FSZ_FLOW
WHERE SCHEME_ID IN ('3e2b89d1088d4aa0ae66c7f4cdf266f4', '682735a043e64d8fa5cb272cb4e64eff')) t
ORDER BY CUR_DATE ASC;
-- ↑ 优化后的如下 ↓
SELECT
    CUR_DATE,
    SUM(CASE WHEN SCHEME_ID ='3e2b89d1088d4aa0ae66c7f4cdf266f4' THEN FSZ_VALUE ELSE 0 END) AS OLD_SUM_DAY_VALUE,
    SUM(CASE WHEN SCHEME_ID ='682735a043e64d8fa5cb272cb4e64eff' THEN FSZ_VALUE ELSE 0 END) AS NEW_SUM_DAY_VALUE
FROM BU_OUT_FSZ_FLOW
WHERE SCHEME_ID IN ('3e2b89d1088d4aa0ae66c7f4cdf266f4', '682735a043e64d8fa5cb272cb4e64eff')
GROUP BY CUR_DATE
ORDER BY CUR_DATE ASC;
-- 根据不同类别查询数据
SELECT ID, TNAME AS LABEL, PARENT_ID AS PID, RES_ONE AS SURL,
		CASE
        WHEN DATA_CONTENT ='行政区划' OR DATA_CONTENT ='水系' AND  PARENT_ID !='1' THEN MODEL_TYPE ELSE DATA_CONTENT
        END AS TYPE
        FROM BU_TREE_NODE
        where (MODEL_TYPE IN ('3dtiles','wms','point')
        or MODEL_TYPE is null )AND DATA_CONTENT !='闸门' AND DATA_CONTENT !='监测' AND DATA_CONTENT !='waterworks';

查询和时间相关SQL

-- 查询当前时间之前的3小时
SELECT SYSDATE - INTERVAL '3' HOUR FROM DUAL;
-- 查询当前时间之后的3天
SELECT SYSDATE + INTERVAL '3' DAY FROM DUAL;
-- 查询当时时间转成字符串
SELECT TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS') FROM DUAL;
-- 查询出最大日期的数据
WITH MAX_DATE AS (SELECT MAX(SENSOR_DATE) - 1 AS MAX_SENSOR_DATE FROM TC_BUSINESS)
SELECT ID,
       SOR_ID,
       IPMENT_ID,
       SOR_MODEL,
       TION_ID,
       E_NAME,
       NEL_ID,
       TITION_ID,
       SOR_POSITION,
       SOR_UNIT,
       SOR_WARN,
       ABS(SENSOR_VALUE) AS SENSOR_VALUE,
       SOR_DATE,
       RE3,
       ATE_TIME,
       ATE_TIME,
       SXYZ,
       SSENID,
       PLAY_POSTITION
FROM TC_BUSINESS, MAX_DATE
WHERE SENSOR_ID = 'DC11-S1' AND SENSOR_DATE >= MAX_DATE.MAX_SENSOR_DATE
ORDER BY SENSOR_DATE ASC;
-- 根据表中的日期统计出,不同等级的数量
SELECT TO_CHAR(A.ALARM_TIME, 'YYYY-MM-DD') AS TIME,
	COUNT( CASE WHEN A.ALARM_GRADE IN ( '0' ) THEN 'LOW' END ) L_SUM,
	COUNT( CASE WHEN A.ALARM_GRADE IN ( '1' ) THEN 'MID' END ) M_SUM,
	COUNT( CASE WHEN A.ALARM_GRADE IN ( '2' ) THEN 'HIGH' END ) H_SUM,
	COUNT( CASE WHEN A.ALARM_GRADE IN ( '3' ) THEN 'SERIOUS' END ) S_SUM,
	COUNT( 1 ) AS SUM
        FROM
            ALARM_WATER_RECORD A
        WHERE
            1 = 1
          AND A.ALARM_TYPE LIKE concat( concat( '%'
            , '安全预警' )
            , '%' )
          AND A.ALARM_SECTION LIKE concat( concat( '%'
            , '实测' )
            , '%' )
          AND A.ALARM_TIME > TRUNC( SYSDATE - 7 )
          AND A.ALARM_TIME < SYSDATE
        GROUP BY
            TO_CHAR( A.ALARM_TIME, 'YYYY-MM-DD' )
        ORDER BY
            TIME ASC;
-- 查询出一定时间内的最大值,然后联表查询出其他需要的信息
WITH MAX_VALUES AS (
    SELECT TYPE_NAME, MAX(SENSOR_VALUE) AS MAX_VALUE
    FROM FOTC_BUSINESS
    WHERE  TO_CHAR(SENSOR_DATE, 'YYYY-MM-DD') <= '2023-12-31'
        AND  TO_CHAR(SENSOR_DATE, 'YYYY-MM-DD') >= '2023-12-01'
    GROUP BY TYPE_NAME
),
MAX_SENSOR_VALUES AS (
    SELECT FB.TYPE_NAME, FB.SENSOR_VALUE AS svalue, BJD.STATION_ID,
           BJD.ID,
           BJD.SENSOR_ID,
           BJD.EQUIPMENT_ID,
           BJD.PID,
           BJD.TUNNEL_ID,
           BJD.POSTITION_ID,
           BJD.SENSOR_POSITION,
           BJD.SENSOR_UNIT,
           BJD.SENSOR_WARN,
           BJD.SENSOR_DATE,
           BJD.SPARE3,
           BJD.UPDATE_TIME,
           BJD.RES_ONE,
           BJD.RES_TWO,
           BJI.LATITUDE AS LATITUDE,
           BJI.LONGITUDE AS LONGITUDE,
           ROW_NUMBER() OVER (PARTITION BY BJD.STATION_ID ORDER BY FB.SENSOR_VALUE DESC) AS RN
    FROM FOTC_BUSINESS FB
    JOIN MAX_VALUES MV ON FB.TYPE_NAME = MV.TYPE_NAME AND FB.SENSOR_VALUE = MV.MAX_VALUE
    JOIN BU_JIANCEDIAN_FOTC BJD ON FB.SENSOR_ID = BJD.SENSOR_ID
    JOIN BU_JIANCEDIAN_INFO BJI ON BJD.PID = BJI.GID
)
SELECT * FROM MAX_SENSOR_VALUES WHERE RN = 1;
-- 查询出当年该字段最大数据量和
WITH SUMCOUNT AS(
    SELECT SUM(TOTAL) AS WATER
        FROM GATE_YEAR_VALUE
        WHERE TO_CHAR(SYSDATE, 'YYYY') = YEAR
          GROUP BY GATE_ID
)
SELECT SUM(WATER) FROM SUMCOUNT;

标签:Java,NAME,--,数据库,VALUE,BU,Oracle,FSZ,ID
From: https://blog.csdn.net/qq_43544074/article/details/132083773

相关文章

  • 微信小程序中supabase在线数据库使用指南
    在微信小程序中使用supabase在线数据库可以无需后端和服务器完成个人小项目的开发。本文记录我的使用过程,在阅读本文前,建议您先满足以下条件:持有可用于开发的微信小程序了解kexue上网第一步注册与简单使用首先,我们到https://supabase.com/注册一个账户,并创建一个您的项目。......
  • Clion创建项目sqlite数据库
    1.创建工程并运行(1)新建——project,选择工程文件夹,创建工程(2)进入界面,等待项目启动,显示main.cpp主文件(3)配置编译环境默认生成了main.cpp文件,但是我们不能运行。我们缺少编译环境,点击Setting打开设置,搜索工具链,发现Clion提供的编译环境有几种MinGW,CygWin,Visualstudio等。我......
  • Java用本地字典数据库实现英语单词翻译
    Java用本地字典数据库实现英语单词翻译依赖的准备<?xmlversion="1.0"encoding="UTF-8"?><projectxmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="h......
  • 【Java】Java中的常见日期对象
    类名说明java.util.Date这是Java早期版本中的主要日期类,尽管现在已经被java.time包中的类所取代,但在一些旧代码库中仍然可以看到它的身影java.util.Calendar这是一个抽象类,提供了操作日历字段如年、月、日、时、分、秒的方法。Calendar类本身不能直接实例化,而是通过调......
  • Java面试要点99 - Java线程池的关闭过程
    文章目录引言一、线程池的关闭方式1.1shutdown方法1.2shutdownNow方法二、关闭过程中的状态转换2.1线程池状态监控2.2优雅关闭的实现三、任务处理与异常处理3.1关闭时的任务处理3.2关闭过程中的异常处理总结引言线程池的关闭是Java并发编程中的重要环节,......
  • Java面试要点98 - Java中线程池的任务提交过程
    文章目录引言一、任务提交方式1.1execute方法1.2submit方法二、任务执行流程2.1核心流程分析2.2任务状态转换三、任务队列处理3.1队列类型选择3.2队列满时的处理四、异常处理4.1提交时异常处理4.2执行时异常处理总结引言在Java并发编程中,了解线程池的......
  • Java面试要点97 - Java中ThreadPoolExecutor源码解析
    文章目录引言一、核心属性1.1状态与线程数量的原子控制1.2任务队列与工作线程组二、Worker线程包装类2.1Worker类的设计三、任务提交源码分析3.1execute方法实现3.2addWorker核心方法四、任务执行源码分析4.1runWorker方法实现4.2getTask方法分析五、线程池......
  • 【最新原创毕设】基于PPH的花涧订购系统+00332(免费领源码)可做计算机毕业设计JAVA、PHP
    摘 要近年来,电子商务的快速发展引起了行业和学术界的高度关注。花涧订购系统旨在为用户提供一个简单、高效、便捷的花卉购物体验,它不仅要求用户清晰地查看所需信息,而且还要求界面设计精美,使得功能与页面完美融合,从而提升系统的可操作性。因此,我们需要深入研究信息内容,并利用......
  • 数据库原理与应用期末试卷(2)SCAU
    华南农业大学期末考试试卷(A卷)2020-2021学年第一学期            考试科目:数据库系统(双语)考试类型:闭卷             考试时间:120 分钟学号              姓名               年级专业          ......
  • 3种常见的数据库迁移工具对比
    3种常见的数据库迁移工具对比神州数码云基地​已认证账号​关注2人赞同了该文章之前在项目中,收到一个紧急需求,要把数据从 PostgreSQL 迁移到 TiDB 中。由于时间紧任务重,来不及调研高效的方式,直接使用了Navicat内置的功能,把数据从PostgreSQL迁移到......