oracle数据库常用语句语法说明

合集下载

ORACLE常用SQL语句大全

ORACLE常用SQL语句大全

ORACLE常用SQL语句大全一、基础1、说明:创建数据库CREATE DATABASE database-name2、说明:删除数据库drop database dbname3、说明:备份sql server--- 创建备份数据的 deviceUSE masterEXEC sp_addumpdevice 'disk', 'testBack', 'c:/mssql7backup/MyNwind_1.dat'--- 开始备份BACKUP DATABASE pubs TO testBack4、说明:创建新表create table tabname(col1 type1 [not null] [primary key],col2 type2 [not nul l],..)根据已有的表创建新表:A:select * into table_new from table_old (使用旧表创建新表)B:create table tab_new as select col1,col2… from tab_old definition only<仅适用于Oracle>5、说明:删除表drop table tablename6、说明:增加一个列,删除一个列A:alter table tabname add column col typeB:alter table tabname drop column colname注:DB2DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。

7、添加主键:Alter table tabname add primary key(col)删除主键:Alter table tabname drop primary key(col)8、创建索引:create [unique] index idxname on tabname(col….)删除索引:drop index idxname注:索引是不可更改的,想更改必须删除重新建。

oracle常用SQL语句(汇总版)

oracle常用SQL语句(汇总版)

Oracle数据库常用sql语句ORACLE 常用的SQL语法和数据对象一.数据控制语句(DML) 部分1.INSER T (往数据表里插入记录的语句)INSERT INTO 表名(字段名1, 字段名2, ……) VALUES ( 值1, 值2, ……);INSERT INTO 表名(字段名1, 字段名2, ……) SELECT (字段名1, 字段名2, ……) FROM 另外的表名;字符串类型的字段值必须用单引号括起来, 例如: ’GOOD DAY’如果字段值里包含单引号’ 需要进行字符串转换, 我们把它替换成两个单引号''.字符串类型的字段值超过定义的长度会出错, 最好在插入前进行长度校验.日期字段的字段值可以用当前数据库的系统时间SYSDATE, 精确到秒或者用字符串转换成日期型函数TO_DATE(‘2001-08-01’,’YYYY-MM-DD’)TO_DATE()还有很多种日期格式, 可以参看OR ACLE DOC.年-月-日小时:分钟:秒的格式YYYY-MM-DD HH24:MI:SSINSERT时最大可操作的字符串长度小于等于4000个单字节, 如果要插入更长的字符串, 请考虑字段用CLOB类型,方法借用ORACLE里自带的DBMS_LOB程序包.INSERT时如果要用到从1开始自动增长的序列号, 应该先建立一个序列号CREATE SEQUENCE 序列号的名称(最好是表名+序列号标记) INCREMENT BY 1 START WI TH 1 MAXVALUE 99999 CYCLE NOCACHE;其中最大的值按字段的长度来定, 如果定义的自动增长的序列号NUMBER(6) , 最大值为999999 INSERT 语句插入这个字段值为: 序列号的名称.NEXTVAL2.DELETE (删除数据表里记录的语句)DELETE FROM表名 WHERE 条件;注意:删除记录并不能释放ORACLE里被占用的数据块表空间. 它只把那些被删除的数据块标成unused.如果确实要删除一个大表里的全部记录, 可以用TRUNCATE 命令, 它可以释放占用的数据块表空间TRUNCATE TABLE 表名;此操作不可回退.3.UPDATE (修改数据表里记录的语句)UPDATE表名SET 字段名1=值1, 字段名2=值2, …… WHERE 条件;如果修改的值N没有赋值或定义时, 将把原来的记录内容清为NULL, 最好在修改前进行非空校验;值N超过定义的长度会出错, 最好在插入前进行长度校验..注意事项:A. 以上SQL语句对表都加上了行级锁,确认完成后, 必须加上事物处理结束的命令COMMIT 才能正式生效,否则改变不一定写入数据库里.如果想撤回这些操作, 可以用命令ROLLBACK 复原.B. 在运行INSERT, DELETE 和UPDATE 语句前最好估算一下可能操作的记录范围,应该把它限定在较小(一万条记录) 范围内,. 否则ORACLE处理这个事物用到很大的回退段.程序响应慢甚至失去响应. 如果记录数上十万以上这些操作, 可以把这些SQL语句分段分次完成, 其间加上COMMIT 确认事物处理.二.数据定义(DDL) 部分1.CREATE (创建表, 索引, 视图, 同义词, 过程, 函数, 数据库链接等)ORACLE常用的字段类型有CHAR 固定长度的字符串VARCHAR2 可变长度的字符串NUMBER(M,N) 数字型M是位数总长度, N是小数的长度DATE 日期类型创建表时要把较小的不为空的字段放在前面, 可能为空的字段放在后面创建表时可以用中文的字段名, 但最好还是用英文的字段名创建表时可以给字段加上默认值, 例如DEFAUL T SYSDATE这样每次插入和修改时, 不用程序操作这个字段都能得到动作的时间创建表时可以给字段加上约束条件例如不允许重复UNIQUE, 关键字PRIMAR Y KEY2.AL TER (改变表, 索引, 视图等)改变表的名称AL TER TABLE 表名1 TO 表名2;在表的后面增加一个字段AL TER TABLE表名ADD 字段名字段名描述;修改表里字段的定义描述AL TER TABLE表名MODIFY字段名字段名描述;给表里的字段加上约束条件AL TER TABLE 表名ADD CONSTRAINT 约束名PRIMAR Y KEY (字段名);AL TER TABLE 表名ADD CONSTRAINT 约束名UNIQUE (字段名);把表放在或取出数据库的内存区AL TER TABLE 表名CACHE;AL TER TABLE 表名NOCACHE;3.DROP (删除表, 索引, 视图, 同义词, 过程, 函数, 数据库链接等)删除表和它所有的约束条件DROP TABLE 表名CASCADE CONSTRAINTS;4.TRUNCATE (清空表里的所有记录, 保留表的结构)TRUNCATE 表名;三.查询语句(SELECT) 部分SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE 条件;字段名可以带入函数例如: COUNT(*), MIN(字段名), MAX(字段名), AVG(字段名), DISTINCT(字段名), TO_CHAR(DATE字段名,'YYYY-MM-DD HH24:MI:SS')NVL(EXPR1, EXPR2)函数解释:IF EXPR1=NULLRETURN EXPR2ELSERETURN EXPR1DECODE(AA﹐V1﹐R1﹐V2﹐R2....)函数解释:IF AA=V1 THEN RETURN R1IF AA=V2 THEN RETURN R2..…ELSERETURN NULLLPAD(char1,n,char2)函数解释:字符char1按制定的位数n显示,不足的位数用char2字符串替换左边的空位字段名之间可以进行算术运算例如: (字段名1*字段名1)/3查询语句可以嵌套例如: SELECT …… FROM(SELECT …… FROM表名1, [表名2, ……] WHERE 条件) WHERE 条件2;两个查询语句的结果可以做集合操作例如: 并集UNION(去掉重复记录), 并集UNION ALL(不去掉重复记录), 差集MINUS, 交集INTERSECT分组查询SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] GROUP BY字段名1[HAVING 条件] ;两个以上表之间的连接查询SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE表名1.字段名= 表名2. 字段名[ AND ……] ;SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE表名1.字段名= 表名2. 字段名(+) [ AND ……] ;有(+)号的字段位置自动补空值查询结果集的排序操作, 默认的排序是升序ASC, 降序是DESCSELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……]ORDER BY字段名1, 字段名2 DESC;字符串模糊比较的方法INSTR(字段名, ‘字符串’)>0字段名LIKE ‘字符串%’[‘%字符串%’]每个表都有一个隐含的字段ROWID, 它标记着记录的唯一性.四.ORACLE里常用的数据对象 (SCHEMA)1.索引(INDEX)CREATE INDEX 索引名ON 表名( 字段1, [字段2, ……] );AL TER INDEX 索引名REBUILD;一个表的索引最好不要超过三个(特殊的大表除外), 最好用单字段索引, 结合SQL语句的分析执行情况, 也可以建立多字段的组合索引和基于函数的索引ORACLE8.1.7字符串可以索引的最大长度为1578 单字节ORACLE8.0.6字符串可以索引的最大长度为758 单字节2.视图(VIEW)CREATE VIEW 视图名AS SELECT …. FROM …..;AL TER VIEW视图名COMPILE;视图仅是一个SQL查询语句, 它可以把表之间复杂的关系简洁化.3.同义词(SYNONMY)CREATE SYNONYM同义词名FOR 表名;CREATE SYNONYM同义词名FOR 表名@数据库链接名;4.数据库链接(DATABASE LINK)CREATE DATABASE LINK数据库链接名CONNECT TO 用户名IDENTIFIED BY 密码USING ‘数据库连接字符串’;数据库连接字符串可以用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA里定义.数据库参数global_name=true时要求数据库链接名称跟远端数据库名称一样数据库全局名称可以用以下命令查出SELECT * FROM GLOBAL_NAME;查询远端数据库里的表SELECT …… FROM 表名@数据库链接名;五.权限管理(DCL) 语句1.GRANT 赋于权限常用的系统权限集合有以下三个:CONNECT(基本的连接), RESOURCE(程序开发), DBA(数据库管理)常用的数据对象权限有以下五个:ALL ON 数据对象名, SELECT ON 数据对象名, UPDATE ON 数据对象名, DELETE ON 数据对象名, INSER T ON 数据对象名, AL TER ON 数据对象名GRANT CONNECT, RESOURCE TO 用户名;GRANT SELECT ON 表名 TO 用户名;GRANT SELECT, INSERT, DELETE ON表名 TO 用户名1, 用户名2;2.REVOKE 回收权限REVOKE CONNECT, RESOURCE FROM 用户名;REVOKE SELECT ON 表名FROM 用户名;REVOKE SELECT, INSERT, DELETE ON表名FROM 用户名1, 用户名2;查询数据库中第63号错误:select orgaddr,destaddr from sm_histable0116 where error_code='63';查询数据库中开户用户最大提交和最大下发数:select MSISDN,TCOS,OCOS from ms_usertable;查询数据库中各种错误代码的总和:select error_code,count(*) from sm_histable0513 group by error_code orderby error_code;查询报表数据库中话单统计种类查询。

