oracle与sqlserver的区别?(详细一点)

问题描述

oracle与sqlserver的区别?(详细一点)
oracle与sqlserver的区别?(详细一点)作用?开发方面的区别?

解决方案

开发上边,至少有以下几点区别:

--sql server 与 oracle的区别:

  --DBMS 数据库管理系统

--1.数据类型不同。
--sql server 的数据类型:int smallint charvarcharncharnvarcharntextdatetimesmalldatetimemoneydecima
--floatbit……

  --oracle 的数据类型:number(ps)charvarchar2DateLOB           --注意:insert into table_name values('1''张三''男'date'2012-3-5');---插入字符串日期前加date转换类型

--2.获得当前系统时间的函数不同。
--sql server :getdate()

  --oracle:sysdate        --例如:设定日期格式的函数:to_char(sysdate'yyy-mm-dd');

--3.在oracle中没有默认约束的说法
--sql server 中添加默认约束:alter table talbe_name add DF_table_name default('男') for sex;

  --oracle 中添加默认值:alter table table_name modify(sex default('男'));

--4.连接变量和字符串的方式不一样
--sql server 中连接:使用“+”连接,例如:print 'aaaa'+@name;

  --oracle  中连接:使用“||”连接,例如:dbms_output.put_line('aaa'||name);---name为变量

--5.oracle没有identity自动增长列,而是使用序列实现增长
--sql server 自动增长:在表的主键列中可直接使用identity(11)实现增长

  --oracle 使用序列自动增长:                             create sequence se_id                              start with 1                             increment by 1  --使用序列实现自动增长:se_id.nextval

--6.条件语句if……else……的语法不同
--sql server中:
if 条件
begin
…………
end
else
begin
…………
end
--oracle中:
if 条件1 then
…………;
elsif 条件2 then
…………;
else
…………;
end if;

--7.case语句的语法不同
--sql server中:
--select ....case.....(else)....end....语句
select stuno '学号'case
when grade>=90 and grade<=100 then '★★★★'
when grade>=80 and grade when grade>=70 and grade when grade>=60 and grade<70 then '★'
else '差'
end as '等级' from score
go
--oracle中:
declare
nums number:=&nos;--&nos表示提示传入值
begin
case nums
when 100 then
dbms_output.put_line('满分也,不错');
when 90 then
dbms_output.put_line('90分页很不错了');
end case;
end;
--8.触发器创建语法不同
--sql server中:

     --首先判断触发器是否已经存在     if exists (select * from sys.sysobjects where name='tr_delete')--如果存在先删除drop trigger tr_delete     go    --创建触发器    create trigger tr_delete    on bookInfo    instead of delete    as        --定义变量        declare @bookid int         select @bookid=Bookid from deleted---deleted执行删除语句( delete from BookInfo where BookId=1),自动生成的deleted表        --删除与该图书的相关记录(先删除从表再删除主表)        delete from borrowinfo where  bookid=@bookid        delete from backinfo where  bookid=@bookid        delete from BookInfo where BookId=@bookid        --判断        if @@error<>0        begin            print '删除失败'            rollback transaction        end        else        begin            print '删除成功'        end    go    delete from BookInfo where BookId=1         --oracle中:    --创建触发器    create or replace trigger tri_test    before insert or update or delete     on table_name    [for each row]---如果要使用 :new /:old 就必须使用行触发器    declare         nums varchar2(20);    begin      select 'F'||lpad('aa'50) into nums from dual;    end;

--9.oracle中的存储过程
--sql server中存储过程:

        --判断存储过程是否已经存在        if exists(select * from sys.sysobjects where name='proc_name') --如果存在先删除 drop proc proc_name        go        --创建存储过程语句        create proc/procedure proc_name        @参数名1 数据类型 [out/output]        @参数名2 数据类型 [out/output]        as              …………        go        --调用存储过程        --如果有输出参数,则需定义变量(假设@参数2为输出参数)        declare @变量名 数据类型        exec proc_name @参数名1='aaa'@参数名2=@变量名 out        ---oracle中带游标及循环的存储过程         create or replace procedure proc_selCurrent         (                names varchar2         )         as                cursor cursor_sel                is                select DepositSumcardTypenamestate from CurrentAccount where name like '%'||names||'%';                dd number;                cc number;                nn varchar2(20);                sta number;                begin                  open cursor_sel;                       loop                         fetch cursor_sel into ddccnnsta;                         dbms_output.put_line('存款金额:'||dd||'姓名:'||nn);                       exit when cursor_sel%notfound;                       end loop;                  close cursor_sel;                end;          --调用存储过程          begin            proc_selCurrent('a');          end;

--10.创建用户的方式不同
--sql server中
--1、创建登陆账号:sa-----123456
create Login 登陆名称 with password='登陆密码'

       --修改登陆账户:             alter Login 登陆名称 with name='新登录名称' and password='新登录密码'       --禁用/启用登陆账号             alter Login 登录名称 disable(禁用)/enable(启用)       --删除登陆账号             drop Login 登录名称       --2、创建用户:        create user 用户名 for/from Login 登陆名称        --修改用户名        alter user 用户名 with name='新用户名'        --删除用户名        drop user 用户名        ---授权限        grant select/update/delete/insert on 表名 to 用户名    ---oracle中:        ---创建用户语法:              create user 用户名              identified by 密码              default tablespace users              temporary tablespace temp              quota 10M on users              --修改密码:              alter user 用户名 identified by 新密码              --授予权限:              grant create session to 用户名              --删除用户              drop user 用户名 cascade;

