ORACLE 常用的SQL语法和数据对象

合集下载

oracle11g的基本SQL语句和函数

oracle11g的基本SQL语句和函数

GROUP BY
首先创建表
create table 成绩(sno number, km varchar2(13), score number); Insert into 成绩 values(1,‟语文’,60); Insert into 成绩 values(1,‟数学’,60); Insert into 成绩 values(1,‟英语’,60); Insert into 成绩 values(2,‟语文’,70); Insert into 成绩 values(2,‟数学’,70); Insert into 成绩 values(3,‟英语’,89); commit;
插入空值
Insert into student values(3,null, to_date(„19980311‟,‟yyyy-MMdd‟)); hh mm ss
insert into student(sno,birthday) values( 4,to_date('19880601','yyyy-MM-dd'));
月、日,小时、分钟、秒 数值数据类型的声明语法: 主要的日期时间类型有:
NUMBER [( p[, s])] DATE - 存储日期和时间部分,精确到整个的秒 P表示精度,S表示小数点的位数 TIMESTAMP - 存储日期、时间和时区信息,秒值精 确到小数点后6位 Select sysdate from dual; Select to_char(sysdate,‟yyyymmdd hh24:mi:ss‟) from dual; Select to_char(sysytimestamp,‟yyyymmdd hh24:mi:ssxff6‟) from dual;

oracle的insert语句

oracle的insert语句

oracle的insert语句Oracle是一种关系型数据库管理系统,它支持SQL语言,可以使用INSERT语句将数据插入到表中。

INSERT语句是SQL语言中最常用的语句之一,它用于将数据插入到表中。

在本文中,我们将介绍Oracle中的INSERT语句,并提供一些示例。

1. 插入单行数据INSERT INTO table_name (column1, column2, column3, ...) VALUES (value1, value2, value3, ...);这是最基本的INSERT语句,它用于将一行数据插入到表中。

在这个语句中,我们需要指定表名和列名,然后提供要插入的值。

例如,我们有一个名为“employees”的表,它有三个列:id、name和age。

我们可以使用以下语句将一行数据插入到表中:INSERT INTO employees (id, name, age) VALUES (1, 'John', 30);这将在“employees”表中插入一行数据,其中id为1,name为“John”,age为30。

2. 插入多行数据INSERT INTO table_name (column1, column2, column3, ...) VALUES (value1, value2, value3, ...), (value1, value2,value3, ...), ...;如果我们需要将多行数据插入到表中,我们可以使用INSERT语句的扩展语法。

在这个语法中,我们可以在一个INSERT语句中插入多个值。

例如,我们有一个名为“employees”的表,它有三个列:id、name和age。

我们可以使用以下语句将多行数据插入到表中:INSERT INTO employees (id, name, age) VALUES (1, 'John', 30), (2, 'Mary', 25), (3, 'Tom', 35);这将在“employees”表中插入三行数据,分别为id为1、name 为“John”、age为30;id为2、name为“Mary”、age为25;id为3、name为“Tom”、age为35。

oracle数据库入门教程

oracle数据库入门教程

oracle数据库入门教程Oracle数据库入门教程Oracle数据库是当今世界上最受欢迎和广泛使用的关系数据库管理系统之一。

它提供了高度可靠性、可扩展性和安全性,使得它成为许多企业和组织的首选数据库解决方案。

本教程将介绍如何入门使用Oracle数据库,从安装到基本的数据操作和查询。

第一部分:安装和配置Oracle数据库1. 下载和安装Oracle数据库首先,您需要从Oracle官方网站上下载并安装Oracle数据库软件。

根据您的操作系统选择合适的版本,并按照官方安装指南进行操作。

2. 配置Oracle数据库安装完成后,您需要进行一些基本的配置。

这包括设置管理员密码、配置监听器和网络连接,以及创建初始化参数文件。

详细的配置步骤可以在官方文档中找到。

3. 启动和停止Oracle数据库一旦配置完成,您可以使用Oracle提供的工具启动和停止数据库。

通常,您需要先启动监听器,然后启动数据库实例。

同样,停止的顺序也是先停止数据库实例,再停止监听器。

第二部分:Oracle数据库基础知识1. 数据库和实例在Oracle概念中,数据库是物理文件的集合,用于存储数据。

而实例则是数据库的运行环境,包括内存结构和进程。

一个数据库可以对应多个实例,每个实例可以在不同的计算机上运行。

