1.数据类型不同。
      sql server 的数据类型

int ,smallint ,char,varchar,nchar,nvarchar,ntext,datetime,smalldatetime,money,decima, float,bit

oracle 的数据类型:number(p,s),char,varchar2,Date,LOB
               注意: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;
      SQL Server中有五种约束类型,分别是 PRIMARY KEY约束、FOREIGN KEY约束、UNIQUE约束、DEFAULT约束、和CHECK

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

oracle之约束

一、维护数据的完整性

概述:数据的完整性用于确保数据库数据遵从一定的商业和逻辑规则。在Oracle中,数据完整性可以使用约束、触发器、应用程序(过程、函数)三种方法来实现,在这三种方法中,因为约束易于维护,并且具有最好的性能,所以作为维护数据完整性的首选。

1、约束

约束用于确保数据库数据满足特定的商业规则。在Oracle中,约束包括:not null、unique、primary key, foreign key和check五种。

A、not null(非空)

如果在列上定义了not null,那么当插入数据时,必须为列提供数据。

B、unique(唯一)

当定义了唯一约束后,该列值是不能重复的,但是可以为null。

C、primary key(主键)

用于唯一的标识表行的数据,当定义主键约束后,该列不但不能重复而且不能为NULL。一张表最多只能有一个主键,但是可以由多个unique约束。

D、foreign key(外键)

用于定义主表和从表之间的关系,外键约束要定义在从表上,主要则必须具有主键约束或是unique约束,当定义外键约束后,要求外键列数据必须在主表的主键列存在或是为NULL。

E、check

用于强制行数据必须满足的条件,假定在sal列上定义了check约束,并要求sal列值在1000~2000之间,如果不在1000~2000之间就会提示出错。

  4.连接变量和字符串的方式不一样
      sql server 中连接:使用“+”连接,例如:print 'aaaa'+@name;
      
      oracle  中连接:使用“||”连接,例如:dbms_output.put_line('aaa'||name);---name为变量
 
  5.oracle没有identity自动增长列,而是使用序列实现增长
      sql server 自动增长:在表的主键列中可直接使用identity(1,1)实现增长
      
      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 2005后已经都支持case column when value与case when column = value,oracle也是)
      sql server中:
            select ....case.....(else)....end....语句
            select stuno '学号',case
            when grade>=90 and grade<=100 then ''
            when grade>=80 and grade<90 then ''
         when grade>=70 and grade<80 then ''
         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',5,0) 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 DepositSum,cardType,name,state from CurrentAccount where name like '%'||names||'%';
                    dd number;
                    cc number;
                    nn varchar2(20);
                    sta number;
                    begin
                      open cursor_sel;
                           loop
                             fetch cursor_sel into dd,cc,nn,sta;
                             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与ORACLE的几点区别的更多相关文章

  1. sql server,mysql,oracle平时用法的区别

    由于工作的原因,上家公司一直使用的oracle,后来接触了的几个项目,既有使用mysql的又有使用sqlserver,自己在使用sqlserver及mysql要实现某功能时,经常要在网上找来找去,所以 ...

  2. 【转】SQL Server与Oracle的区别

    转自:http://soft.chinabyte.com/database/255/12258255.shtml SQL Server与Oracle的区别 2012-02-10 00:00 中国IT实 ...

  3. 数据库 --> SQL Server 和 Oracle 以及 MySQL 区别

    SQL Server 和 Oracle 以及 MySQL 区别 三者是目前市场占有率最高(依安装量而非收入)的关系数据库,而且很有代表性.排行第四的DB2(属IBM公司),与Oracle的定位和架构非 ...

  4. SQL Server,MySQL,Oracle三者的区别

    SQL Server,MySQL,Oracle三者的区别 2016-10-14 转自:SQL Server,MySQL,Oracle三者的区别 目录 1 Oracle.Sql Server.MySql ...

  5. sql server 与 oracle的区别(转)

    --1.数据类型不同.      --sql server 的数据类型:int ,smallint ,char,varchar,nchar,nvarchar,ntext,datetime,smalld ...

  6. ASP.NET 连接 SQL Server 和 Oracle 教程

    临近期末,有很多同学都问我怎么关于ASP.NET 连接 SQL Server 和 Oracle 的问题.由于人太多了,我也不能一一去帮忙,就写了这篇博客.希望对大家有用处. 首先,前期准备是要安装数据 ...

  7. SQL Server 中 EXEC 与 SP_EXECUTESQL 的区别

    SQL Server 中 EXEC 与 SP_EXECUTESQL 的区别 MSSQL为我们提供了两种动态执行SQL语句的命令,分别是 EXEC 和 SP_EXECUTESQL ,我们先来看一下两种方 ...

  8. SQL Server 表变量和临时表的区别

    SQL Server 表变量和临时表的区别 一.表变量 表变量在SQL Server 2000中首次被引入.表变量的具体定义包括列定义,列名,数据类型和约束.而在表变量中可以使用的约束包括主键约束,唯 ...

  9. 关于sql server远程访问Oracle数据库 OpenQuery查询返回多条数据的问题

    在Sql Server远程访问Oracle 中的数据库表时: 远程语法通常为: select * from OpenQuery(Oracle链接服务器名称,‘查询语句’) eg: select * f ...