oracle查询数据库语句

oracle查询数据库语句

oracle查询数据库语句在Oracle 数据库中,用于查询数据的语句通常是SQL(Structured Query Language)语句。

以下是一些基本的Oracle 查询语句示例:1. SELECT 语句:用于从数据库表中检索数据。

```sqlSELECT column1, column2, ...FROM table_nameWHERE condition;```示例:```sqlSELECT employee_id, first_name, last_nameFROM employeesWHERE department_id = 30;```2. DISTINCT 关键字:用于返回唯一不同的值。

```sqlSELECT DISTINCT column1, column2, ...FROM table_name;```示例:```sqlSELECT DISTINCT job_idFROM employees;```3. WHERE 子句:用于过滤检索的数据。

```sqlSELECT column1, column2, ...FROM table_nameWHERE condition;```示例:```sqlSELECT employee_id, first_name, last_nameFROM employeesWHERE salary > 50000;```4. ORDER BY 子句:用于按指定的列对结果进行排序。

```sqlSELECT column1, column2, ...FROM table_nameORDER BY column1 [ASC|DESC], column2 [ASC|DESC], ...;```示例:```sqlSELECT employee_id, first_name, last_nameFROM employeesORDER BY last_name ASC, first_name ASC;```5. GROUP BY 子句:用于对结果进行分组。

常用oracle数据库命令

常用oracle数据库命令

常用oracle数据库命令
1. 启动Oracle数据库
$ sqlplus /nolog
SQL> connect / as sysdba
SQL> startup
3. 创建表空间
创建表空间的命令是:
SQL> create tablespace 表空间名 datafile '路径名' size 大小;
6. 创建用户
7. 删除用户
删除用户的命令是:
8. 授权用户
SQL> grant 权限 to 用户名;
9. 撤销用户的权限
11. 查看表结构
查看表结构的命令是:
SQL> desc 表名;
SQL> create table 表名 (列名数据类型, 列名数据类型, …);
13. 删除表
14. 插入数据
插入数据的命令是:
SQL> update 表名 set 列名=新值 where 某条件;
18. 创建索引
20. 查看索引
21. 查询相关信息
查询相关信息的命令是:
SQL> select * from v$session; -- 查看会话 22. 查看数据库版本
24. 备份数据库
$ exp 用户名/密码 file=备份文件路径备注:以上命令均需要在Oracle登录后进行。

oracle if 语法

oracle if 语法

oracle if 语法Oracle IF语法详解一、引言Oracle是一种关系型数据库管理系统,提供了丰富的SQL语法来操作数据库。

其中,IF语法是一种常用的条件语句,用于根据条件判断执行不同的操作。

本文将详细介绍Oracle IF语法的使用方法和注意事项。

二、IF语法的基本用法IF语法的基本结构如下:IF 条件 THEN执行操作1;ELSE执行操作2;END IF;其中,条件是一个逻辑表达式,用于判断是否满足某个条件。

如果条件为真,则执行操作1;如果条件为假,则执行操作2。

三、IF语法的扩展用法除了基本的IF语法外,Oracle还提供了一些扩展用法,以满足更复杂的条件判断需求。

1. IF-ELSIF-ELSE结构如果需要判断多个条件,可以使用IF-ELSIF-ELSE结构。

示例如下:IF 条件1 THEN执行操作1;ELSIF 条件2 THEN执行操作2;ELSE执行操作3;END IF;在这种结构中,条件1为真时执行操作1;条件1为假,条件2为真时执行操作2;条件1和条件2都为假时执行操作3。

2. IF-THEN-ELSEIF-ELSE结构如果需要判断多个条件,并且每个条件都需要执行不同的操作,可以使用IF-THEN-ELSEIF-ELSE结构。

示例如下:IF 条件1 THEN执行操作1;ELSEIF 条件2 THEN执行操作2;ELSEIF 条件3 THEN执行操作3;ELSE执行操作4;END IF;在这种结构中,条件1为真时执行操作1;条件1为假,条件2为真时执行操作2;条件1和条件2都为假,条件3为真时执行操作3;条件1、条件2和条件3都为假时执行操作4。

3. IF-THEN嵌套结构在某些情况下,可能需要嵌套使用IF-THEN语句来实现更复杂的条件判断。

示例如下:IF 条件1 THENIF 条件2 THEN执行操作1;ELSE执行操作2;END IF;ELSE执行操作3;END IF;在这种结构中,条件1为真时,进一步判断条件2是否为真,如果条件2为真则执行操作1,否则执行操作2;条件1为假时执行操作3。

Oracle数据库语法总结

Oracle数据库语法总结