2. 数据表和字段在Oracle数据库中,数据以表的形式组织。

表由列(字段)和行组成,每个列定义了一种数据类型。

您可以使用SQL语句或图形界面工具创建和管理表,为每个字段指定适当的数据类型、长度和约束。

3. 数据类型Oracle数据库支持多种数据类型,包括数值、字符、日期、布尔、LOB(二进制大对象)等。

了解每种数据类型的特性和用法对于有效存储和检索数据至关重要。

第三部分:Oracle SQLSQL是结构化查询语言(Structured Query Language)的缩写,是Oracle数据库的标准查询语言。

它允许用户执行各种操作,如插入、更新和删除数据,以及查询和排序数据。

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常用SQL命令

Oracle常用SQL命令

Oracle常⽤SQL命令创建表空间1.创建默认表空间WLP_DATCREATE TABLESPACE "MYSPACE" DATAFILE'D:\oracle\oradata\orcl\data/WLP_DAT.dbf' SIZE 32M REUSE AUTOEXTEND ON NEXT 32MLOGGING EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO;2.创建临时表空间WLP_TEMP(⽤于缓存,可以不建)ALTER TABLESPACE "TEMP" ADD TEMPFILE'D:\oracle\oradata\orcl\data/WLP_TEMP.dbf' SIZE 32m REUSE autoextend on next 32m;创建⽤户并授权1CREATE USER "WLPING" PROFILE "DEFAULT"2 IDENTIFIED BY "123456"3DEFAULT TABLESPACE "MYSPACE" //默认指定表空间4TEMPORARY TABLESPACE "TEMP" //指定缓存表空间5 ACCOUNT UNLOCK; //⽤户⾮锁定67GRANT EXECUTE ON dbms_comparison TO "WLPING";8GRANT UNLIMITED TABLESPACE TO "XIR_MD";9GRANT "CONNECT" TO "XIR_MD";10GRANT "RESOURCE" TO "XIR_MD";1112-- GRANT DBA TO XIR_MD;PROFILE:Oracle系统中的profile可以⽤来对⽤户所能使⽤的数据库资源进⾏限制,使⽤Create Profile命令创建⼀个Profile,⽤它来实现对数据库资源的限制使⽤,如果把该profile分配给⽤户,则该⽤户所能使⽤的数据库资源都在该profile的限制之内。

oceanbase oracle语法

oceanbase oracle语法

OceanBase Oracle语法简介OceanBase是一个分布式关系型数据库系统,它的语法和Oracle数据库有很多相似之处。

本文将介绍OceanBase中与Oracle语法相关的内容,包括数据类型、DDL 语句、DML语句、PL/SQL语句等。

数据类型OceanBase和Oracle都支持常见的数据类型,如整数类型、浮点数类型、字符类型等。

以下是一些常用的数据类型:•整数类型:INT、INTEGER、SMALLINT、BIGINT•浮点数类型:FLOAT、DOUBLE、REAL•字符类型:CHAR、VARCHAR、VARCHAR2、NCHAR、NVARCHAR、NVARCHAR2•日期时间类型:DATE、TIME、TIMESTAMPDDL语句DDL(Data Definition Language)用于定义数据库对象,包括表、索引、视图等。

OceanBase的DDL语句和Oracle的语法非常相似,以下是一些常用的DDL语句:•创建表:CREATE TABLE table_name (column1 datatype,column2 datatype,...);•创建索引:CREATE INDEX index_name ON table_name (column1, column2, ...);•创建视图:CREATE VIEW view_name AS SELECT column1, column2, ... FROM table_name WHERE condition;•创建序列:CREATE SEQUENCE sequence_name START WITH 1 INCREMENT BY 1;DML语句DML(Data Manipulation Language)用于操作数据库中的数据,包括插入、更新、删除等操作。

OceanBase的DML语句和Oracle的语法也非常相似,以下是一些常用的DML语句:•插入数据:INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2,...);•更新数据:UPDATE table_name SET column1 = value1, column2 = value2, ... WHERE condition;•删除数据:DELETE FROM table_name WHERE condition;•查询数据:SELECT column1, column2, ... FROM table_name WHERE condition;PL/SQL语句PL/SQL(Procedural Language/Structured Query Language)是Oracle数据库中的编程语言,用于编写存储过程、函数和触发器等。

plsql的set语句用法_概述说明以及解释

plsql的set语句用法_概述说明以及解释

