当前位置: 首页 > 编程日记 > 正文

SQL Server 与 ORACLE 的区别

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 1increment 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_deleteon bookInfoinstead of deleteas 定义变量 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 '删除成功' endgodelete from BookInfo where BookId=1 oracle中: 创建触发器create or replace trigger tri_testbefore 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; beginopen 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;   自己总结的一点,仅供参考

作者:落幕年代 来源:CSDN 原文:https://blog.csdn.net/lailai186/article/details/45267959?utm_source=copy 版权声明:本文为博主原创文章,转载请附上博文链接!

转载于:https://www.cnblogs.com/bocom-zx/p/9783315.html

相关文章:

php如何定时执行任务

PHP的实现决定了它没有Java和.Net这种AppServer的概念, 而http协议是一个无状态的协议, php只能被用户触发, 被调用, 调用后会自动退出内存, 没有常驻内存, 就没有办法准确的定时处理那么, 如果需要用PHP定时执行某些任务的话, 可以有以下俩个方法&#xff0c;下面就让我们来看…

Java的多态(详尽版)

父类类型&#xff08;比如Mammal&#xff09;的变量指向子类&#xff08;比如Cat&#xff09;创建的对象&#xff0c;使用该变量调用父类中一个*被子类重写*的方法&#xff08;比如move方法&#xff09;&#xff0c; 则父类中的方法呈现出不同的行为特征&#xff0c;这就是多态…

C++ memset

memset的主要功能是对一片内存进行赋值&#xff08;逐字节进行&#xff09; 包含在头文件#include < cstring >中。 函数模板 void *memset(void *s, int v, size_t n); s&#xff1a;数组名&#xff0c;或指向某一片内存的指针名&#xff0c; v&#xff1a;要填充的值…

Linux12-文件系统基础

目录 一、识别文件系统和设备 1.1、分区 1.2、逻辑卷 二、挂载卸载文件系统命令mount、umount、blkid、lsof 2.1、挂载 2.2、卸载 三、检查文件系统命令df、du 四、制作文件链接命令ln 4.1、硬链接 4.2、软连接 五、查找文件命令locate、find 一、识别文件系统和设备…

C语言------运算符和表达式

1. 自动类型转换是由计算机自动完成的&#xff0c;当由低级别的向高级别的转换时&#xff0c;不会报警&#xff0c;但是当高级别的向低级别的转换时&#xff0c;会发出告警信息&#xff0c;信息意思就是提示会有部分数据丢失的可能。 2. 强制类型转换是通过“&#xff08;数据类…

String类常用方法(看一眼就懂)