Oracle数据库语法总结一、DDL(数据定义语言)1、创建、删除表(1)CREATE TABLE 语句用于在Oracle数据库中创建新表:CREATETABLE表名(列1数据类型(大小/长度)[NOTNULL][CONSTRAINT约束名]列2数据类型(大小/长度)[NOTNULL][CONSTRAINT约束名]……(2)DROP TABLE 语句用于从Oracle数据库中删除表:DROPTABLE表名2、更改表(1)ALTERTABLE语句用于更改现有的表:ALTERTABLE表名ADD(添加新的列),MODIFY(修改现有的列),DROP(删除现有的列)(2)RENAME语句用于更改表名:RENAME表名1TO表名23、创建索引(1)CREATEINDEX语句用于在表中创建索引:CREATEINDEX索引名ON表名(列1,列2,...)(2)DROPINDEX语句用于从表中删除索引:DROPINDEX索引名4、创建约束(1)Primary Key 约束:ALTERTABLE表名ADDCONSTRAINT主键名PRIMARYKEY(列名)(2)Foreign Key约束:ALTERTABLE表名ADDCONSTRAINT外键名FOREIGNKEY(列名)REFERENCES参照表名(参照列);(3)Unique 约束:ALTERTABLE表名ADDCONSTRAINT唯一约束名UNIQUE(列1,列2,...);(4)NOTNULL约束:ALTERTABLE表名ADDCONSTRAINT非空约束名NOTNULL(列1,列2,...);5、删除约束(1)Primary Key 约束:ALTERTABLE表名DROPCONSTRAINT主键名PRIMARYKEY;(2)Foreign Key约束:ALTERTABLE表名DROPCONSTRAINT外键名FOREIGNKEY;(3)Unique 约束:。

Oracle数据库语句大全

Oracle数据库语句大全

Oracle数据库语句大全一.入门部分1.创建表空间create tablespace schooltbs datafile ‘D:\oracle\datasource\schooltbs.dbf’ size 10M autoextend on;2.删除表空间drop tablespace schooltbs[including contents and datafiles];3.查询表空间基本信息select *||tablespace_name from DBA_TABLESPACES;4.创建用户create user lihuaidentified by lihuadefault tablespace schooltbstemporary tablespace temp;5.更改用户alter user lihuaidentified by 123default tablespace users;6.锁定用户alter user lihua account lock|unlock;7.删除用户drop user lihua cascade;--删除用户模式8.oracle数据库中的角色connect,dba,select_catalog_role,delete_catalog_role,execute_catalo g_role,exp_full_database,imp_full_database,resource9.授予连接服务器的角色grant connect to lihua;10.授予使用表空间的角色grant resource to lihua with grant option;--该用户也有授权的权限11.授予操作表的权限grant select,insert on user_tbl to scott;--当前用户grant delete,update on er_tbl to scott;--系统管理员二.SQL查询和SQL函数1.SQl支持的命令:数据定义语言(DDL):create,alter,drop数据操纵语言(DML):insert,delete,update,select数据控制语言(DCL):grant,revoke事务控制语言(TCL):commit,savepoint,rollback2.Oracle数据类型字符,数值,日期,RAW,LOB字符型char:1-2000字节的定长字符varchar2:1-4000字节的变长字符long:2GB的变长字符注意:一个表中最多可有一列为long型Long列不能定义唯一约束或主键约束long列上不能创建索引过程或存储过程不能接受long类型的参数。

oracle常用语法

oracle常用语法

oracle常用语法Oracle是一种广泛使用的关系型数据库管理系统,它被广泛使用于企业级应用程序和其他高效数据处理方案中。

在使用Oracle时,需要掌握一些常用的语法和技巧,才能更轻松地处理数据。

下面我们来介绍一些常用的Oracle语法。

1. SELECT语句SELECT语句是Oracle中最常用的语句之一,它用于从表中检索数据。

SELECT语句的基本语法如下:SELECT column1, column2, …, columnN FROM table_name;其中,column1, column2, …, columnN是需要检索的列名,table_name是需要从中检索数据的表名。

可以使用通配符(*)来检索所有列。

2. WHERE语句WHERE语句用于从表中选择满足指定条件的行。

它的基本语法如下:SELECT column1, column2, …, columnN FROM table_name WHERE condition;其中,condition是指定的条件,可以使用比较运算符(>、<、=、>=、<=、<>)和逻辑运算符(AND、OR、NOT)来连接多个条件。

例如:SELECT * FROM employees WHERE salary > 50000 AND department = 'Sales';此语句将从employees表中选择薪资大于50000且所在部门为“Sales”的员工。

3. ORDER BY语句ORDER BY语句用于按照指定的列对检索结果进行排序。

它的基本语法如下:SELECT column1, column2, …, columnN FROM table_name ORDER BY column1 [ASC|DESC];其中,ASC表示按升序排列,DESC表示按降序排列。

例如:SELECT * FROM employees ORDER BY salary DESC;此语句将从employees表中选择所有员工,并按薪资从高到低进行排序。

oracle数据库if语句的用法

oracle数据库if语句的用法

oracle数据库if语句的用法Oracle数据库if语句的用法是用于在SQL查询中执行条件判断和条件控制的语句。

它可以根据条件的结果选择不同的执行路径,实现灵活的逻辑控制。

在Oracle数据库中,if语句的基本语法为:```sqlIF condition THENstatements;ELSIF condition THENstatements;ELSEstatements;END IF;```其中,condition是一个条件表达式,可以是一个比较表达式、逻辑表达式或者函数返回的布尔值。

根据条件表达式的结果,程序将会执行相应的语句块。

例如,我们可以使用if语句根据员工的工资水平来进行评级。

假设我们有一个员工表(employees),其中包含了员工的工资信息(salary)。

我们可以按照以下方式来实现:```sqlDECLAREv_grade VARCHAR2(10);v_salary employees.salary%TYPE;BEGINSELECT salaryINTO v_salaryFROM employeesWHERE employee_id = 100; -- 假设查询员工ID为100的工资IF v_salary >= 10000 THENv_grade := '高级';ELSIF v_salary >= 5000 AND v_salary < 10000 THENv_grade := '中级';ELSEv_grade := '初级';END IF;DBMS_OUTPUT.PUT_LINE('员工工资评级为:' || v_grade);END;```在上述代码中,我们首先声明了两个变量:v_grade用于存储员工的评级结果,v_salary用于存储查询到的员工工资。

然后,使用SELECT语句将查询到的工资值赋给v_salary。

oracle 数据库建表语句

oracle 数据库建表语句

oracle 数据库建表语句摘要:1.Oracle 数据库简介2.建表语句的基本语法3.创建表的实例4.总结正文:Oracle 数据库是一款功能强大的关系型数据库管理系统,广泛应用于各种企业和组织的数据存储和管理。

在Oracle 数据库中,建表语句是创建数据库表的关键操作,它可以通过SQL 语句实现。

下面,我们将详细介绍Oracle 数据库建表语句的基本语法和创建表的实例。

1.Oracle 数据库简介Oracle 数据库是由Oracle 公司开发的一款关系型数据库管理系统,它具有高性能、高可用性和可扩展性等特点。

Oracle 数据库支持多种平台,如Windows、Linux 等,适用于各种企业和组织的数据存储和管理需求。

2.建表语句的基本语法在Oracle 数据库中,创建表的SQL 语句的基本语法如下:```CREATE TABLE 表名(列名1 数据类型,列名2 数据类型,...);```其中,`表名`是所创建表的名称,`列名1`、`列名2`等是表中的列名,`数据类型`是列的数据类型,如VARCHAR2、NUMBER 等。

例如,创建一个名为`students`的表,包含`id`、`name`和`age`三个列,可以使用以下SQL 语句:```CREATE TABLE students (id NUMBER,name VARCHAR2(50),age NUMBER);```3.创建表的实例下面,我们通过一个具体的实例来演示如何使用Oracle 数据库建表语句创建一个表。

假设我们要创建一个名为`employees`的表,包含`id`、`name`、`position`、`salary`和`department`五个列。

首先,我们需要确定每个列的数据类型:`id`为`NUMBER`类型,`name`为`VARCHAR2(50)`类型,`position`为`VARCHAR2(100)`类型,`salary`为`NUMBER`类型,`department`为`VARCHAR2(100)`类型。

oracle数据库group by用法(一)

oracle数据库group by用法(一)

oracle数据库group by用法(一)Oracle数据库Group By用法详解在Oracle数据库中,GROUP BY是一种常用的查询语句,用于按照指定的列对查询结果进行分组。

通过GROUP BY语句,可以对分组后的数据进行聚合运算,如计算总和、平均值等。

本文将介绍一些常见的GROUP BY用法,并对其进行详细解释。

1. 基本用法下面是GROUP BY的基本语法:SELECT column_name(s)FROM table_nameWHERE conditionGROUP BY column_name(s)•column_name(s):指定要分组的列名,可以是一个或多个列名。

•table_name:指定要操作的表名。

•condition:查询条件,可选。

2. 分组查询通过GROUP BY可以实现对指定列的分组查询,例如:SELECT department, COUNT(*)FROM employeesGROUP BY department;上述示例中,我们通过GROUP BY将employees表中的数据按照department列进行分组,并计算每个部门的员工数量。

3. 加入聚合函数GROUP BY常常和聚合函数一起使用,以进行进一步的统计和计算。

下面是一个示例:SELECT department, AVG(salary)FROM employeesGROUP BY department;上述示例中,我们按照department列进行分组,并计算每个部门的平均工资。

4. 多个分组列GROUP BY语句支持多个分组列的定义,即可以按照多个列对查询结果进行分组。

示例如下:SELECT department, gender, AVG(salary)FROM employeesGROUP BY department, gender;上述示例中,我们按照department和gender两列进行分组,并计算每个部门和性别的平均工资。

oracle 语句大全

oracle 语句大全

oracle 语句大全SELECT --从数据库表中检索数据行和列INSERT --向数据库表添加新数据行DELETE --从数据库表中删除数据行UPDATE --更新数据库表中的数据--数据定义CREATE TABLE --创建一个数据库表DROP TABLE --从数据库中删除表ALTER TABLE --修改数据库表结构CREATE VIEW --创建一个视图DROP VIEW --从数据库中删除视图CREATE INDEX --为数据库表创建一个索引DROP INDEX --从数据库中删除索引CREATE PROCEDURE --创建一个存储过程DROP PROCEDURE --从数据库中删除存储过程CREATE TRIGGER --创建一个触发器DROP TRIGGER --从数据库中删除触发器CREATE SCHEMA --向数据库添加一个新模式DROP SCHEMA --从数据库中删除一个模式CREATE DOMAIN --创建一个数据值域ALTER DOMAIN --改变域定义DROP DOMAIN --从数据库中删除一个域--数据控制GRANT --授予用户访问权限DENY --拒绝用户访问REVOKE --解除用户访问权限--事务控制COMMIT --结束当前事务ROLLBACK --中止当前事务SET TRANSACTION --定义当前事务数据访问特征--程序化SQLDECLARE --为查询设定游标EXPLAN --为查询描述数据访问计划OPEN --检索查询结果打开一个游标FETCH --检索一行查询结果CLOSE --关闭游标PREPARE --为动态执行准备SQL 语句EXECUTE --动态地执行SQL 语句DESCRIBE --描述准备好的查询---局部变量declare @id char(10)--set @id = '10010001'select @id = '10010001'---全局变量---必须以@@开头--IF ELSEdeclare @x int @y int @z intselect @x = 1 @y = 2 @z=3if @x > @yprint 'x > y' --打印字符串'x > y'else if @y > @zprint 'y > z'else print 'z > y'--CASEuse panguupdate employeeset e_wage =casewhen job_level = ’1’ then e_wage*1.08when job_level = ’2’ then e_wage*1.07when job_level = ’3’ then e_wage*1.06else e_wage*1.05end--WHILE CONTINUE BREAKdeclare @x int @y int @c intselect @x = 1 @y=1while @x <3 br/>beginprint @x --打印变量x 的值while @y <3 br/>beginselect @c = 100*@x + @yprint @c --打印变量c 的值select @y = @y + 1endselect @x = @x + 1select @y = 1end--WAITFOR--例等待1 小时2 分零3 秒后才执行SELECT 语句waitfor delay ’01:02:03’select * from employee--例等到晚上11 点零8 分后才执行SELECT 语句waitfor time ’23:08:00’select * from employee***SELECT***select *(列名) from table_name(表名) where column_name operator valueex:(宿主)select * from stock_information where stockid = str(nid)stockname = 'str_name'stockname like '% find this %'stockname like '[a-zA-Z]%' --------- ([]指定值的范围)stockname like '[^F-M]%' --------- (^排除指定范围)--------- 只能在使用like关键字的where子句中使用通配符)or stockpath = 'stock_path'or stocknumber <1000 br/>and stockindex = 24not stocksex = 'man'stocknumber between 20 and 100stocknumber in(10,20,30)order by stockid desc(asc) --------- 排序,desc-降序,asc-升序order by 1,2 --------- by列号stockname = (select stockname from stock_information where stockid = 4)--------- 子查询--------- 除非能确保内层select只返回一个行的值,--------- 否则应在外层where子句中用一个in限定符select distinct column_name form table_name --------- distinct指定检索独有的列值,不重复select stocknumber ,"stocknumber + 10" = stocknumber + 10 from table_nameselect stockname , "stocknumber" = count(*) from table_name group by stockname--------- group by 将表按行分组,指定列中有相同的值having count(*) = 2 --------- having选定指定的组select *from table1, table2where table1.id *= table2.id -------- 左外部连接,table1中有的而table2中没有得以null表示table1.id =* table2.id -------- 右外部连接select stockname from table1union [all] ----- union合并查询结果集,all-保留重复行select stockname from table2***insert***insert into table_name (Stock_name,Stock_number) value ("xxx","xxxx")value (select Stockname , Stocknumber from Stock_table2)---value为select语句***update***update table_name set Stockname = "xxx" [where Stockid = 3]Stockname = defaultStockname = nullStocknumber = Stockname + 4***delete***delete from table_name where Stockid = 3truncate table_name ----------- 删除表中所有行,仍保持表的完整性drop table table_name --------------- 完全删除表***alter table*** --- 修改数据库表结构alter table database.owner.table_name add column_name char(2) null .....sp_help table_name ---- 显示表已有特征create table table_name (name char(20), age smallint, lname varchar(30))insert into table_name select ......... ----- 实现删除列的方法(创建新表)alter table table_name drop constraint Stockname_default ---- 删除Stockname的default约束***function(/*常用函数*/)***----统计函数----AVG --求平均值COUNT --统计数目MAX --求最大值MIN --求最小值SUM --求和--AVGuse panguselect avg(e_wage) as dept_avgWagefrom employeegroup by dept_id--MAX--求工资最高的员工姓名use panguselect e_namefrom employeewhere e_wage =(select max(e_wage)from employee)--STDEV()--STDEV()函数返回表达式中所有数据的标准差--STDEVP()--STDEVP()函数返回总体标准差--VAR()--VAR()函数返回表达式中所有值的统计变异数--VARP()--VARP()函数返回总体变异数----算术函数----/***三角函数***/SIN(float_expression) --返回以弧度表示的角的正弦COS(float_expression) --返回以弧度表示的角的余弦TAN(float_expression) --返回以弧度表示的角的正切COT(float_expression) --返回以弧度表示的角的余切/***反三角函数***/ASIN(float_expression) --返回正弦是FLOAT 值的以弧度表示的角ACOS(float_expression) --返回余弦是FLOAT 值的以弧度表示的角ATAN(float_expression) --返回正切是FLOAT 值的以弧度表示的角ATAN2(float_expression1,float_expression2)--返回正切是float_expression1 /float_expres-sion2的以弧度表示的角DEGREES(numeric_expression)--把弧度转换为角度返回与表达式相同的数据类型可为--INTEGER/MONEY/REAL/FLOAT 类型RADIANS(numeric_expression) --把角度转换为弧度返回与表达式相同的数据类型可为--INTEGER/MONEY/REAL/FLOAT 类型EXP(float_expression) --返回表达式的指数值LOG(float_expression) --返回表达式的自然对数值LOG10(float_expression)--返回表达式的以10 为底的对数值SQRT(float_expression) --返回表达式的平方根/***取近似值函数***/CEILING(numeric_expression) --返回>=表达式的最小整数返回的数据类型与表达式相同可为--INTEGER/MONEY/REAL/FLOAT 类型FLOOR(numeric_expression) --返回<=表达式的最小整数返回的数据类型与表达式相同可为--INTEGER/MONEY/REAL/FLOAT 类型ROUND(numeric_expression) --返回以integer_expression 为精度的四舍五入值返回的数据--类型与表达式相同可为INTEGER/MONEY/REAL/FLOAT 类型ABS(numeric_expression) --返回表达式的绝对值返回的数据类型与表达式相同可为--INTEGER/MONEY/REAL/FLOAT 类型SIGN(numeric_expression) --测试参数的正负号返回0 零值1 正数或-1 负数返回的数据类型--与表达式相同可为INTEGER/MONEY/REAL/FLOAT 类型PI() --返回值为π即3.1415926535897936RAND([integer_expression]) --用任选的[integer_expression]做种子值得出0-1 间的随机浮点数----字符串函数----ASCII() --函数返回字符表达式最左端字符的ASCII 码值CHAR() --函数用于将ASCII 码转换为字符--如果没有输入0 ~ 255 之间的ASCII 码值CHAR 函数会返回一个NULL 值LOWER() --函数把字符串全部转换为小写UPPER() --函数把字符串全部转换为大写STR() --函数把数值型数据转换为字符型数据LTRIM() --函数把字符串头部的空格去掉RTRIM() --函数把字符串尾部的空格去掉LEFT(),RIGHT(),SUBSTRING() --函数返回部分字符串CHARINDEX(),PATINDEX() --函数返回字符串中某个指定的子串出现的开始位置SOUNDEX() --函数返回一个四位字符码--SOUNDEX函数可用来查找声音相似的字符串但SOUNDEX函数对数字和汉字均只返回0 值DIFFERENCE() --函数返回由SOUNDEX 函数返回的两个字符表达式的值的差异--0 两个SOUNDEX 函数返回值的第一个字符不同--1 两个SOUNDEX 函数返回值的第一个字符相同--2 两个SOUNDEX 函数返回值的第一二个字符相同--3 两个SOUNDEX 函数返回值的第一二三个字符相同--4 两个SOUNDEX 函数返回值完全相同QUOTENAME() --函数返回被特定字符括起来的字符串/*select quotename('abc', '{') quotename('abc')运行结果如下----------------------------------{{abc} [abc]*/REPLICATE() --函数返回一个重复character_expression 指定次数的字符串/*select replicate('abc', 3) replicate( 'abc', -2)运行结果如下----------- -----------abcabcabc NULL*/REVERSE() --函数将指定的字符串的字符排列顺序颠倒REPLACE() --函数返回被替换了指定子串的字符串/*select replace('abc123g', '123', 'def')运行结果如下----------- -----------abcdefg*/SPACE() --函数返回一个有指定长度的空白字符串STUFF() --函数用另一子串替换字符串指定位置长度的子串----数据类型转换函数----CAST() 函数语法如下CAST() ( AS [ length ])CONVERT() 函数语法如下CONVERT() ([ length ], [, style])select cast(100+99 as char) convert(varchar(12), getdate())运行结果如下------------------------------ ------------199 Jan 15 2000----日期函数----DAY() --函数返回date_expression 中的日期值MONTH() --函数返回date_expression 中的月份值YEAR() --函数返回date_expression 中的年份值DATEADD( , ,)--函数返回指定日期date 加上指定的额外日期间隔number 产生的新日期DATEDIFF( , ,)--函数返回两个指定日期在datepart 方面的不同之处DATENAME( , ) --函数以字符串的形式返回日期的指定部分DATEPART( , ) --函数以整数值的形式返回日期的指定部分GETDATE() --函数以DATETIME 的缺省格式返回系统当前的日期和时间----系统函数----APP_NAME() --函数返回当前执行的应用程序的名称COALESCE() --函数返回众多表达式中第一个非NULL 表达式的值COL_LENGTH(<'table_name'>, <'column_name'>) --函数返回表中指定字段的长度值COL_NAME(, ) --函数返回表中指定字段的名称即列名DATALENGTH() --函数返回数据表达式的数据的实际长度DB_ID(['database_name']) --函数返回数据库的编号DB_NAME(database_id) --函数返回数据库的名称HOST_ID() --函数返回服务器端计算机的名称HOST_NAME() --函数返回服务器端计算机的名称IDENTITY([, seed increment]) [AS column_name])--IDENTITY() 函数只在SELECT INTO 语句中使用用于插入一个identity column列到新表中/*select identity(int, 1, 1) as column_nameinto newtablefrom oldtable*/ISDATE() --函数判断所给定的表达式是否为合理日期ISNULL(, ) --函数将表达式中的NULL 值用指定值替换ISNUMERIC() --函数判断所给定的表达式是否为合理的数值NEWID() --函数返回一个UNIQUEIDENTIFIER 类型的数值NULLIF(, )--NULLIF 函数在expression1 与expression2 相等时返回NULL 值若不相等时则返回expression1 的值??。