解决方案二:
相比较而言,开发比较小规模的系统,适合采用SQL Server,它在Windows平台上配置维护都很简单。而开发比较大规模的系统,Oracle占优。至于技术上的差别,其实很小,而且一些比较老的文章中提到SQL Server所不支持的一些特性,其实在新版中早已支持。

解决方案三:
oracle适合作为大型系统的数据库,sqlserver更适合中小型系统的数据库。另外,oracle可以在多种平台(linux、unix、windows)上面部署,sqlserver目前只支持windows。在开发工具方面,sql server management studio更加容易操作(跟windows、office一样的风格),plsql相比较没有那么强大,但是比纯命令行操作oracle要方便的多。

解决方案四:
IPHONE和诺基亚的区别

时间: 2024-05-19 12:02:01

oracle与sqlserver的区别?(详细一点)的相关文章

MySQL与Oracle的语法区别详细对比 (转)

Oracle和mysql的一些简单命令对比 1) SQL> select to_char(sysdate,'yyyy-mm-dd') from dual; SQL> select to_char(sysdate,'hh24-mi-ss') from dual; mysql> select date_format(now(),'%Y-%m-%d'); mysql> select time_format(now(),'%H-%i-%S'); 日期函数 增加一个月: SQL> se

oracle与sqlserver相互操作

oracle|server|sqlserver 一:sqlserver连接oracle1.配置windows的ODBC数据源: 开始菜单->设置->管理工具->数据源(ODBC)->进入配置用户DSN或者系统DSN均可以:添加->选择Microsoft ODBC for oracle->自定义数据源名称(最好跟tns中连接串同名!)->服务器名称(必填!填写tns文件中的连接串名称)->完成. 2.配置sqlserver2000中的连接服务器: 企业管理器-

JavaScript中property和attribute的区别详细介绍

 这篇文章主要介绍了JavaScript中property和attribute的区别详细介绍,本文总结了定义.相同这处.不同之处.浏览器兼容性上的差别等内容,并建议优先选择property,需要的朋友可以参考下     1. 定义 Property:属性,所有的HTML元素都由HTMLElement类型表示,HTMLElement类型直接继承自Element并添加了一些属性,添加的这些属性分别对应于每个HTML元素都有下面的这5个标准特性: id,title,lang,dir,className

哪位大神帮我注释这段代码,最好详细一点(AT89s**与霍尔元件测速报警应用)。有附电路的原理图

问题描述 哪位大神帮我注释这段代码,最好详细一点(AT89s**与霍尔元件测速报警应用).有附电路的原理图 5C #includeunsigned char code table[12]={0xc00xf90xa40xb00x990x920x820xf80x800x900xff0xBF};unsigned char code table2[12]={0x400x790x240x300x190x120x020x780x000x100xff}; sbit CS3020=P1^0;sbit SET=P

Oracle 与 MySQL 的区别

Oracle 与 MySQL 的区别 1.在ORACLE中用select * from all_users显示所有的用户,而在MYSQL中显示所有数据库的命令是show databases.对于我的理解,ORACLE项目来说一个项目就应该有一个用户和其对应的表空间,而MYSQL项目中也应该有个用户和一个库.在ORACLE(db2也一样)中表空间是文件系统中的物理容器的逻辑表示,视图.触发器和存储过程也可以保存在表空间中.而MYSQL并没有使用表空间来进行管理. 2.查询当前所有的表.ORACLE

bundler 怎么在ubuntu下安装和编译 详细一点 现有教程操作完后不能成功!

问题描述 bundler 怎么在ubuntu下安装和编译 详细一点 现有教程操作完后不能成功! bundler 怎么在ubuntu下安装和编译 详细一点 现有教程操作完后不能成功! 解决方案 参考下http://wenku.baidu.com/link?url=NgJF6QDZ7Dnl3rLlCiWtPRP9MMnOVDhNqGkL2ceC5ZwWQ-adUTNS-Dm8mKSVtInWTnUSZfsg5dZ5E7OskbwDW7H7bp3EN9ogz8q5nDd_BgO 解决方案二: 先说说什

sqlserver-求助:从Oracle向SqlServer导入数据问题

问题描述 求助:从Oracle向SqlServer导入数据问题 情况是这样: 用datareader从oracle中读取数据,100w左右记录,利用.NET的sqlbulkcopy方法插入到sqlserver中. 但是每次执行到80w左右的时候就提示 "primary文件组已满". 网上说的方法都试了没用,磁盘空间足够,ntfs格式.数据库和日志文件设置了自动增长不限大小,每次增长30M-1024M都试过. 目前数据文件在10G左右. 奇怪的是另一张表数据量更大,200多万数据,同样的

c++-求大神帮忙翻译一下几句程序,关于图书管理系统,顺便可以的话详细一点。谢谢(?_?)

问题描述 求大神帮忙翻译一下几句程序,关于图书管理系统,顺便可以的话详细一点.谢谢(?_?) #ifndef _LIBARY_H#define _LIBARY_H#include "appoint.h"#include "Manager.h"#include "Mysql_select.h"#include "Reader.h"#include "ways.h"class Libary{private: C

c语言-求大神解释C语言题,请解释详细一点,谢谢

问题描述 求大神解释C语言题,请解释详细一点,谢谢 下面的代码输出什么? #include int main(void) { int i; int a[5]; for (i = 0; i <= 5; ++i) { a[i] = -i; printf("a[%d] = %dn", i, a[i]); } return 0; } 解决方案 #include<stdio.h> void main() { int i=0; int a[5]={0,0,0,0,0}; for