plsql的set语句用法概述说明以及解释1. 引言1.1 概述本文将重点介绍和解释PL/SQL的SET语句的用法。

PL/SQL是Oracle数据库中一种编程语言,用于存储过程、触发器和函数等对象的开发。

SET语句作为PL/SQL中最基本且常用的语句之一,具有灵活性和强大功能,在数据处理和逻辑控制方面起到了重要作用。

1.2 文章结构本文主要分为五个部分。

首先是引言部分,对文章进行概要介绍。

接下来是PL/SQL的SET语句的基本用法及使用场景进行详细讲解。

然后是对SET语句的详细说明和示例,包括赋值操作符、条件判断和逻辑运算符以及查询子句和聚合函数的使用方法。

第四部分将通过应用实例分析SET语句在PL/SQL编程中的具体应用,涵盖更新表中记录、处理游标数据集合以及执行动态SQL操作等方面。

最后是总结与展望部分,对PL/SQL的SET语句进行优势特点总结,并展望未来其在PL/SQL开发中的趋势与发展。

1.3 目的本文旨在全面阐述和解释PL/SQL的SET语句用法,并通过实例演示其在实际应用中的作用。

通过阅读本文,读者将能够掌握SET语句的基本语法和使用场景,了解SET语句中赋值操作符、条件判断和逻辑运算符以及查询子句和聚合函数的使用方法。

此外,读者还将通过应用实例的分析了解如何使用SET语句来更新表中的记录、处理游标数据集合以及执行动态SQL操作。

最后,在总结与展望部分,读者将对PL/SQL的SET语句有更全面和深入的认识,并对未来其在PL/SQL开发中的趋势与发展有一定预期。

2. PL/SQL的SET语句用法2.1 什么是PL/SQL的SET语句PL/SQL的SET语句是一种用于在程序中设置变量值或表字段值的命令。

它提供了一种简单而有效的方法来更新数据或执行计算操作。

2.2 SET语句的基本语法PL/SQL中的SET语句通常由关键字SET、要设置值的目标对象以及赋予该对象新值组成。

SET语句可以用于设置各种类型的变量或数据库表字段。

oracle 数据库database link sql写法

oracle 数据库database link sql写法

oracle 数据库database link sql写法Oracle数据库中,可以使用数据库链接(Database Link)来连接两个不同实例中的数据库,使得可以在一个数据库中访问另一个数据库中的对象。

数据库链接是一个逻辑连接,允许在一个数据库中以另一个数据库的角度访问对象。

在Oracle中,创建和使用数据库链接需要以下步骤:1. 创建数据库链接要创建数据库链接,可以使用CREATE DATABASE LINK语句。

语法如下:```CREATE DATABASE LINK link_nameCONNECT TO username IDENTIFIED BY passwordUSING 'tns_alias';```其中,link_name是链接的名称,username和password是目标数据库的登录凭证,tns_alias是指向目标数据库的TNS别名。

2. 使用数据库链接创建完数据库链接后,可以使用链接来访问目标数据库中的对象。

可以在SQL语句中使用@符号,后跟链接名称来引用链接,然后在链接名称之后指定要访问的表或视图。

例如:```SELECT * FROM table_name@link_name;```这将在当前数据库中执行SQL查询,访问链接指向的数据库中的表或视图。

3. 约束和限制在使用数据库链接时,需要注意以下约束和限制:- 数据库链接只能用于访问远程数据库上的对象,不能用于执行DDL语句。

- 数据库链接不能跨越数据库实例和版本,即数据库链接只能连接到同一个数据库版本中的对象。

- 数据库链接将使用连接的目标数据库的默认表空间和默认角色。

- 数据库链接的权限继承自目标数据库中的用户。

4. 管理数据库链接可以使用数据库链接的元数据视图来查询和管理数据库链接。

例如,可以使用DBA_DB_LINKS视图来查看当前数据库中的所有数据库链接。

```SELECT * FROM DBA_DB_LINKS;```该视图将返回链接的详细信息,例如链接名称、目标数据库的用户名和密码等。

Oracle常用命令大全(很有用,做笔记)

Oracle常用命令大全(很有用,做笔记)