oracle常用语法

oracle常用语法

oracle常⽤语法别名别名中不能出现中⽂括号()不能使⽤全⾓符号coalescecoalesce(参数列表):返回参数列表中第⼀个⾮空参数,最后⼀个参数通常为常量distinct去重nvl作⽤:判断某个值是否为空值,若不为空值则输出,若为空值,返回指定值。

专详细解释如下:1、nvl()函数的格属式如下:NVL(expr1,expr2);2、含义是:如果oracle第⼀个参数为空那么显⽰第⼆个参数的值,如果第⼀个参数的值不为空,则显⽰第⼀个参数本来的值。

3、例:select name,NVL(name,-1) from user;运⾏后,结果返回两列数值,若name为空,则返回-1,若name不为空值,则返回其⾃⾝。

roundround函数⽤于数据的四舍五⼊1、round(x,d) ,x指要处理的数,d是指保留⼏位⼩数这⾥有个值得注意的地⽅是,d可以是负数,这时是指定⼩数点左边的d位整数位为0,同时⼩数位均为0;2、round(x) ,其实就是round(x,0),也就是默认d为0;union与union allunion:去重复,排序union all:不重复也不排序.(推荐)intersect 与 minusintersect 就是交集minus 就是差集交集就是两个结果集中都有的元素⽐如 select uid from tb1intersectselect uid from tb2那么既存在zhitb1 ⼜存在tb2中相同的UID 就会查dao出来差集:select uid from tb1minusselect uid from tb2存在于tb1 但不存在与tb2中的uid 会被查出表的复制如果需要对表中的数据进⾏删除和修改,建议通过复制表中的数据来对数据进⾏操作create table 表名 as 查询语句;--将emp表中的数据复制到t_emp表中create table t_empasselect * from emp;--只需要表的结构--将emp表的结构复制到t_emp表中create table t_empasselect * from empwhere 1=0;/*提供⼀个否定条件*/--只复制⼀部分数据--将emp表中部门10的员⼯的数据复制到t_emp表中create table t_empasselect * from empwhere deptno=10;--将emp表中的员⼯姓名,⼯资,年薪保存到t_emp表中create table t_empasselect ename,sal,sal*12 year_sal /*如果字段中出现函数或者计算需要提供别名*/ from emp;--统计emp表中部门的⼈数,将部门编码和⼈数保存到t_emp表中create table t_emp(did,ecount)asselect deptno,count(ename)from empgroup by deptno;注意:表的复制只会复制表中的数据,不会复制表中的约束伪列rowid,rownumselect rowid from dual;rowid:是⼀个伪列,Oracle独有的.每⼀条记录的rowid 的记录是唯⼀的sign⽐较⼤⼩与0进⾏⽐较,判断是不是正数,⼤于0显⽰1 ,⼩于0显⽰-1 ,等于0显⽰0 select sign( 100 ),sign(- 100 ),sign( 0 ) from dual;如何进⾏SQL语句的优化在select语句中避免使⽤*减少数据库的访问次数删除重复记录尽量多使⽤commit使⽤where替换having多使⽤内部函数提⾼sql语句效率多使⽤表的别名使⽤exists替换in,使⽤not exists替换notin尽量使⽤索引类进⾏查询sql语句尽量⼤写.oracle会⾃动转换成⼤写避免在索引列上进⾏计算避免在索引类上使⽤not,oracle遇到not就使⽤全表扫描可以使⽤>=替换>使⽤in替换or尽量使⽤where替换groupby避免使⽤消耗资源的操作.如union⼦查询注意事项1.⼦查询需要定义在括号当中2.⼦查询通常定义在条件判断的右边3.在⼦查询中不建议使⽤ order by⼦查询中多⾏⽐较符in :等于列表中的任何⼀个any:和⼦查询结果中的任意⼀个值进⾏⽐较all:和⼦查询结果中的所有值进⾏⽐较oracle 与 mysql的区别(1) 对事务的提交MySQL默认是⾃动提交,⽽Oracle默认不⾃动提交,需要⽤户⼿动提交,需要在写commit;指令或者点击commit按钮(2) 分页查询MySQL是直接在SQL语句中写"select... from ...where...limit x, y",有limit就可以实现分页;⽽Oracle则是需要⽤到伪列ROWNUM和嵌套查询(3) 事务隔离级别MySQL是read commited的隔离级别,⽽Oracle是repeatable read的隔离级别,同时⼆者都⽀持serializable串⾏化事务隔离级别,可以实现最⾼级别的读⼀致性。

