SqlServer和Oracle

SQL语句可以用来执行各种各样的操作,例如更新数据库中的数据,从数据库中提取数据等。目前,绝大多数流行的关系型数据库管理系统,如Oracle, Sybase, Microsoft SQL Server, Access等都采用了SQL语言标准。虽然很多数据库都对SQL语句进行了再开发和扩展,但是包括Select, Insert, Update, Delete, Create,以及Drop在内的标准的SQL命令仍然可以被用来完成几乎所有的数据库操作。 SQL Server SQL Server 是一个关系数据库管理系统。它最初是由Microsoft Sybase 和Ashton-Tate三家公司共同开发的,于1988 年推出了第一个OS/2 版本。在Windows NT 推出后,Microsoft与Sybase 在SQL Server 的开发上就分道扬镳了,Microsoft 将SQL Server 移植到Windows NT系统上,专注于开发推广SQL Server 的Windows NT 版本。Sybase 则较专注于SQL Server在UNIX操作系统上的应用。 SQL Server 2000 是Microsoft 公司推出的SQL Server 数据库管理系统,该版本继承了SQL Server 7.0 版本的优点,同时又比它增加了许多更先进的功能。具有使用方便可伸缩性好与相关软件集成程度高等优点,可跨越从运行Microsoft Windows 98 的膝上型电脑到运行Microsoft Windows 2000 的大型多处理器的服务器等多种平台使用。
编辑本段SQL Server 2008新功能
这个平台有以下特点: · 可信任的——使得公司可以以很高的安全性、可靠性和可扩展性来运行他们最关键任务的应用程序。 · 高效的——使得公司可以降低开发和管理他们的数据基础设施的时间和成本。 · 智能的——提供了一个全面的平台,可以在你的用户需要的时候给他发送观察和信息。 一、可信任的 (一)保护你的信息 在过去的SQL Server 2005的基础之上,SQL Server 2008做了以下方面的增强来扩展它的安全性: * 简单的数据加密 SQL Server 2008可以对整个数据库、数据文件和日志文件进行加密,而不需要改动应用程序。进行加密使公司可以满足遵守规范和及其关注数据隐私的要求。简单的数据加密的好处包括使用任何范围或模糊查询搜索加密的数据、加强数据安全性以防止未授权的用户访问、还有数据加密。这些可以在不改变已有的应用程序的情况下进行。 * 外键管理 SQL Server 2008为加密和密钥管理提供了一个全面的解决方案。为了满足不断发展的对数据中心的信息的更强安全性的需求,公司投资给供应商来管理公司内的安全密钥。 SQL Server 2008通过支持第三方密钥管理和硬件安全模块(HSM)产品为这个需求提供了很好的支持。 * 增强了审查 SQL Server 2008使你可以审查你的数据的操作,从而提高了遵从性和安全性。审查不只包括对数据修改的所有信息,还包括关于什么时候对数据进行读取的信息。SQL Server 2008具有像服务器中加强的审查的配置和管理这样的功能,这使得公司可以满足各种规范需求。SQL Server 2008还可以定义每一个数据库的审查规范,所以审查配置可以为每一个数据库作单独的制定。为指定对象作审查配置使审查的执行性能更好,配置的灵活性也更高。 (二)确保业务可持续性 * 改进了数据库镜像 SQL Server 2008基于SQL Server 2005,并提供了更可靠的加强了数据库镜像的平台。新的特性包括: · 页面自动修复。SQL Server 2008通过请求获得一个从镜像合作机器上得到的出错页面的重新拷贝,使主要的和镜像的计算机可以透明的修复数据页面上的823和824错误。 · 提高了性能。SQL Server 2008压缩了输出的日志流,以便使数据库镜像所要求的网络带宽达到最小。 SQL Server 服务器安装剖析 sql server 2000以前的版本,例如7.0一般不存在多个版本,只有标准版跟桌面版,用户如果不清楚该装什么版本的话,可按安装上的安装先决条件指示安装,一般在WIN2000 服务器版上装标准版,其他的系统装桌面版的就可以;而SQL Server 2000安装问题就比较大,时常见问题有如下: (1)配置服务器时中断. (2)注册 ActiveX 时中断. (3)显示到100%的时候中断. (4)提示:command line option syntax error, type command /? for help,继续安装,最后在配置服务器的时候出现:无法找到动态链接SQLUNIRL.DLL于指定的路径…… (5)以前进行的程序创建了挂起的文件操作,运行安装程序前,必须重新启动 (1)(2)(3)的解决办法: 提醒:为避免误操作,先备份注册表和数据库进不了SQL Server 2000,可以备份 Program Files\Microsoft SQL Server\MSSQL\Data 文件夹的文件. 1、先把SQL Server卸载(卸载不掉也没有关系,继续下面的操作) 2、把Microsoft SQL Server文件夹整个删掉。 3、运行注册表,删除如下项: HKEY_CURRENT_USER\Software\Microsoft\Microsoft SQL Server HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer 4、需要的话就重新启动系统 5、重新安装 另外也可尝试单步运行安装 SQL Server 2000的方法: 1:放入 SQL Server 2000 光盘. 2:在"开始"–“运行"键入 “F:\x86\setup.exe k=dbg” (F是光盘) 注意: 一、不同的操作系统支持的SQL Server 2000版本以及对硬件的要求。 Windows 2000 Server可以安装SQL Server 2000的任何版本. Windows 2000 Professional只能安装SQL Server 2000的个人版、开发版、评估版、MCDE 二、 SQL Server 2000各版本以及对硬件的要求。 (4)的解决办法 因为安装文件的路径(完整路径)里有中文. 比如 c:\SQLSERVER中文企业版\ 改成 c:\SQLSERVER\ (5)的解决办法 a、重启机器,再进行安装,如果发现还有该错误,请按下面步骤 b、在开始->运行中输入regedit c、到HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager 位置 d、选择文件->倒出,保存 e、在右边窗口右击PendingFileRenameOperations,选择删除,然后确认 f、重启安装,问题解决 ------------------------------------------------------- 如果问题依旧,试试先修复操作系统 命令提示符下执行: sfc /scannow 最后的方法:换Windows 2000 安装盘 和SQL Server2000安装盘 有时候问题的原因很奇怪,有人曾更换了一个电源就解决了问题。 1 先卸载您的 SQL Server 2000,必要的时候删除 Program Files\Microsoft SQL Server 文件夹 2 打开注册表 在"开始”–"运行"键入 “regedit” 3 按下列顺序点击打开 + HKEY_LOCAL_MACHINE + SOFTWART + Microsoft + Windows + CurrentVersion + Setup + ExceptionComponents 4 将 ExceptionComponents 下面的文件夹全部删除! 如 {60BFF50D-FB2C-4498-A577-C9548C390BB9} {60BFF50D-FB2C-4498-A577-C9548C390BB9} {60BFF50D-FB2C-4498-A577-C9548C390BB9} {60BFF50D-FB2C-4498-A577-C9548C390BB9} 6 重新启动: 7 重新安装 SQL Server 2000 XP+SP2的问题 1.winxp+sp2的系统需要安装SQL Server SP3(服务包补丁3),如果之前已经安装,必须再安装一次。 SP3可以在微软网站免费下载,中文版地址如下: SQL Server 2000 Service Pack 3a

  1. Oracle电子商务套件(Oracle E-Business Suite) Oracle电子商务套件是行业中第一个集成的基于互联网的商务应用套件,它将前台与后台运营中的关键业务流程自动化。Oracle电子商务套件涵盖了营销、销售、服务、合同、定单管理、产品设计、采购、供应链、制造、财务、项目管理、人力资源与专业服务自动化在内的企业中每一个领域的业务。2001年全球共有1100多家企业实施了Oracle电子商务套件,目前全球已经有超过12000家用户正在获益于Oracle电子商务套件所带来的前所未有的好处。 自从Oracle电子商务套件首次面世以来,甲骨文公司已经推出了6种电子商务套件的增强版本,从而形成了一整套成熟的、功能齐全的应用套件。Oracle电子商务套件能够使用户在实施业务应用时拥有前所未有的可选择性与灵活性,它的开放式基础架构与单一数据模型使用户在部署套件中的应用软件时拥有多种选择,既可以单独使用,也可以组成业务流,还可以作为一个整体的集成套件来部署。Oracle电子商务套件既可以作为用CD ROM为载体的传统软件的形式,也可以作为一种在线服务的形式来提供给用户。 2. Oracle10g —— 新一代电子商务平台 Oracle10g是业界第一个完整的、智能化的新一代Internet基础架构,Oracle10g电子商务平台实际上是指Oracle数据库10g、Oracle应用服务器10g和Oracle开发工具套件10g的完整集成。 Oracle数据库10g是第一套具有无限可伸缩性与高可用性,并可在集群环境中运行商业软件的互联网数据库,具有400多个领先的数据库功能,在集群技术、高可用性、商业智能、安全性、系统管理等方面都实现了新的突破。作为甲骨文公司长达十年的软件技术研发成果,真正应用集群技术(Real Application Clusters)能够提供近乎无限的扩充能力与整体可用性,为用户带来透明的、高速增长的集群功能。 Oracle应用服务器10g是J2EE认证的、最轻、最快、最具伸缩性的应用服务器,提供了企业门户软件、无线支持、高速缓存、轻量级J2EE引擎、商务智能、快速应用开发、应用与业务集成、Web 服务等多种应用开发功能,形成完整的电子商务应用开发和部署环境。使用了Oracle应用服务器10g的用户可以通过升级软件来取代升级硬件,大大的节省了基础设施的成本花费。 Oracle开发工具套件10g是一套完整的集成开发工具,可用于快速开发使用Java和XML语言的互联网应用和Web服务,支持任何语言、任何操作系统、任何开发风格、开发生命周期的任何阶段以及所有最新的互联网标准。 9i之后的Oracle的硬件要求很高,(Windows版本)9i建议配512M内存,10g建议配1G内存。 3.oracle11g 2007年7月12日,甲骨文公司在美国纽约宣布推出数据库Oracle 11g,这是Oracle数据库的最新版本。甲骨文介绍说,Oracle 11g有400多项功能,经过了1500万个小时的测试,开发工作量达到了3.6万人/月。 有意思的是,根据甲骨文以往几个版本的发行经验,发布新版Oracle数据库的频率在3年左右,以此类推,Oracle 11g应该在07年年底发布,选择在7月份发布,不知道是否和代号Katmai的SQL Server 2008有关,因为目前还处于测试阶段的SQL Server 2008将在08年2月发布,业内用Oracle 10g和SQL Server 2003做比较也曾一度惹恼了甲骨文。 Oracle 11g五大特性 与无压缩格式下存储数据相比,新的Oracle数据压缩技术能够确保以较小的开销节省三倍以上的磁盘存储空间。这一点比仅节省磁盘空间要具有更大的优势,因为它能够使企业节约更多的开支,以便有更多的资金来巩固自己的地位。 自动诊断知识库(Automatic Diagnostic Repository,ADR)是专门针对严重错误的知识库。该知识库基本上能够自动完成一些以往需要由数据库管理员来手动完成的操作。 作为ADR的一部分,SQL性能分析器(SQL Performance Analyzer,SPA)是最让人惊喜的特性之一。SQL性能分析器是一个整体调整工具,管理员可以通过该工具在数据库上定义和重演(replay) 一个典型的工作负载,之后管理员可以调节整体参数来使数据库尽快的达到最佳性能——而这一任务同样也是许多年以来由数据库管理员手动完成的。 由于获得了最优的初始参数,数据库管理员就不需要调整数以万计的SQL语句。管理员需要做的就是给定一个典型的负载 ,由SPA根据历史记录来决定SQL的最终设置,而不用管理员来检测哪一个SQL设置是最合理的。 多年以来,甲骨文公司一直在努力完成地另一个新特性便是“联机更新”(在不down机的情况下更新软件)。实际上,很难从软件工程的角度来设计一个运行时能自动升级的软件。由于真正的应用集群(Real Application Clusters ,RAC)特性,甲骨文公司再一次对其他的数据库供应商造成了更大的压力。在实际的使用过程中,数据库产品的用户总是希望产品有持续的高可用性,这并不是说只需满足下次补丁更新之前的3年的时间就够了。 自动内存管理特性可以追根溯源至Oracle 9i,那时甲骨文公司推出首款自动调节存储池的工具。AMM工具其实就是一种探测机制。实际上,Oracle 11g 有很多随机访问存储池,当存储管理模式(Access Management Mode,AMM)探测到某个存储池中已满时,它将整个随机存储器(Random Access Memory,RAM)从一个区域分配到其他相对合适的区域。

–sql server 与 oracle的区别:

  --DBMS 数据库管理系统

–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;

  --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(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中:
–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;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值