>  기사  >  데이터 베이스  >  db2와 oracle sql 문의 차이점은 무엇입니까?

db2와 oracle sql 문의 차이점은 무엇입니까?

WBOY
WBOY원래의
2022-05-30 17:23:232607검색

차이점: 1. db2는 유사한 테이블을 생성하기 위해 "b와 같은 테이블 a 생성"을 사용하고, oracle은 "b에서 *를 선택하여 테이블 a 생성"을 사용합니다. 2. db2는 varchar 유형 변환을 사용하고, oracle은 "to_char" 함수를 사용하여 전환하다.

db2와 oracle sql 문의 차이점은 무엇입니까?

이 튜토리얼의 운영 환경: Windows 10 시스템, Oracle 11g 버전, Dell G3 컴퓨터.

db2와 oracle sql 문의 차이점은 무엇입니까

1. 유사한 테이블 구문 만들기

Oracle : 
	create table a as select * from b;
DB2    : 
	create table a like b;
		 
	(8版本有效,9版本无效)
	create table new_a as select col1,col2... from a definition only

2. 빠르게 큰 테이블 구문 지우기

Oracle : 
	truncate table a;
DB2    :
	alter table a active not logged initially with empty table;

3. 첫 번째 N 데이터 구문 가져오기

Oracle : 
	select * from a where rownum <h4> <strong> 4. 시스템 시간 구문 가져오기</strong>
</h4><pre class="brush:php;toolbar:false">Oracle :
	select sysdate from dual;
DB2    :
	select current timestamp from sysibm.sysdummy1;

5. Null 값 변환 방법이 다릅니다

Oracle :
	select col1,col2,nvl(col3,'0') from tablename; (判断col3字段是否为空,不为空就输出原来的数值,为空就输出0)
DB2   :
	select col1,col2,value(col3,'0') from tablename;
	
	(mysql和Db2可以使用Coalesce(col3,'0')函数来实现上述功能)
Coalesce() 함수
这个函数主要用来进行空值处理,其参数格式如下: COALESCE ( expression,value1,value2……,valuen) 
COALESCE()函数的第一个参数expression为待检测的表达式,而其后的参数个数不定。
COALESCE()函数将会返回包括expression在内的所有参数中的第一个非空表达式。
	如果expression不为空值则返回expression;
	否则判断value1是否是空值,如果value1不为空值则返回value1;
	否则判断value2是否是空值,如果value2不为空值则返回value2;
	……以此类推,
	如果所有的表达式都为空值,则返回NULL。

6 유형 변환 방법이 다릅니다.

oracle :
	select to_char(sysdate,'YYYY-MM-DD HH24:MI:SS') from dual;
DB2    :
	select varchar(current timestamp) from sysibm.sysdummy1;

분석:

Oracle数据类型改变函数:to_char()、to_date()、to_number()等;
	如果仅仅取年,月,日等,可以用
		to_char(sysdate, 'YYYY'),
		to_char('MM') ,
		to_char('DD')取得。
	只取年月日TRUNC(SYSDATE)。
	取时分秒TO_CHAR(SYSDATE,'HH24:MI:SS')。

DB2数据类型改变函数:char()、varchar()、int()、date()、time()等;
	取得年,月,日等的写法:
		YEAR(current timestamp),
		MONTH(current timestamp),
		DAY(current timestamp),
		HOUR(current timestamp),
		MINUTE(current timestamp),
		SECOND(current timestamp),
		MICROSECOND(current timestamp),
	只取年月日可以用
		DATE(current timestamp),
	取时分秒
		TIME(current timestamp)。
	Char()是定长字符串(1-255),varchar()为非定长字符串(1-32672)日期,
	时间形态变为字符形态: 
		char(current date),
		char(current time)
	将字符串转换成日期或时间形态:
		TIMESTAMP('2002-10-2012:00:00'),
		DATE('2002-10-20'),
		DATE('10/20/2002'),
		TIME('12:00:00')

현재 DB2 V8은 to_char 및 to_date를 지원하며 V9 버전에는 to_number

7이 추가되었습니다. 문자열을 날짜로 변환하는 다양한 방법(To_Number/cast)

Oracle:
	select to_number('123') from dual;
	select cast('123' as integer) from dual;
DB2   :
	select cast('123' as integer) from sysibm.sysdummy1;
	select cast(current time as char(8)) from sysibm.sysdummy1;

8. 쿼리(계층적 쿼리)

Oracle:
	直接用子查询

Db2:WITH语句
	WITH  a1 AS(SELECT max(id) AS aa1 FROM test )SELECT id ,aa1 FROM test ,a1
Oracle:
Oracle递归查询:CONNECT BY PRIOR ... START WITH ...
DB2   递归查询:DB2较难理解,要WITH一个虚拟表

자세히 알아보기: Oracle 계층형 쿼리(재귀 쿼리): 시작...이전 및 수준 키워드로 연결

DB2:db2와 oracle sql 문의 차이점은 무엇입니까?

//从child是son的数据向上查询出所有的长辈select distinct test_parent from (
       select t.test_parent from t_test t 
              connect by prior t.test_parent = t.test_child 
              start with t.test_child = 'son' )
위 그림과 같이 손자부터 시작하여 모든 상위 노드를 쿼리합니다. 먼저 가상 테이블의 시작점을 설정합니다(왼쪽의 네 번째 행이 순서대로 푸시됨). 이전 행의 자식, 즉 VT.parent +

10. 데이터 유형에 차이가 있습니다db2와 oracle sql 문의 차이점은 무엇입니까?

// Db2递归查询写法with par_test(test_child,test_parent) as(
     select test_child,test_parent from t_test where child='grandchild'  -- 设置递归起点
     union all
     select t.test_child,t.test_parent from par_test pt,t_test t where pt.test_parent = t.test_child ----递归的方向为从子向父)select distinct test_parent from par_test
db2와 oracle sql 문의 차이점은 무엇입니까?
11. rowId

比较大的差别:
1. char大小对比
   Oracle: char 2000
   DB2   : char 254
2. 日期类型
   Oracle: date datetime
   DB2   :date(日期) time(时间)timestamp(日期时间)
12.decode 방법
Oracle中它是由数据库唯一产生的,在程序中可以获得
DB2  在V8版本才有此功能
Oracle 영상 튜토리얼"
추천 튜토리얼: "

위 내용은 db2와 oracle sql 문의 차이점은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.