oracle 的语法

oracle 的语法

oracle 的语法Oracle的语法是一种用于访问和管理Oracle数据库的编程语言。

它提供了一种结构化的方式来存储、操作和检索数据,并允许用户创建和管理数据库对象。

本文将介绍一些常用的Oracle语法,并解释其用法和含义。

一、DDL语句DDL(Data Definition Language)语句用于定义和管理数据库对象,例如表、视图、索引等。

常用的DDL语句包括CREATE、ALTER和DROP。

1. CREATE TABLECREATE TABLE语句用于创建表。

它指定了表的名称和列的定义。

列的定义包括名称、数据类型和约束条件等。

例如:CREATE TABLE employees (employee_id NUMBER(10),first_name VARCHAR2(50),last_name VARCHAR2(50),hire_date DATE,salary NUMBER(10,2));2. ALTER TABLEALTER TABLE语句用于修改表的结构。

它可以添加、修改或删除列,添加或删除约束等。

例如:ALTER TABLE employeesADD (department_id NUMBER(10));3. DROP TABLEDROP TABLE语句用于删除表。

它会删除表的定义和所有相关的数据。

例如:DROP TABLE employees;二、DML语句DML(Data Manipulation Language)语句用于操作数据库中的数据。

常用的DML语句包括SELECT、INSERT、UPDATE和DELETE。