public class Test{public static void main(String[] args){String name " T o m ";System.out.println(name.length()); //输入字符的长度&#xff0c;&#xff08;空格也占一个字节&#xff09;System.out.println(name.equals(" T o m ")); //判断连…

1.2.2一个数可以有多少种用连续素数之和表示

#include <iostream> using namespace std; const int maxp2000,n10000; int prime[maxp],total0; bool isprime(int k)//bool函数用来求素数 {for(int i0;i<total;i)if(k%prime[i]0)//判断素数的一种方法&#xff08;用这个数对数组当中所有的 素数 进行取余&#xf…

C++查找算法(更新中)

C的查找分为静态查找与动态查找。 静态查找&#xff1a;只是在查找表中判断是否有这一个元素&#xff0c;取出这个元素的属性。 动态查找&#xff1a;在查找过程中&#xff0c;会对查找表做出修改。 比如插入、删除。 静态查找 静态查找包括&#xff1a;顺序查找、二分查找、…

编译Linux Kernel(linux-4.19.178)并制作成rpm文件

目录 一、安装依赖项 二、下载、解压缩、制作.config文件 三、编译内核及打包 四、升级内核 首次尝试编译Linux内核&#xff0c;记录过程&#xff0c;提供Linux Kernel(linux-4.19.178)下载https://download.csdn.net/download/qpeity/15637656。 一、安装依赖项 安装依赖…

2016 多校赛3 A 水 B 期望,规律 C 各种博弈 J 物理题,积分 K 暴力,水

2016 Multi-University Training Contest 3 A - Sqrt Bo 题意&#xff1a;给一个数 n&#xff0c;问n要多少次平方后化为1&#xff0c;如果超过5次输出"TAT"。 tags&#xff1a;SB题&#xff0c;5次内平方的&#xff0c;即小于2*2*4*16*256*65536 。然后0、1特判。 #…

BZOJ 1801 [Ahoi2009]中国象棋(线性动规)(洛谷P2051)

题意&#xff1a;就是在n*m的格子中放“炮”&#xff08;中国象棋中的棋子&#xff09;问有多少种放法&#xff0c;使得没有任意的两个炮相互攻击 思路&#xff1a;我们很容易的得到一列或者一行中最多放下两个炮&#xff08;我也只能得到这些了&#xff0c;满脑子状压&#xf…

Java中父类构造方法对子类构造方法的影响(不是一句话可以说清的)

推荐的阅读顺序是&#xff1a;先看Test类&#xff0c;再根据提示看父类和子类 让我们通过代码来了解一下&#xff1a;创建一个父类&#xff1a; public class Father{public Father(){super();//默认调用Object构造方法(Object是所有类的父类)System.out.println("父类构…

ORB_SLAM2概述

追踪线程 灰度化处理。构建当前帧&#xff08;提取每幅图像的特征点&#xff0c;并分配到网格中&#xff0c;这会极大的方便某一领域内的特征点的查找与匹配&#xff09;。单目相机初始化操作&#xff1a;通过特征点匹配&#xff0c;使用RANSACDLC计算H矩阵&#xff0c;并根据…

源同步方法与注意事项

2021年的信息安全攻防演练比2020年来的稍早了一些&#xff0c;还是一样的配方&#xff0c;还是一样的味道。检查单位的YUM源&#xff0c;发现没有CentOS 7.9的&#xff0c;排查后发现原来是中科大的rsync同步地址放生了变化&#xff0c;导致源同步失败。改一下地址就好&#xf…

Android开发教程 - 使用Data Binding(二)集成与配置

本系列目录 使用Data Binding&#xff08;一&#xff09;介绍使用Data Binding&#xff08;二&#xff09;集成与配置使用Data Binding&#xff08;三&#xff09;在Activity中的使用使用Data Binding&#xff08;四&#xff09;在Fragment中的使用使用Data Binding&#xff08…

Java封装(速读版)

封装就是使用公共方法对私有成员变量进行操作&#xff08;赋值或获取&#xff09;&#xff0c;这样做可以防止该类的代码和数据被其他类 定义的代码随意访问&#xff0c;有助于数据的安全。–我们可以通过修改成员变量的属性&#xff08;一般为private&#xff09;&#xff0c;…

C# 创建压缩文件

出处&#xff1a;http://www.cnblogs.com/sparkdev/ 在程序中对文件进行压缩解压缩是很重要的功能&#xff0c;不仅能减小文件的体积&#xff0c;还能对文件起到保护作用。如果是生成用户可以下载的文件&#xff0c;还可以极大的减少网络流量并提升下载速度。最近在一个 C# 项目…

Windows自带certutil工具校验用法

windows自带校验工具certutil&#xff0c;记录用法如下。 certutil -hashfile <file> MD5 certutil -hashfile <file> SHA1 certutil -hashfile <file> SHA256 注意MD5、SHA1、SHA256必须是大写的&#xff01;否则报错&#xff01; C:\Users\Lenovo\Downl…

C++数组名做函数形参/指针

数组名做函数形参 数组未开辟空间时 #include <iostream> using namespace std; void test(int* a) {*a 0;*(a1) 1;*(a2) 2;cout<<a[0]<<a[1]<<a[2]<<endl;return; } int main(int argc,char* argv[]) {int* a;test(a);cout<<a[0]<…

String创建方式及其区别(快速了解)

让我们来看两种赋值方式&#xff1a; 第一种&#xff1a;直接赋值 String name1 "Tom"; String name2 "Tom"; System.out.println(name1 name2);//用来判断name1和name2的地址是否相同&#xff0c;相同为true&#xff0c;不同为false //此时打印的结果…

npm 常用命令详解

本文以Windows平台上做测试&#xff0c;以gulp为示例做教程&#xff0c;出自作者白树&#xff0c;转载请声明&#xff01; 目录 npm是什么npm install 安装模块npm uninstall 卸载模块npm update 更新模块npm outdated 检查模块是否已经过时npm ls 查看安装的模块npm init 在项…

linux Mysql 安装

一、wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm二、sudo rpm -ivh mysql-community-release-el7-5.noarch.rpm三、yum install -y mysql-server mysql mysql-devel四、systemctl start mysqld.service 五、systemctl status mysqld.service六、mysq…

==和equals()的作用及区别

""的作用是比较两个变量是否相等。 当变量是基本数据类型时&#xff0c;比较的是值是否相等的&#xff1a;相等返回true&#xff0c;不等返回false&#xff1a; double a 100.0;int b 100;System.out.println(ab);//输出结果为&#xff1a;true当变量是引用类型时…

np.dot()运算准则

数组*数组 直接点乘。 数组*多维 数组有3个元素的话&#xff0c;用(3,)表示 二维矩阵3*3用&#xff08;3,3&#xff09;表示 &#xff08;3,3&#xff09; * &#xff08;3,&#xff09;结果为&#xff08;3,&#xff09;&#xff0c;即包含3个元素的一维向量 https://blog.…

用createrepo命令创建自己的yum源

观察一下使用的各大开源软件镜像站的yum源&#xff0c;思考他们是怎么创建的呢&#xff1f;我们自己能否创建呢&#xff1f;当然能。 1、安装web服务&#xff0c;本例选择nginx。配置过程不多说&#xff0c;本例选择的根目录是/var/repos&#xff0c;添加三个选项可以看到包的…

String创建对象的个数 StringBuffer

String name1 "Tom"; //创建了一个String类型的对象 String name2 "Lu""cy"; //创建了一个String类型的对象&#xff08;先拼接后创建对象&#xff0c;所以是一个&#xff09;String str "Ja"; String name3 str "m…

第5次作业+105032014166+张珍珍

测试链接&#xff1a;http://www.cnblogs.com/wxcclub/p/6792634.html 一、被测项目界面。 二、测试用例设计表 1.等价类 等价类划分法 输入及外部条件 有效等价类 等价类编号 无效等价类 等价类编号 日期类型 数字 1 非数字 8 年 1912≤year≤2050 2 year<19…

C++ new

C中利用new操作符在堆区开辟数据 堆区开辟的数据&#xff0c;由程序员手动开辟&#xff0c;手动释放&#xff0c;释放利用操作符 delete 语法&#xff1a;new 数据类型 利用new创建的数据&#xff0c;会返回该数据对应的类型的指针 开辟单个内存 语法&#xff1a;new 数据类型…

漫画:禅道程序员的一天

更多精彩欢迎关注《海边的程序员》 转载于:https://www.cnblogs.com/xiaobai007/p/9797462.html

HA01-集群介绍

目录 一、宏观理解集群 二、微观理解集群 三、安装高可用集群环境 3.1、实验环境简介 3.2、安装集群软件并配置集群 3.3、用命令行创建集群 一、宏观理解集群 集群中的一个服务器称为一个节点node。 集群资源以mysql为例一般有&#xff1a;vip&#xff08;浮动IP&#…