Oracle常⽤命令⼤全(很有⽤,做笔记)⼀、ORACLE的启动和关闭1、在单机环境下要想启动或关闭ORACLE系统必须⾸先切换到ORACLE⽤户,如下su - oraclea、启动ORACLE系统oracle>svrmgrlSVRMGR>connect internalSVRMGR>startupSVRMGR>quitb、关闭ORACLE系统oracle>svrmgrlSVRMGR>connect internalSVRMGR>shutdownSVRMGR>quit启动oracle9i数据库命令:$ sqlplus /nologSQL*Plus: Release 9.2.0.1.0 - Production on Fri Oct 31 13:53:53 2003Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.SQL> connect / as sysdbaConnected to an idle instance.SQL> startup^CSQL> startupORACLE instance started.2、在双机环境下要想启动或关闭ORACLE系统必须⾸先切换到root⽤户,如下su - roota、启动ORACLE系统hareg -y oracleb、关闭ORACLE系统hareg -n oracleOracle数据库有哪⼏种启动⽅式说明:有以下⼏种启动⽅式:1、startup nomount⾮安装启动,这种⽅式启动下可执⾏:重建控制⽂件、重建数据库读取init.ora⽂件,启动instance,即启动SGA和后台进程,这种启动只需要init.ora⽂件。

2、startup mount dbname安装启动,这种⽅式启动下可执⾏:数据库⽇志归档、数据库介质恢复、使数据⽂件联机或脱机,重新定位数据⽂件、重做⽇志⽂件。

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常用的SQL及语法

oracle常用的SQL及语法

1、两个oracle 开发工具介绍a)SqlDbx王金生曾推荐过的一款数据库客户端开发工具,使用容易,不需要额外的安装其它插件,有sql提示功能,支持Oracle,Sybase ASE, IBM,DB2/UDB, MicrosoftSQL Server 和ODBC数据源,免费绿色版。

b)PLSQL Developer专门针对oracle开发的一款比较专业的客户端工具,除了常用的数据库操作外,还支持存储过程及函数的调试功能等比较高级的功能,详细的操作可以安装完毕后大家去慢慢研究。

配置方式见网上找的一段方法,第二种:/view/65b5a80f6c85ec3a87c2c583.html以上提到的工具及可能用到的插件见共享目录中的文件。

2、oracle 与 sqlserver 语法大比较a)oracle各类型字段描述b)字段类型比较c)常用函数比较注:此处仅记录语法有区别的地方,更多丰富的语法请查看附件中的手册。

以下的exp为expression的缩写d)关于脏读目前我们使用的sqlserver 数据库,在查询数据时,都要求在select语句中后面跟一个(nolock)或(with nolock)来保证读取大表时不影响其它程序进程的数据操作。

在oracle中,目前还不允许脏读的方式,在每次select 后,读到的数据都是已经commit的数据,所以为了避免读取数据的不准确,程序中如果有比较耗时的sql 操作,尤其是在insert 和update后,尽量减小事务,而且要在事务结束后及时commit。

e)表(主键、外键、CHECK、UNIQUE、DEFAULT、INDEX)在创建表及其主键、外键、CHECK、UNIQUE、DEFAULT、INDEX时,SQL SERVER 与ORACLE的语法大致相同。