1. SELECTSELECT语句用于查询数据库中的数据。

它可以指定要查询的列、表和条件等。

例如:SELECT employee_id, first_name, last_nameFROM employeesWHERE department_id = 100;2. INSERTINSERT语句用于向表中插入新的数据。

oracle中if语句的用法

oracle中if语句的用法

oracle中if语句的用法Oracle是一种数据库管理系统,提供了丰富的语法和功能。

其中if语句是一种常用的控制流语句,可以根据条件进行分支处理。

本文将详细介绍Oracle中if语句的用法,包括语法、示例以及注意事项等方面。

1. if语句的基本语法Oracle中的if语句与其他编程语言中的if语句类似,基本语法为:IF condition THENstatements;ELSEstatements;END IF;其中,condition表示取值为TRUE或FALSE的布尔表达式,如果condition为TRUE,则执行THEN语句块;否则执行ELSE语句块。

例如,下面的代码示例中,如果num的值大于10,则输出"num is greater than 10",否则输出"num is less than or equal to 10"。

DECLAREnum NUMBER(4):= 20;BEGINIF num > 10 THENDBMS_OUTPUT.PUT_LINE('num is greater than 10');ELSEDBMS_OUTPUT.PUT_LINE('num is less than or equal to 10');END IF;END;2. if语句中的逻辑运算符在if语句中,可以使用逻辑运算符(AND、OR、NOT)来处理多个条件。

例如,下面的代码示例中,判断num的值是否在10到20之间。

DECLAREnum NUMBER(4):= 15;BEGINIF num >= 10 AND num <= 20 THENDBMS_OUTPUT.PUT_LINE('num is between 10 and 20');ELSEDBMS_OUTPUT.PUT_LINE('num is not between 10 and 20');END IF;END;3. if语句中的比较运算符在if语句中,可以使用比较运算符(=、!=、<、>、<=、>=)来比较变量的值。

oracle语句大全及用法

oracle语句大全及用法

oracle语句大全及用法Oracle语句是Oracle数据库中用于管理和操作数据的SQL语句。

以下是一些常用的Oracle语句及其用法:1. 数据定义语句(DDL)CREATE DATABASE:用于创建新的数据库。

CREATE TABLE:用于创建新的表。

语法如下:sql`CREATE TABLE table_name (column1 datatype1, column2 datatype2, ...);`ALTER TABLE:用于修改现有的表结构,如添加、删除或修改列。

DROP TABLE:用于删除现有的表。

CREATE INDEX:用于在表上创建索引,以提高查询性能。

2. 数据操纵语句(DML)SELECT:用于从表中查询数据。

语法如下:sql`SELECT column1, column2, ... FROM table_name;`INSERT INTO:用于向表中插入新的数据行。

语法如下:sql`INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...);`UPDATE:用于修改表中的现有数据。

DELETE:用于从表中删除数据。

3. 数据控制语句(DCL)GRANT:用于授予用户或角色对数据库对象的访问权限。

REVOKE:用于撤销用户或角色对数据库对象的访问权限。

4. 事务控制语句(TCL)COMMIT:用于提交当前事务,使所做的更改永久生效。

ROLLBACK:用于撤销当前事务,恢复到事务开始前的状态。

SAVEPOINT:用于在事务中设置保存点,以便在之后的某个时刻可以回滚到该点。

5. 其他常用语句DECLARE:用于声明变量或常量,并为其分配数据类型和初始值。

BEGIN ... END:用于定义PL/SQL代码块的开始和结束。

IF ... THEN ... ELSE:用于条件判断,根据条件执行不同的操作。

ORACLE常用SQL语句大全

ORACLE常用SQL语句大全

ORACLE常用SQL语句大全一、基础1、说明:创建数据库CREATE DATABASE database-name2、说明:删除数据库drop database dbname3、说明:备份sql server--- 创建备份数据的 deviceUSE masterEXEC sp_addumpdevice 'disk', 'testBack', 'c:/mssql7backup/MyNwind_1.dat'--- 开始备份BACKUP DATABASE pubs TO testBack4、说明:创建新表create table tabname(col1 type1 [not null] [primary key],col2 type2 [not nul l],..)根据已有的表创建新表:A:select * into table_new from table_old (使用旧表创建新表)B:create table tab_new as select col1,col2… from tab_old definition only<仅适用于Oracle>5、说明:删除表drop table tablename6、说明:增加一个列,删除一个列A:alter table tabname add column col typeB:alter table tabname drop column colname注:DB2DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。

7、添加主键:Alter table tabname add primary key(col)删除主键:Alter table tabname drop primary key(col)8、创建索引:create [unique] index idxname on tabname(col….)删除索引:drop index idxname注:索引是不可更改的,想更改必须删除重新建。

oracle+常用SQL语法手册

oracle+常用SQL语法手册

oracle 常用SQL语法手册Select用途:从指定表中取出指定的列的数据解释:从数据库中选取资料列,并允许从一或多个资料表中,选取一或多个资料列或资料行。

SELECT 陈述式的完整语法相当复杂,但主要子句可摘要为:SELECT select_list[ INTO new_table ]FROM table_source[ WHERE search_condition ][ GROUP BY group_by_expression ][ HAVING search_condition ][ ORDER BY order_expression [ ASC | DESC ] ]例:“Persons” 表中的数据有选出字段名” LastName”、” FirstName” 的数据返回结果:选出所有字段的数据返回结果:下面的操作符能被使用在WHERE中:=,<>,>,<,>=,<=,BETWEEN,LIKE注意:在某些SQL的版本中不等号< >能被写作为!= 解释:SELECT语句返回WHERE子句中条件为true的数据例:从”Persons”表中选出生活在” Sandnes” 的人"Persons" 表中的数据有:返回结果:用AND运算子来查找"Persons" 表中FirstName为”Tove”而且LastName 为” Svendson”的数据返回结果:用OR运算子来查找"Persons" 表中FirstName为”Tove”或者LastName为” Svendson”的数据返回结果:你也能结合AND和OR (使用括号形成复杂的表达式),如:返回结果:Between…And用途:指定需返回数据的范围例:“Persons”表中的原始数据用BETWEEN…AND返回LastName为从”Hansen”到”Pettersen”的数据:返回结果:为了显示指定范围之外的数据,也可以用NOT操作符:返回结果:Distinct用途: DISTINCT关键字被用作返回唯一的值解释:当column-name(s)中存在重复的值时,返回结果仅留下一个例:“Orders”表中的原始数据用DISTINCT关键字返回Company字段中唯一的值:返回结果:Order by用途:指定结果集的排序解释:指定结果集的排序,可以按照ASC(递增方式排序,从最低值到最高值)或者DESC(递减方式排序,从最高值到最低值)的方式进行排序,默认的方式是ASC 例:“Orders”表中的原始数据:按照Company字段的升序方式返回结果集:返回结果:按照Company字段的降序方式返回结果集:返回结果:例:“Sales”表中的原始数据:按照Company字段进行分组,求出每个Company的Amout的合计:返回结果:Having用途:指定群组或汇总的搜寻条件。

oracle语法大全有注解

oracle语法大全有注解

