`
javaee08
  • 浏览: 4206 次
  • 性别: Icon_minigender_1
  • 来自: 广州
最近访客 更多访客>>
社区版块
存档分类
最新评论

SQL Server,Oracle,DB2数据库SQL语句比较(转载)

阅读更多

转载:honeydh(http://www.51testing.com/?uid-191521-action-viewspace-itemid-101702)

 

1.1.1 取前n条记录

SQL Server: Select top n * from xtable

Oracle: Select * from xtable where rownum <=n

DB2: Select * from xtable fetch first n rows only

1.1.2 取当前日期

SQL Server: Select getdate()

Oracle: Select sysdate from dual

DB2: Select current timestamp from sysibm.sysdummy1

1.1.3 连接字符串

SQL Server: Select Hello+Toone

Oracle: Select Hello||Toone from dual

DB2: Select Hello||Toone from sysimb.sysdummy1

1.1.4 空值转换

SQL Server: SELECT userid,username,isnull(email,0) FROM AUTH_USER

Oracle: SELECT userid,username,nvl(email,0) FROM AUTH_USER

DB2: SELECT userid,username,value(email,0) FROM AUTH_USER

1.1.5 类型转换

SQL Server: SELECT convert(varchar,getdate(),20)

Oracle: SELECT to_char(sysdate,yyyy-mm-dd hh24:mi:ss) from dual

DB2: SELECT varchar(current timestamp) from sysibm.sysdummy1

注1:

■SQL Server中转换日期格式改变Style参数:20 ;

■Oracle中转换日期格式改变格式化参数:yyyy-mm-dd hh24:mi:ss ‘yyyy’、’mm’、’dd’、’hh12’、’hh24’、’mi’、’ss’等;

■Db2中转换日期格式改变系统常量:current timestamp ‘current date’、’current time’等;

注2:

■SQL Server数据类型改变“数据类型参数”:int、varchar等;

■Oracle数据类型改变函数:to_char()、to_date()、to_number()等;

■DB2数据类型改变函数:varchar()、int()、date()、time()等;

1.1.6 取值判断

SQL Server: select case Convert = case when g.master_type =system then 管理员 when g.master_type =roletype then 特殊角色 else 普通用户 end from global_code g

Oracle: select case g.master_type when system then 管理员 when roletype then 特殊角色 else 普通用户 end AS caseConvert from global_code g

DB2: select case g.master_type when system then 管理员 when roletype then 特殊角色 else 普通用户 end AS caseConvert From global_code g

1.1.7 位置 SQL

Server: select charindex(E,ABCDEF) select patindex(%E%,ABCDEF)

Oracle: select instr(ABCDEF,E) from dual

DB2: Select locate(E,ABCDEF) from

sysibm.sysdummy1

1.1.8 其他函数 SQL Server Oracle DB2

长度 Len() Length() Length()

取子串 Substring() Substr() Substr()

1.2



1.2.1 DB2V8.

1常用命令

■ 创建数据库 在服务器上执行 db2 CREATE DB oatemp

■ 删除数据库 在服务器上执行 db2 DROP DB oatemp

■ 创建表空间 db2 CREATE USER TEMPORARY TABLESPACE USERSPACE1 MANAGED BY SYSTEM USING ( USERSPACE1)

■ 启动数据库 切换用户 su – db2inst1 启动数据库: db2start

■ 关闭数据库 切换用户 su – db2inst1 关闭数据库 db2stop [force]

■ 创建远程管理节点 进入 DB2命令窗口 db2 CATALOG TCPIP NODE asnode REMOTE 10.1.22.176 SERVER 50000 db2 CATALOG DB oadb2 AS oadb2 AT NODE asnode

■ 连接数据库 db2 CONNECT TO oadb2 USER db2inst1 USING ibmdb2

■ 关闭数据库连接 db2 terminate

■ 执行脚本 db2 -td! -vf ioa2.db2 -z info.log

■ 导出脚本 db2look -d oadb2 -i db2inst1 -w ibmdb2 -e -o putsql.db2 -t auth_user db2look -d oadb2 -i db2inst1 -wibmdb2 -e -o putsq.db2

■ 查看正在使用的端口 netstat -a

■ 查询系统表 select count(*) from SYSCAT.TABLES where TABSCHEMA=’DB2INST1’ select count(*) from SYSCAT.PROCEDURES where PROCSCHEMA=’DB2INST1’

■ 常用命令 DB2 SELECT DROP TALBE ||TABNAME FROM SYSCAT.TABLES WHERE T ABSCHEMA=DB2INST1 AND TYPE=T >db2droptables.db2 DB2 SELECT DROP VIEW ||TABNAME FROM SYSCAT.TABLES WHERE T ABSCHEMA=DB2INST1 AND TYPE=V >db2dropviews.db2 DB2 –vf db2droptables.db2 –z info.log db2 SELECT username FROM auth_user FETCH FIRST 3 ROWS ONLY

■ 启动JDBC db2jstrt JDBC APPLET SERVER 6789

1.1 数据库移植注意事项

1.1.1 取前n条记录

SQL Server: Select top n * from xtable

Oracle:Select * from xtable where rownum <=n

DB2:Select * from xtable fetch first n rows only

1.1.2 取当前日期

SQL Server: Select getdate()

Oracle: Select sysdate from dual

DB2: Select current timestamp from sysibm.sysdummy1

1.1.3 连接字符串

SQL Server: Select 'Hello'+'Toone'

Oracle: Select 'Hello'||'Toone' from dual

DB2: Select 'Hello'||'Toone' from sysimb.sysdummy1

1.1.4 空值转换

SQL Server:SELECT userid,username,isnull(email,'0') FROM AUTH_USER

Oracle: SELECT userid,username,nvl(email,'0') FROM AUTH_USER

DB2:SELECT userid,username,value(email,'0') FROM AUTH_USER

1.1.5 类型转换

SQL Server: SELECT convert(varchar,getdate(),20)

Oracle:SELECT to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual

DB2: SELECT varchar(current timestamp) from sysibm.sysdummy1

注1:

■SQL Server中转换日期格式改变Style参数:20 ;

■Oracle中转换日期格式改变格式化参数:yyyy-mm-dd hh24:mi:ss XML:namespace prefix = o ns = "urn:schemas-microsoft-com:Office:office" />

‘yyyy’、’mm’、’dd’、’hh12’、’hh24’、’mi’、’ss’等;

■Db2中转换日期格式改变系统常量:current timestamp

‘current date’、’current time’等;

注2:

■SQL Server数据类型改变“数据类型参数”:int、varchar等;

■Oracle数据类型改变函数:to_char()、to_date()、to_number()等;

■DB2数据类型改变函数:varchar()、int()、date()、time()等;

1.1.6 取值判断

SQL Server:

select caseConvert =

case when g.master_type ='system' then '管理员'

when g.master_type ='roletype' then '特殊角色'

else '普通用户'

end

from global_code g

Oracle:

select case g.master_type

when 'system' then '管理员'

when 'roletype' then '特殊角色'

else '普通用户'

end

AS caseConvert

from global_code g

DB2:



select case g.master_type

when 'system' then '管理员'

when 'roletype' then '特殊角色'

else '普通用户'

end

AS caseConvert

From global_code g

1.1.7 位置

SQL Server:

select charindex('E','ABCDEF')

select patindex('%E%','ABCDEF')

Oracle:

select instr('ABCDEF','E') from dual

DB2:

Select locate('E','ABCDEF') from sysibm.sysdummy1

1.1.8 其他函数

SQL Server Oracle DB2

长度 Len() Length() Length()

取子串Substring() Substr() Substr()













1.2 附

1.2.1 DB2V8.1常用命令

■ 创建数据库在服务器上执行 db2 CREATE DB oatemp

■ 删除数据库在服务器上执行db2 DROP DB oatemp

■ 创建表空间

db2 "CREATE USER TEMPORARY TABLESPACE USERSPACE1 MANAGED BY SYSTEM USING (' USERSPACE1')"

■ 启动数据库 切换用户 su – db2inst1

启动数据库:db2start

■ 关闭数据库 切换用户 su – db2inst1 关闭数据库 db2stop [force]

■ 创建远程管理节点进入 DB2命令窗口

db2 CATALOG TCPIP NODE asnode REMOTE 10.1.22.176 SERVER 50000

db2 CATALOG DB oadb2 AS oadb2 AT NODE asnode

■ 连接数据库

db2 CONNECT TO oadb2 USER db2inst1 USING ibmdb2

■ 关闭数据库连接

db2 terminate

■ 执行脚本

db2 -td! -vf ioa2.db2 -z info.log

■ 导出脚本

db2look -d oadb2 -i db2inst1 -w ibmdb2 -e -o putsql.db2 -t auth_user

db2look -d oadb2 -i db2inst1 -w ibmdb2 -e -o putsq.db2

■ 查看正在使用的端口

netstat -a

■ 查询系统表

select count(*) from SYSCAT.TABLES where TABSCHEMA=’DB2INST1’ select count(*) from SYSCAT.PROCEDURES where PROCSCHEMA=’DB2INST1’

分享到:
评论

相关推荐

    SQL_Server,Oracle,DB2数据库SQL语句比较

    标题与描述均聚焦于SQL Server, Oracle, 和DB2数据库中的SQL语句比较,这是一个对IT专业人士特别是数据库管理员(DBA)、开发人员以及对数据库技术感兴趣的人来说极为实用的主题。以下是对给定文件中提及的关键知识点...

    oracle,sqlserver,db2驱动包亲测可用

    在实际开发中,这些驱动包被包含在Java项目类路径中,使得Java应用程序可以通过JDBC API执行SQL语句,完成对数据库的增删改查等操作。例如,使用`Class.forName()`加载驱动,`DriverManager.getConnection()`建立...

    数据库转换工具,可实现oracle,mysql,sqlserver,sybase,db2相互转换

    数据库转换工具,可实现oracle,mysql,sqlserver,sybase,db2相互转换

    db2 oracle sql server sybase access 数据库连接详解

    在本文中,我们将详细介绍数据库连接的各种方式,包括 Oracle、Sybase、SQL Server、Access 等多种数据库的连接方式,以及 ERWIN 工具的使用。 数据库连接是指应用程序与数据库之间的交互过程,通过数据库连接,...

    JDBC连接各种数据库的驱动(mySQL,SQLServer,Oracle,DB2,Access)

    本篇文章将深入探讨如何使用JDBC连接到不同类型的数据库,包括MySQL、SQL Server、Oracle、DB2和Access。 1. **MySQL驱动**: MySQL是一种开源、轻量级的关系型数据库管理系统,广泛应用于Web应用。在Java中,我们...

    db2,mysql,berby,oracle,postgresql,sqlserver,sybase数据库驱动jar包

    DB2的驱动jar包(如`db2jcc4.jar`或`db2jcc.jar`)包含了与DB2服务器通信所需的类和接口,使得Java应用可以执行SQL语句,管理数据等。 2. **MySQL**:MySQL是一款开源、免费的数据库,被广泛用于Web应用。MySQL的...

    LoadRunner对数据库的监控指标(sqlserver/oracle/db2)

    ### LoadRunner对数据库的监控...通过以上对于SQL Server、Oracle以及DB2中的关键监控指标的详细解释,可以帮助我们在进行性能测试时更好地理解和分析数据库性能瓶颈,从而采取相应的优化措施提升整体应用的性能表现。

    oracle连接db2数据库的步骤

    - 在新的 SQL 窗口中执行查询语句,从 DB2 数据库中选取数据,确保能够正确返回结果。 7. **处理存储过程**: - 如果有与 DB2 数据库交互的存储过程,可能需要重新编译以确保与新连接兼容。 请注意,不同环境的...

    基于SQL Server链接服务器实现Proficy Historian数据库的访问.pdf

    - 通过链接服务器访问其他数据库系统时,SQL Server实例可以通过OpenQuery函数调用其他服务器上的SQL语句,并获得查询结果。 4. SQL Server对Proficy Historian数据库的访问和数据整合方法 - 文章通过实例展示了...

    VB6.0与SQL Server2000的数据库连接方案比较.pdf

    ODBC可以连接多种数据库,包括SQL Server、Oracle、DB2等。 在VB6.0中,可以使用ADO或OLE DB来连接SQL Server2000数据库。ADO可以提供更好的性能和灵活性,而OLE DB可以提供更好的可扩展性和灵活性。 VB6.0与SQL ...

    微型Sql Server查询分析器、数据库比较工具,SQL语句编写助手

    微型Sql Server查询分析器: 有时为了解决问题,需要执行SQL脚本,但是电脑上又没有装SQL... 对主流数据库Sql Server,Oracle,DB2,MySql,Access等都可用,写脚本或存储过程时提示功能十分强大,十分方便,包你爱不释手

    如何将DB2数据库中的大对象(BLOB,CLOB)数据类型复制到Oracle数据库中

    本例中,我们讨论如何将DB2数据库中的BLOB数据类型复制到Oracle数据库。 1. **BLOB与CLOB数据类型**: BLOB(Binary Large Object)存储二进制大对象,如图像、音频或视频文件。CLOB(Character Large Object)...

    mysql,db2,oracle,sql2000,sql2005的数据库驱动包

    安装或引入这个驱动后,开发者可以使用SQL语句执行数据查询、更新等操作。 2. DB2驱动:DB2是由IBM开发的一款企业级关系数据库管理系统,适用于大型分布式环境。对应的驱动包括JDBC和ODBC(Open Database ...

    .net 统一数据库访问接口库,支持sql server ,db2,oracle,my sql,postgresql,sqlit

    .net 统一数据库访问接口库,支持sql server ,db2,oracle,my sql,postgresql,sqlite等多种数据库,简化数据库的GRUD操作和where语句的lambda表达式

    SQL SERVER数据库教程

    关系数据库系统是当前应用最广泛的数据库管理系统,其代表产品包括MS SQL Server、Oracle和DB2等。关系数据库系统通过SQL语言进行数据的查询和操作。SQL语言不仅能够管理数据,还能够管理数据库本身。为了统一不同...

    java连接数据库(Oracle8、Sql Server、DB2、Informix、Sybase、MySQL、PostgreSQL)

    本文将详细介绍如何使用Java连接Oracle8、SQL Server、DB2、Informix、Sybase、MySQL以及PostgreSQL等数据库,并提供相应的代码示例。 #### 1. Java连接Oracle8/8i/9i数据库 在连接Oracle数据库时,我们需要使用...

    常用数据库sql分页

    常见的数据库管理系统包括MySQL、SQL Server、Oracle、DB2等,每种数据库管理系统都有其特有的分页机制和语法。 MySQL分页 MySQL的分页语句使用LIMIT关键字,语法为: ```sql SELECT * FROM table_name LIMIT ...

    Oracle迁移到DB2 SQL语句差异

    ### Oracle迁移到DB2 SQL语句差异 在IT项目的实施过程中,可能会遇到客户提出更换数据库的需求,例如从Oracle迁移到DB2。这种情况下,除了要考虑配置上的差异外,还需要关注SQL语句的不同之处。以下是对Oracle与DB2...

    数据库表数据转为insert sql语句

    1、对ms sql server及其他数据库库中类似int identity的数据库类型没有处理,转出来的sql语句直接执行时,还需要做一下处理. 2、不支持长字符集类型.比如ms sql server中的image,oracle中的blob,clob,long以及db2中...

Global site tag (gtag.js) - Google Analytics