主要区别如下:Oracle定义表字段的default属性紧跟字段类型之后,如下:Create table MZ_Ghxx( ghlxh number primay key ,rq date default sysdate not null,….)而不能写成Create table MZ_Ghxx( ghlxh number primay key ,rq date not null default sysdate,….)f)存储过程/函数结构的不同SQLSERVER中存储过程的结构大致如下CREATE PROCEDURE procedure_name/*输入、输出参数的声明部分*/ASDECLARE/*局部变量的声明部分*/BEGIN/*主体SQL语句部分*//*游标声明、使用语句在此部分*/ENDORACLE中存储过程的结构大致如下CREATE OR REPLACE PROCEDURE procedure_name(/*输入、输出参数的声明部分*/ )AS/*局部变量、游标等的声明部分*/BEGIN/*主体SQL语句部分*//*游标使用语句在此部分*/EXCEPTION/*异常处理部分*/END ;ORACLE端FUNCTION语法说明CREATE [OR REPLACE] FUNCTION function_name[(argument [{IN | OUT | IN OUT }] ) type,…[(argument [{IN | OUT | IN OUT }] ) typeRETURN return_type {IS | AS}BEGIN…END;变量赋值在SQL SERVER语句中用如下语句对局部变量赋值(初始值或数据库表的字段值或表达式):“SELECT 局部变量名= 所赋值(初始值或数据库表的字段值或表达式)”;而在ORACLE中,将初始值赋给局部变量时,用如下语句:“局部变量名: = 所赋值(初始值或表达式);”,将检索出的字段值赋给局部变量时,用如下语句:“SELECT 数据库表的字段值INTO 局部变量名…”。

Oracle 数据库对象_序列_索引_视图_同义词

Oracle 数据库对象_序列_索引_视图_同义词


查看序列情况
SELECT s_test.currval FROM dual; SELECT s_test.nextval FROM dual;
删除序列

删除序列使用DROP SEQUENCE语句

例如,删除s_test3序列
DROP SEQUENCE s_test3;

执行效果如下图所示:
索引介绍
使用序列填充主键-2

查询插入结果
SELECT * FROM order_status2;

查询结果如图所示

注意

Hale Waihona Puke 当使用序列填充主键列时,通常应使用NOCACHE避免序列产生的数 值发生遗漏(数值产生遗漏是因为缓存数值时,数据库被关闭)。然 而,使用NOCACHE虽然会降低性能。但是如果不介意主键值产生遗 漏,可以再考虑使用CACHE。
案例

使用默认选项创建序列
CREATE SEQUENCE s_test;

说明

创建序列忽略了其他选项,那么将会使用默认值。 start_num和increment_num都是1

指定相关选项创建序列
CREATE SEQUENCE s_test2 START WITH 10 INCREMENT BY 5 MINVALUE 10 MAXVALUE 20 CYCLE CACHE 2 ORDER;

说明

minimum_num:序列中的最小值,该值必须比start_num小,比 maximum_num也要小 NOMINVALUE:对于序列最小值,不指定最小值,对于升序最小值是1 ,对于降序最小值是-1026 CYCLE:对于序列的值达到最大值或最小值时的处理方法。如果是升序 达到最大值了,那么下一个生成的值将是最小值;如果是降序达到最小值 时,那么下一个值将是最大值。 NOCYCLE:当序列的值达到最大或最小值时,序列将不再产生任何数值 。默认是NOCYCLE。

oracle的sql用法

oracle的sql用法

oracle的sql用法Oracle SQL是一种强大而广泛使用的关系型数据库管理系统(RDBMS)的查询语言。

它由Oracle公司开发并维护,可用于执行各种数据库操作,如数据检索、数据插入、数据更新和数据删除。

本文将深入探讨Oracle SQL 的用法,并一步一步回答与该主题相关的问题。

一、Oracle SQL的简介Oracle SQL是一种结构化查询语言(Structured Query Language,简称SQL),用于与Oracle数据库进行交互和操作。

它是一种高级语言,可通过简洁而强大的语法从数据库中检索所需的数据。

二、Oracle SQL的基本语法Oracle SQL的基本语法由多个关键字、函数和操作符组成。

以下是一些常用的关键字和操作符:1. SELECT:用于从表中检索数据。

2. FROM:用于指定要查询的表。

3. WHERE:用于筛选数据的条件。

4. ORDER BY:用于按指定的列对结果进行排序。

5. GROUP BY:用于根据指定的列对结果进行分组。

6. INSERT INTO:用于向表中插入新数据。

7. UPDATE:用于更新表中的现有数据。

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

9. IN:用于在一组值中进行匹配。

三、Oracle SQL的用法详解1. 数据检索要从表中检索数据,可以使用SELECT语句。

例如,要检索名为"customers"的表中所有行的所有列,可以执行以下语句:SELECT * FROM customers;要检索指定列的数据,可以在SELECT语句中列出这些列的名称。

例如,要检索名为"customers"的表中所有行的"customer_name"和"email"列,可以执行以下语句:SELECT customer_name, email FROM customers;2. 数据插入要向表中插入新数据,可以使用INSERT INTO语句。

plsql教程

plsql教程

plsql教程PL/SQL是一种与Oracle数据库一起使用的过程化编程语言。

它是操纵、定义和控制Oracle数据库对象的语言,并提供了一种编写存储过程、触发器、函数、包等数据库程序模块的方式。

PL/SQL的基本语法与SQL相似,可以执行SQL语句和存储过程的调用。

以下是一些常用的PL/SQL代码示例:1. 声明变量和常量:```DECLAREnum1 NUMBER := 10;text1 VARCHAR2(20) := 'Hello';constant1 CONSTANT NUMBER := 5;BEGIN-- 执行代码END;```2. 条件语句:```IF num1 > 0 THENNULL;ELSIF num1 = 0 THENNULL;ELSENULL;END IF;```3. 循环语句:```FOR i IN 1..5 LOOPNULL;END LOOP;WHILE num1 > 0 LOOP NULL;num1 := num1 - 1; END LOOP;LOOPNULL;EXIT WHEN num1 = 0; num1 := num1 - 1; END LOOP;```4. 异常处理:```BEGIN-- 执行代码EXCEPTIONWHEN OTHERS THEN -- 处理异常END;```5. 创建存储过程:```CREATE OR REPLACE PROCEDURE procedure_name (param1 IN NUMBER, param2 OUT VARCHAR2) IS-- 变量声明BEGIN-- 执行代码param2 := 'Hello';END;```这些只是PL/SQL语言的一部分功能和用法。

通过学习和实践,您可以掌握更多PL/SQL的知识和技巧,提高数据库编程的效率和质量。

oracle数据库教程

oracle数据库教程

oracle数据库教程Oracle数据库是一种关系型数据库管理系统(RDBMS),被广泛应用于企业级应用和大型数据处理。

本教程旨在帮助初学者快速入门Oracle数据库。

1. 数据库基础知识- 关系型数据库的定义和特点- 数据库管理系统的作用和功能- 数据库模型和关系模型的概念- 数据表、字段、记录和键的说明2. Oracle数据库安装和配置- 安装Oracle数据库软件- 创建和配置数据库实例- 创建管理员账户和用户账户3. SQL基础- SQL语言的概述和发展历史- SQL命令的分类和语法结构- 常用的SQL命令:SELECT、INSERT、UPDATE、DELETE- 使用WHERE子句和运算符进行条件查询- 使用ORDER BY子句对结果排序- 使用GROUP BY子句进行分组和聚合- 使用JOIN操作连接多个表- 创建和管理索引4. 数据库对象管理- 创建和管理数据库表- 创建和管理视图- 创建和管理索引- 创建和管理存储过程和函数- 创建和管理触发器- 创建和管理序列5. 数据库事务和并发控制- 事务的定义和特性- 数据库锁和并发控制的概念- 事务的隔离级别和并发控制机制 - 死锁和事务恢复6. 数据备份和恢复- 备份和恢复的重要性- 数据库备份的类型和方法- 数据库恢复的方法和步骤7. 性能优化和调优- 识别和解决数据库性能问题- SQL查询性能优化的常见技巧 - 数据库参数的调整和优化8. 数据库安全性- 数据库安全的重要性和威胁- 用户权限和角色管理- 数据库连接和访问控制- 数据库加密和安全审计以上是Oracle数据库的基本教程内容,通过学习这些知识,你将能够使用Oracle数据库进行基本的数据库开发和管理操作。

oracle sql数据库基本知识

oracle sql数据库基本知识

oracle sql数据库基本知识
OracleSQL是一种用于操作Oracle数据库的编程语言,是关系型数据库操作语言的一种。

它被广泛应用于企业级应用程序开发和管理中。

以下是Oracle SQL数据库基本知识:
1. 数据库对象:Oracle数据库由多个对象组成,包括表、索引、视图、存储过程等。

2. SQL语句:Oracle SQL包括多种SQL语句,如SELECT、UPDATE、INSERT、DELETE等,用于对数据库进行操作。

3. 数据类型:Oracle SQL的数据类型包括数字、字符、日期等。

4. 数据库连接:Oracle SQL可以通过JDBC或ODBC等连接方式与Oracle数据库进行连接。

5. 数据库管理:Oracle SQL可以用于管理数据库,如创建用户、授权、备份等。

6. 视图和存储过程:Oracle SQL支持视图和存储过程,用于简化和优化数据库操作。

7. 事务管理:Oracle SQL支持事务处理,保证数据库操作的一致性和可靠性。

总之,Oracle SQL是一种强大的数据库操作语言,具有广泛的应用价值。

掌握Oracle SQL的基本知识,可以提高企业级应用程序的开发和管理效率。

- 1 -。

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语句大全及用法

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:用于条件判断,根据条件执行不同的操作。

plsql 使用手册

plsql 使用手册

plsql 使用手册PL/SQL 使用手册PL/SQL 是一种过程化编程语言,特别适合与 Oracle 数据库一起使用。

本文将为您提供 PL/SQL 的使用手册,详细介绍 PL/SQL 的特性、语法以及常用技巧,帮助您快速上手并有效地利用 PL/SQL 进行数据库开发。

1. PL/SQL 简介PL/SQL 是 Oracle 数据库中扩展功能的一部分,它结合了 SQL 语句和流程控制语句,允许开发人员在数据库中执行复杂的任务和操作。

PL/SQL 以块的方式组织代码,这些代码块可以嵌套和重用,提高了代码的可维护性和复用性。

2. PL/SQL 基础语法2.1 变量和数据类型在 PL/SQL 中,可以声明各种类型的变量来存储数据。

常见的数据类型包括整型、浮点型、字符型等。

通过变量,可以存储和操作数据,使得代码更加灵活和可读性更强。

2.2 控制流程PL/SQL 提供了丰富的控制流程语句,如条件判断、循环等,用于实现不同的业务逻辑。

通过控制流程语句,可以根据不同的情况执行不同的代码块,实现灵活的程序逻辑。

2.3 异常处理PL/SQL 具有强大的异常处理机制,通过使用 EXCEPTION 关键字来捕获和处理异常。

可以使用 TRY-CATCH 结构捕获异常,并在异常发生时执行相应的操作,保证程序的健壮性和稳定性。

3. PL/SQL 常用技巧3.1 存储过程存储过程是 PL/SQL 的一种重要应用,可以将一系列的 SQL 语句和逻辑封装在一个过程中,提供数据库操作的接口。

存储过程可以提高性能,减少网络开销,并增加代码的重用性。

3.2 游标游标是 PL/SQL 用于遍历结果集的一种对象。

通过游标,可以从查询结果中提取出数据,并逐条进行处理。

这在需要对查询结果进行逐行处理时非常有用。

3.3 包和触发器PL/SQL 支持包和触发器的概念,这些是组织和管理代码的有力工具。

通过将相关的过程和函数组织到包中,可以提高代码的可维护性和可读性。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

ORACLE 常用的SQL语法和数据对象一.数据控制语句 (DML) 部分1.INSERT (往数据表里插入记录的语句)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()还有很多种日期格式, 可以参看ORACLE DOC.年-月-日小时:分钟:秒的格式YYYY-MM-DD HH24:MI:SSINSERT时最大可操作的字符串长度小于等于4000个单字节, 如果要插入更长的字符串, 请考虑字段用CLOB类型,方法借用ORACLE里自带的DBMS_LOB程序包.INSERT时如果要用到从1开始自动增长的序列号, 应该先建立一个序列号CREATE SEQUENCE 序列号的名称 (最好是表名序列号标记) INCREMENT BY 1 START WITH 1 MAXVALUE 99999 CYCLE NOCACHE;其中最大的值按字段的长度来定, 如果定义的自动增长的序列号 NUMBER(6) , 最大值为999999INSERT 语句插入这个字段值为: 序列号的名称.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 日期类型创建表时要把较小的不为空的字段放在前面, 可能为空的字段放在后面创建表时可以用中文的字段名, 但最好还是用英文的字段名创建表时可以给字段加上默认值, 例如 DEFAULT SYSDATE这样每次插入和修改时, 不用程序操作这个字段都能得到动作的时间创建表时可以给字段加上约束条件例如不允许重复 UNIQUE, 关键字 PRIMARY KEY2.ALTER (改变表, 索引, 视图等)改变表的名称ALTER TABLE 表名1 TO 表名2;在表的后面增加一个字段ALTER TABLE表名 ADD 字段名字段名描述;修改表里字段的定义描述ALTER TABLE表名 MODIFY字段名字段名描述;给表里的字段加上约束条件ALTER TABLE 表名 ADD CONSTRAINT 约束名 PRIMARY KEY (字段名);ALTER TABLE 表名 ADD CONSTRAINT 约束名 UNIQUE (字段名);把表放在或取出数据库的内存区ALTER TABLE 表名 CACHE;ALTER 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, ……] );ALTER INDEX 索引名 REBUILD;一个表的索引最好不要超过三个 (特殊的大表除外), 最好用单字段索引, 结合SQL语句的分析执行情况,也可以建立多字段的组合索引和基于函数的索引ORACLE8.1.7字符串可以索引的最大长度为1578 单字节ORACLE8.0.6字符串可以索引的最大长度为758 单字节2.视图 (VIEW)CREATE VIEW 视图名AS SELECT …. FROM …..;ALTER 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 数据对象名, INSERT ON 数据对象名, ALTER 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;查询报表数据库中话单统计种类查询。

相关文档
最新文档