随机推荐

  1. oracle数据据 Python+Pandas 获取Oracle数据库并加入DataFrame

    import pandas as pd import sys import imp imp.reload(sys) from sqlalchemy import create_engine impor ...

  2. 一个汉字转拼音的php类

    代码来自网上,可用 <?php function Pinyin($_String, $_Code='gb2312') { $_DataKey = "a|ai|an|ang|ao|ba| ...

  3. $ cd `dirname $0` 和PWD用法

      在命令行状态下单纯执行 $ cd `dirname $0` 是毫无意义的.因为他返回当前路径的".".这个命令写在脚本文件里才有作用,他返回这个脚本文件放置的目录,并可以根据这 ...

  4. c++ 纯虚析构函数

    ; 这就是一个纯虚析构函数,这种定义是允许的. 一般纯虚函数都不允许有实体,但是因为析构一个类的过程中会把所有的父类全析构了,所以每个类必有一个析构函数. 所以.纯虚析构函数需要提供函数的实现,而一般 ...

  5. Unity3D笔记 英保通二

    一.访问另一个物体 1.代码中定义一个public的物体 例如:var target:Transform; 在面板上直接拖拽一个物体赋值给target 2.通过GameObject.Find(&quo ...

  6. Unity3D笔记十七 Unity3D生命周期

    一个游戏组件的脚本有一个生命周期——一开始实例化,直到结束实例被销毁.在这期间,他们有时候处于激活状态,有时候处于非激活状态:对于活动,对用户有时候可见,有时候不可见 本文主要讨论常见脚本的的生命周期 ...

  7. Java虚拟机九 java.lang.String在虚拟机中的实现

    在Java中,Java的设计者对String对象进行了大量的优化,主要有三个特点: 1.不变性: 不变性是指String对象一旦生成,则不能再对它进行改变.String的这个特点可以泛化成不变(imm ...

  8. H5填坑笔记--持续更新

    最近一直在做移动端的页面,发现很多的坑,这里做一下总结,填填坑…… css常见的问题(一) 一.iOS键盘首字母自动大写 IOS的机子,默认英文输入法状态下,首字母是自动大写的,有时候挺烦人的. 在i ...

  9. Kafka在Linux上安装部署及样例测试

    Kafka是一个分布式的.可分区的.可复制的消息系统.它提供了普通消息系统的功能,但具有自己独特的设计.这个独特的设计是什么样的呢 介绍 Kafka是一个分布式的.可分区的.可复制的消息系统.它提供了 ...

  10. 基本类型互相之间转化可以用Covent类来实现。

    一.C#类型的转换 在c#中类型的转换分两种:显式和隐式,基本的规则如下: 1.基类对象转化为子类对象,必须显式转换,规则:(类型名) 对象.2.值类型和引用类型的转换采用装箱(boxing)或拆箱( ...