第一部分基本语法//拼接表字段select id || 'is' || name from adminselect * from emp where ename like'%s%';//模糊查询select * from emp where mgr is null ; //查询表列为空的to_date('2011-12-12','yyyy-mm-dd') //插入时间格式 to_date()//给表字段取别名select id as这是ID , name as "这是名字" from admin//清除重复出现的值select distinct id,name from admin//用户定义降序select * from admin order by id desc //asc升序 //desc降序//查询当前时间select sysdate from admin第二部分字符函数//截取字符串select substr (name,1,1) as用户名from admin //(1,1)表示第一个开始,和第一个数//取出字段的长度select length(name) from admin//取出字符串为’张’当前所在的位置为几,找不到则为0 …区分大小写select name ,instr(name,'张') from admin// lpad左侧补全, rpad右侧补全select lpad(name,10, '-') from adminselect rpad(name,10, '-') from admin//给字段截取前后空格select trim(name) from admin//给字段为张的全部替换为zhangselect name ,replace(name,'张','zhang') from admin第四部分表达式语法//case表达式语句给用户区别名用法,相当与if elseselect id,name,case id when1then'优'when2then'良'when3then'差'else'未知'end部门from admin//decode()函数给用户区别名用法,与上面意思一个样select id,name,decode(id,1,'优',2,'良',3,'差','未知') as成绩from admin//函数嵌套,单行函数可以嵌套使用,嵌套层次无限制select id,name,initcap(trim(rpad(name,10,'-'))) from admin//函数里面可以是字段名,也可以是表达式,日期类型select avg(id) as平均数,max(id) as最大数,min(id) as最小数,sum(id) as总和from admin//查询总数,不能有重复和不能为空的id总数select count(distinct(id)) as总数from admin//求总和,如果id字段为空,则设置字段为0. 然后用总和除以总数最后得出结果select sum(nvl(id,0)) / count(id) as总和除以总数from admin//查询id为1的数量有多少个 , 根据平均分排序select count(id) as记录数from admin where id =1group by id having id=1 order by avg(id)//查询id大于3 having筛选 id<5 之间的数总数select count(id) as记录数from admin where id > 3group by id having id < 5第六部分多表连接//emp表和dep表结构--emp表,create table emp(empNo number,eName varchar2(20), sal number, deptNo number);insert into emp(empNo,eName,sal,deptno) values(7369,'smith',800,20);insert into emp values(7499,'allen',1600,30);insert into emp values(7521,'ward',1250,30);insert into emp values(7566,'jones',2975,20);insert into emp values(7654,'martin',1250,30);insert into emp values(7902,'ford',300,20);insert into emp values(7934,'miller',1300,10);drop table empselect * from emp--dep表create table dep(deptNo number,dName varchar2(20),loc varchar2(20));insert into dep values(10,'accounting','new york')insert into dep values(20,'research','dallas')insert into dep values(30,'sales','chicago')insert into dep values(40,'operations','boston')insert into dep values(50,'advertisement','beijing')drop table depselect * from dep// 根据deptNo编号对应查找出相应的数据select emp.empno,emp.ename,emp.sal,emp.deptno,dep.deptno,dep.dname,dep.loc from emp,depwhere emp.deptno = dep.deptno;// Join字句连接的方法查询两张表数据, using(deptNo)参照列进行连接// right left 左右连接全外连接 full outerselect emp.empno,emp.ename,emp.sal,deptno,deptno,dep.dname,dep.locfrom emp join depusing(deptno);// on字句连接的方法查询两张表数据,On( emp.deptno = dep.deptno and sal > 1000);// 根据deptNo编号对应查找出相应的数据根据sal和loc进行筛选select e.empno,ename,sal,d.deptno,d.deptno,dname,locfrom emp e,dep dwhere e.deptno = d.deptno and ( e.sal > 1000or d.loc='chicago' );// e和d对应 d和l对应的数据进行三表查询,,select e.empno,ename,sal,d.deptno,d.deptno,dname,loc,l.idfrom emp e,dep d,loc lwhere e.deptno = d.deptno and l.id=e.id// Join 进行三表查询,,select e.empno,ename,sal,d.deptno,d.deptno,dname,loc,l.idfrom emp join dep using(deptNo)natural join locatins; //也可以继续 join 表名 using(关联列)第七部分子查询// 简单的子查询语法,,如果有多个返回值select * from emp where sal > ( select sal from emp where sal = 800 )+ ( select sal from emp where sal = 300 )//使用 in等于列表中任何一个 not in 不在这里面的所有列表select * from emp where sal not in (select avg(sal) from emp group by deptno)//使用 any 和子查询返回的任意一个值比较查最小select * from emp where sal > any (select avg(sal) from emp group by deptno)//使用 all和子查询返回的所有值比较查最大select * from emp where sal > all (select avg(sal) from emp group by deptno)//返回前面五条最高记录, rownum相当与 sqlserver里面top rownum也可当虚拟主键select * from (select * from emp order by sal desc) where rownum <=5//分页子查询语句,, rownum定义的虚拟主键,别名myno where 进行筛选select * from (select rownum myno , a.* from (select * from emp order by sal desc) a ) where myno > 4and myno <=7//希望员工scott的岗位,工资,补助与smith员工一样Update emp set (job,sal,comm) = (select job,sal,comm from emp where = 'smith') where ename = 'scott';第八部分DML与事务控制//事物必须满足ACID属性,→原子性(Atomicity):有一个地方出错,前面成功的也撤销..应是一个整体..必须恢复以前数据.要么全部成功,要么全部失败..→一致性(Consistency):数据必须处于一致性,如B级工资300升到500级别也从B升到A,但是数据保持不一致,只上调了级别没上调工资..→隔离性(Isolation):多个事物多个用户操作一个数据, 如修改字段,其他事物不受影响..直到事物都成功了, 要么看到的数据之前和之后的状态中间的被隔离开→持久性(Durability):事物结束后永久保存在数据库中..不能撤销//insert into 插入表中所有的数据Insert into admin(id,name) select id,name from admin;insert into admin values(6,'老百');回滚点savepoint p1;insert into admin values(6,'老千');回滚 rollback p1;提交commit;set autocommit on;set autocommit off;第九部分数据库对象//创建 test 表create table test(id number(10),name varchar2(20),hiredate date default sysdate,salary number(8,2) default0);// 将test 表的字段数据注入到test1里面来create table test1(用户id,用户名字)as select id,name from test// 给test表增加mm gg 两个字段默认值是,,...alter table testadd(gg varchar2(20) default'你是男人',mm varchar2(20) default'你是女人')// 使用modify给字句修改现有字段,包括字段的数据类型,大小和默认值alter table testmodify(gg varchar2(20) default'你是猪',mm varchar2(20) default'你真笨');// 使用drop删除表中字段行 drop table 表名即可删除表alter table testdrop(gg,mm);// 使用truncate清空表所有的记录,不能进行条件的删除,表结构还在create table test1 as (select name,hiredate,salary from test) truncate table test1// 使用rename讲表test1名字替换成testrename test1 to test// 查看当前用户拥有的所有表的名字select * from user_tables;// 查询当前用户可访问的所有表的名字select * from all_tables;// 查询当前用户拥有所有对象的类型select distinct object_type from user_objects;// 查询用户拥有所有对象的类型select * from dba_tables;第十部分表约束create table mg(id number(3) primary key, //主键约束gg number not null unique, //唯一约束mm number constraint mg_mm not null, //非空约束constraint mg_id_fk foreign key(id) references admin(id); //外键约束);//给admin表增加 check约束create table admin(id number(3) check(id>=5and id<=10),name varchar2(20) check(length(name)>4and length(name) <=20))//建好表之后在添加约束和删除约束create table student(sid number(3),sname varchar2(20),saddress varchar2(20),tid number(3))alter table studentadd constraint studetn_pk_sid primary key(sid);alter table studentadd constraint studetn_sname check(length(sname)>4);alter table studentadd constraint studetn_saddress saddress default'湖南岳阳';alter table studentadd constraint studetn_fk_tid foreign key(tid) references tracher(tid);alter table studentdrop constraint studetn_pk_sidcreate table tracher(tid number(3))alter table tracheradd constraint tracher_pk_id primary key(tid);第十一部分视图,索引//添加简单的视图create or replace view v1as select * from empdesc v1drop view v1;//添加简单的索引create index myindex on emp(ename);drop index myindex第十二部分基本数据命令Conn scott/sa //切换用户账户Show user //查询属于那个用户Desc //查看表结构Disconnect //断开数据库连接Password //修改用户密码Exit //断开,退出窗口Start 加路径. //要导入sql文件Edit 加路径 //需要打开的修改的文件Spool 加路径 spool off保存 //把结果保存到文件里面去Setpagesize //一页显示多少条数据Create user (admin)用户名 indentified by (sa)密码 //创建用户和密码Drop user (admin)用户名 //删除用户Grant connect to (admin)用户名 //给用户授予连接权限用户才能进行登录Grant resource to (admin)用户名 //给有用授予创建表的权限才能创建表Grant select on emp to (admin)用户名 //用其他用户登录给admin表授予查询emp表权限Grant update on emp to (admin)用户名 //给用户授予改emp表的权限Grant all on emp to (admin)用户名 //给用户授予增删改emp表的权限Revoke select on emp from admin //收回权限使用 revoke 上面都可收回Grant select on emp to admin with grant option //给admin授予可以给别人授予这张表查询权限Revoke select on emp to admin with grant option //撤销admin授予可以给别人授予这张表查询权限Alter user admin(用户名) account unlock; //给用户解锁第十三部分sequence自增Create sequence myseq //自增Drop sequence myseq //删除自增Insert into test values(myseq.nextval);Insert into test values(myseq.currval)/*创建序列*/ create sequence s_id increment by 1 start with 1 nomaxvalue nocycle; /*创建触发器*/ create or replace trigger myTrigger before insert on myTable referencing old as old_value new as new_value for each row beginnew_erid= s_id.nextval; end;end;oracle都用sequence可以直接用native,hibernate会根据底层数据库自行判断采用sequence。

oracle常用语法

oracle常用语法

oracle常用语法Oracle是一种强大的关系型数据库管理系统,广泛应用于企业级应用程序中。

在使用Oracle时,熟悉其常用语法是非常重要的。

以下是关于Oracle常用语法的一些简介。

1. 创建表在Oracle中,可以使用CREATE TABLE语句创建表。

该语句需要指定表的名称以及列的名称和数据类型。

例如:CREATE TABLE customers (id NUMBER,name VARCHAR2(50),address VARCHAR2(100));2. 插入数据可以使用INSERT INTO语句向表中插入数据。

该语句需要指定表的名称以及要插入的值。

例如:INSERT INTO customers (id, name, address)VALUES (1, 'John Doe', '123 Main St');3. 更新数据可以使用UPDATE语句更新表中的数据。

该语句需要指定要更新的表、要更新的列和新的值。

例如:UPDATE customersSET name = 'Jane Doe'WHERE id = 1;4. 删除数据可以使用DELETE语句从表中删除数据。

该语句需要指定要删除的表以及要删除的行。

例如:DELETE FROM customersWHERE id = 1;5. 查询数据可以使用SELECT语句从表中检索数据。

该语句需要指定要检索的列以及要检索的表。

例如:SELECT name, addressFROM customers;以上是关于Oracle常用语法的简介。

熟悉这些语法可以帮助您更轻松地使用Oracle进行数据库管理。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
--1.SQL中GROUP BY的用法
GROUP BY 是分组查询, 一般 GROUP BY是和 聚合函数(SUM)配合使用
group by 有一个原则,就是 select 后面的所有列中,没有使用聚合函数的列,必须出现在 group by 后面。
--3.运算符
=(等号) 等于 (A1=B1)
and c.owner = cc.owner and c.constraint_name = cc.constraint_name
order by cc.position;
--15.存储函数和过程
SQL>select object_name,status from user_objects where object_type='FUNCTION';
SQL>select object_name,status from user_objects where object_type='PROCEDURE';
查看函数和过程的源代码
SQL>select text from all_source where owner=user and name=upper('&plsql_name');
查看创建视图的select语句
SQL>set view_name,text_length from user_views;
SQL>set long 2000; 说明:可以根据视图的text_length值设定set long 的大小
--11.查询序列号
查看序列号,last_number是当前值
SQL>select * from user_sequences;
--12.查看视图
查看视图的名称
SQL>select view_name from user_views;
SQL>select text from user_views where view_name=upper('&view_name');
--13.查询同义词
查看同义词的名称
SQL>select * from user_synonyms;
>(大于号) 大于 (A1>B1)
<(小于号) 小于 (A1<B1)
>=(大于等于号) 大于或等于 (A1>=B1)
<=(小于等于号) 小于或等于 (A1<=B1)
<>(不等号) 不相等 (A1<>B1)
--4.nvl
nvl(字段,0)是一个空值判断的函数,相当于if...else...,如果字段为null,则取后面的值0,不为空,则取字段的值。
--16.查看数据库版本
Select version FROM Product_component_version
Where SUBSTR(PRODUCT,1,6)='Oracle';
--17.查看数据库的创建日期和归档方式
INSERT 语句插入这个字段值为: 序列号的名称.NEXTVAL
2.DELETE (删除数据表里记录的语句)
DELETE FROM表名 WHERE 条件;
注意:删除记录并不能释放ORACLE里被占用的数据块表空间. 它只把那些被删除的数据块标成unused.
字符串类型的字段值超过定义的长度会出错, 最好在插入前进行长度校验.
日期字段的字段值可以用当前数据库的系统时间SYSDATE, 精确到秒
或者用字符串转换成日期型函数TO_DATE(‘2001-08-01’,’YYYY-MM-DD’)
TO_DATE()还有很多种日期格式, 可以参看ORACLE DOC.
年-月-日 小时:分钟:秒 的格式YYYY-MM-DD HH24:MI:SS
INSERT时最大可操作的字符串长度小于等于4000个单字节, 如果要插入更长的字符串, 请考虑字段用CLOB类型,
方法借用ORACLE里自带的DBMS_LOB程包.
INSERT时如果要用到从1开始自动增长的序列号, 应该先建立一个序列号
--5.筛选日期格式
字段 > to_date ('2016-12-12 08:00:00','yyyy-mm-dd hh24:mi:ss')
--6.order by用法
默认升序排列,后加desc为降序排列。
--7.常用运算函数
ORDER BY – 按照指定列排序返回结果的子句
SQL>select c.constraint_name,c.constraint_type,cc.column_name
from user_constraints c,user_cons_columns cc
where c.owner = upper('&table_owner') and c.table_name = upper('&table_name')
DISTINCT – 只返回结果集合内唯一行的关键词
COUNT - 返回匹配查询的数据行总数数值的函数
AVG – 该函数返回指定列的平均值
SUM –该函数把指定的列中的数字加起来
MIN – 该函数返回列中最小的非NULL值
MAX –该函数返回列中的最大值
where instr(object_name,'LOG')>0;
查看某表的创建时间
SQL>select object_name,created from user_objects where object_name=upper('&table_name');
如果要停某个连接用
SQL> alter system kill session 'sid,serial#'
--19.数据控制语句 (DML) 部分
1.INSERT (往数据表里插入记录的语句)
INSERT INTO 表名(字段名1, 字段名2, ……) VALUES ( 值1, 值2, ……);
如果确实要删除一个大表里的全部记录, 可以用 TRUNCATE 命令, 它可以释放占用的数据块表空间
TRUNCATE TABLE 表名;
此操作不可回退.
3.UPDATE (修改数据表里记录的语句)
UPDATE表名 SET 字段名1=值1, 字段名2=值2, …… WHERE 条件;
SQL>select index_name,index_type,table_name from user_indexes order by table_name;
查看索引被索引的字段
SQL>select * from user_ind_columns where index_name=upper('&index_name');
Select Created, Log_Mode, Log_Mode From V$Database;
--18.ORACLE用户连接的管理
用系统管理员,查看当前数据库有几个用户连接:
SQL> select username,sid,serial# from v$session;
查看索引的大小
SQL>select sum(bytes)/(1024*1024) as "size(M)" from user_segments
where segment_name=upper('&index_name');
查看某表的大小
SQL>select sum(bytes)/(1024*1024) as "size(M)" from user_segments
where segment_name=upper('&table_name');
INSERT INTO 表名(字段名1, 字段名2, ……) SELECT (字段名1, 字段名2, ……) FROM 另外的表名;
字符串类型的字段值必须用单引号括起来, 例如: ’GOOD DAY’
如果字段值里包含单引号’ 需要进行字符串转换, 我们把它替换成两个单引号''.
CREATE SEQUENCE 序列号的名称 (最好是表名+序列号标记) INCREMENT BY 1 START WITH 1
MAXVALUE 99999 CYCLE NOCACHE;
其中最大的值按字段的长度来定, 如果定义的自动增长的序列号 NUMBER(6) , 最大值为999999
SQL>select * from user_role_privs;
查看当前用户的系统权限和表级权限
SQL>select * from user_sys_privs;
SQL>select * from user_tab_privs;
如果修改的值N没有赋值或定义时, 将把原来的记录内容清为NULL, 最好在修改前进行非空校验;
GROUP BY – 按列汇集查询函数结果的子句
--8.查询oracle用户相关信息
用户
查看当前用户的缺省表空间
SQL>select username,default_tablespace from user_users;
查看当前用户的角色
--9.查询表
查看用户下所有的表
SQL>select * from user_tables;
相关文档
最新文档