oracle增删改查详细图文
Oracle之xml的增删改查操作
Oracle之xml的增删改查操作工作之余,总结一下xml操作的一些方法和心得!tip: xmltype函数是将clob字段转成xmltype类型的函数,若字段本身为xmltype类型则不需要引用xmltype()函数同名标签用数组取值的方式获取,但起始值从1开始一.查询(Query)1. extract函数,查询节点值,带节点名1-- 获取带节点的值,例如:<tel>222</tel>2selectextract(xmltype(e.prj_xml),'/data/project/persons/person[1]/tel').getStringV al() as title from project e where e.zh_title='白夜追逐繁星';3-- 备注如果节点表达式查询一个节点的父节点,则会将该父节点下的所有节点包含该父节点查出Query Result:tip: extract函数中路径引用text(),查询的节点若重复则自动拼接select extractvalue(xmltype('<a><b>1</b><b>2</b></a>'),'/a/b') from dual; -- 报错,报只返回一个节点值,因为在a标签下存在两个同名标签b selectextract(xmltype('<a><b>1</b><b>2</b></a>'),'/a/b/text()') from dual; -- extract+text() 解决同名节点问题,若存在重复节点会自动拼接在一起,但不使用任何拼接符号2. extractvalue函数,查询节点值,不带节点名-- 获取不带节点的值,例如:2221 selectextractvalue(xmltype(e.prj_xml),'/data/project/persons/person[1]/tel') asresult from project e where e.zh_title='白夜追逐繁星';Query Result:Tip: 节点不存在时,查询结果均为空3. existsnode函数,判断节点是否存在,表示存在,0表示不存在1 select existsnode(xmltype(e.prj_xml),'/data/project/persons/person[1]/tel') as result from project e where e.zh_title='白夜追逐繁星';Query Result:4. sys_dburigen,将指定列通过函数生成一个该列的URI值,例如:/PUBLIC/PROJECT/ROW[ZH_TITLE='邹成咁180117']/ZH_TITLE1 select sys_dburigen(e.zh_title) as result from project e where e.zh_title='白夜追逐繁星';Query Result:5. sys_xmlAgg,合并查询,将多个xml合并,类似于set集合-- sys_xmlGen 将xml转成xmltype实例,方便xml合并,sys_xmlAgg用于xml 合并1 select sys_xmlAgg(sys_xmlgen(e.prj_xml)) as result from project e wheree.zh_title='白夜追逐繁星'or e.zh_title='白夜追逐繁星2' ;Query Result:6. xmlforest,将指定列以xml格式查询出来,可指定生成的xml节点名称1 select xmlforest(e.zh_title as zhTitle,e.prj_no as prjNo,e.psn_code as psnCode).getStringVal() as xml from project e where e.zh_title='白夜追逐繁星';Query Result:7. xmlelement,为查询出来的xml添加挂载的父节点,并将xml字符串格式化成xml ,与xmlforest函数配套使用1 selectxmlelement(data,xmlforest(e.zh_title,e.prj_no,e.psn_code)).getStringVal() as xml from project e where e.zh_title='白夜追逐繁星';Query Result:延伸:为data节点添加属性,使用xmlattributes函数1 select xmlelement(data,xmlattributes(e.prj_code ascode),xmlforest(e.zh_title,e.prj_no,e.psn_code)).getStringVal() as xml from project e where e.zh_title='白夜追逐繁星';Query Result:延伸:XMLCOLATTVAL效果等同于xmlforest函数,但默认会为每个标签添加一个属性name,属性值为列明,若未指定列别名,默认该列列明1 select XMLCOLATTVAL(e.zh_title as zhTitle,e.prj_no as prjNo,e.psn_code as psnCode).getStringVal() as xml from project e where e.zh_title='白夜追逐繁星'Query Result:8. xmlConcat,xmlType实例之间联结1selectxmlelement(data,xmlConcat(xmltype('<a>1</a>'),xmltype('<b>1</b>'))).getStrin gVal() as result from dual;Query Result:9. xmlsequence将一个xml以标签为单位,转换成数组,也就是一行行记录1select e.getStringVal() as result2fromtable(xmlsequence(extract(xmltype('<a><b>233</b><c>666</c><d>88</d></a>'),'/ a/*'))) e;Query Result:二.添加(Insert)-- 添加xml节点,insertchildxml添加xml节点,参数3默认指定插在该节点后,若该节点不存在,则追加到子节点集合的末尾-- 添加xml节点,insertchildxmlbefore,和insertchildxmlafter添加xml节点,参数3指定插在该节点前或者后,若该节点不存在,则追加到子节点集合的末尾1update project e sete.prj_xml=insertchildxml(xmltype(e.prj_xml),'/data/project/persons/person[1] ','tel',xmltype('<tel>222</tel>')).getClobVal() where e.zh_title='白夜追逐繁星';2update project e sete.prj_xml=insertchildxmlbefore(xmltype(e.prj_xml),'/data/project/persons/per son[1]','psn_code',xmltype('<tel>111</tel>')).getClobVal() where e.zh_title='白夜追逐繁星';三.修改(Update)-- updatexml用于更新节点值1-- updatexml用于更新节点值,参数1:需要修改节点的xml字段;参数2:节点路径;参数3:值2update project e sete.prj_xml=updatexml(xmltype(e.prj_xml),'/data/project/persons/person[1]/tel','<tel>111</tel>').getClobVal() where e.zh_title='白夜追逐繁星';3update project e sete.prj_xml=updatexml(xmltype(e.prj_xml),'/data/project/persons/person[1]/tel/ text()','222').getClobVal() where e.zh_title='白夜追逐繁星';tip: getClobVal()是将xmltype类型转成clob类型方法四.删除(Delete)1-- 删除xml节点,参数1:需要删除节点的xml字段;参数2:节点路径;2update project e set e.prj_xml=deletexml(xmltype(e.prj_xml),'/data/project/persons/person[1]/tel' ).getClobVal() where e.zh_title='白夜追逐繁星';。
Oracle的基本语法(增删改查)
Oracle的基本语法(增删改查)表的操作:创建表:create table 表名(列名属性;);查看表结构:desc 表名;表重命名:rename 原表名 to 新表名;删除表:drop 表名;表的字段操作:增:alter table 表名 add 列名列的属性; --单列操作alter table 表名 add (列名1 列1的属性,列名2 列2的属性,...) --多列操作删: alter table 表名 drop column 列名; --单列操作alter table 表名 drop (列1,列2); --多列操作(多列不需要加column)改:alter table 表名 modify 列名新属性; --单列操作alter table 表名 modify (列名1 列1的新属性,列名2 列2的新属性);--多列操作数据的操作:增:--单⾏操作insert into 表名 values(所有列的信息); --数据类型必须与表结构⾥字段的属性⼀致insert into 表名 values(部分信息); --会按表的字段顺序加⼊信息,后⾯没设置的为null(输⼊数据必须⼩于或等于列数) --多⾏操作insert into 表1select 数据1 from dualunionselect 数据2 from dual; --dual 是⼀张伪表只是为了⽅便操作⽽存在,需要了解的请百度删:delete from 表名 --删除所有数据delete 列名 from 表名 where 条件 --删除符合条件的某些数据删除某⼀列数据(该列必须可以为null):1.update 表名 set 列名=null;2.delete from 表名 where 列名 is not null ;改:update 表名 set 列名=数据 where 条件; --修改满⾜条件的数据update 表名 set 列名=数据; --将该列全部修改查看:select * from 表名; --查看表的全部信息select 列1,列2 from 表名; --查看表的列1,列2信息。
oracle 视图的增删改查操作举例
oracle 视图的增删改查操作举例oracle视图创建和操作创建简单复杂的视图创建基表不存在的视图视图增删改查看视图的结构关键字: oracle视图创建操作简单复杂基表不存在增删改插入修改删除查看结构视图的概念视图是基于一张表或多张表或另外一个视图的逻辑表。
视图不同于表视图本身不包含任何数据。
表是实际独立存在的实体是用于存储数据的基本结构。
而视图只是一种定义对应一个查询语句。
视图的数据都来自于某些表这些表被称为基表。
通过视图来查看表就像是从不同的角度来观察一个或多个表。
视图有如下一些优点可以提高数据访问的安全性通过视图往往只可以访问数据库中表的特定部分限制了用户访问表的全部行和列。
简化了对数据的查询隐藏了查询的复杂性。
视图的数据来自一个复杂的查询用户对视图的检索却很简单。
一个视图可以检索多张表的数据因此用户通过访问一个视图可完成对多个表的访问。
视图是相同数据的不同表示通过为不同的用户创建同一个表的不同视图使用户可分别访问同一个表的不同部分。
视图可以在表能够使用的任何地方使用但在对视图的操作上同表相比有些限制特别是插入和修改操作。
对视图的操作将传递到基表所以在表上定义的约束条件和触发器在视图上将同样起作用。
视图的创建创建视图需要CREAE VIEW系统权限视图的创建语法如下CREATE OR REPLACE FORCENOFORCE VIEW 视图名别名1别名 2... AS 子查询WITH CHECK OPTION CONSTRAINT 约束名WITH READ ONL Y 其中OR REPLACE 表示替代已经存在的视图。
FORCE表示不管基表是否存在创建视图。
NOFORCE表示只有基表存在时才创建视图是默认值。
别名是为子查询中选中的列新定义的名字替代查询表中原有的列名。
子查询是一个用于定义视图的SELECT 查询语句可以包含连接、分组及子查询。
WITH CHECK OPTION表示进行视图插入或修改时必须满足子查询的约束条件。
oracle实验 表的插入、修改和删除的原理
Oracle实验表的插入、修改和删除的原理Oracle实验中,表的插入、修改和删除的原理如下:
1.插入数据:
●当向表中插入数据时,Oracle会根据表的结构(列的数据类型和
约束等)对数据进行验证,确保数据符合表的定义。
●如果要插入的数据与表中的主键或唯一约束冲突,Oracle会抛出
错误。
●插入数据时,可以使用INSERT语句指定要插入的列和对应的数
据值。
如果未指定列名,则必须为表中的每一列提供一个值。
2.修改数据:
●当修改表中的数据时,Oracle会找到要修改的行,并更新相应的
列的值。
●如果修改的数据违反了表中的某些约束(如唯一约束、非空约束
等),Oracle会抛出错误。
●修改数据时,可以使用UPDATE语句指定要修改的列和新值,以
及用于定位要修改的行的条件(通常为WHERE子句)。
3.删除数据:
●当从表中删除数据时,Oracle会找到要删除的行,并将其从表中
删除。
●如果删除的数据违反了表中的某些约束(如外键约束等),
Oracle会抛出错误。
●删除数据时,可以使用DELETE语句指定用于定位要删除的行的条
件(通常为WHERE子句)。
如果要删除表中的所有行,可以使用
TRUNCATE TABLE语句。
这些原理是基于关系数据库管理系统的基本操作,Oracle作为关系数据库管理系统之一,也遵循这些原理。
在实际实验中,需要注意操作的正确性和数据的一致性,以避免数据损坏或错误。
Oracle更新数据和删除数据
Oracle 更新数据和删除数据更新数据如果表中的数据不合适,那么就需要对其修改或更新。
在SQL 中,用户可以使用UPDATE 语句完成数据的更新操作。
在更新数据时,即可以一次更新一列,也可以一次更新多列。
如果在UPDATE 语句中使用了WHERE 条件表达式,那么只有符合条件的记录才会被更新;如果没有使用WHERE 条件表达式,那么表示更新表中所有行的数据。
在更新表中的数据时,这些更新操作不能违反表中的完整性约束。
例如,在EMP 表中,主键列EMPNO 的数据不允许重复,因此如果更新后的数据与现存数据相同,则会因为违反主键约束而失败。
如下所示: SQL> update emp2 set empno=78763 where ename='CLARK';update emp*第 1 行出现错误:ORA-00001: 违反唯一约束条件 (SCOTT.PK_EMP)删除数据如果表中的数据不再需要,那么就可以删除表中的数据。
在删除表中的数据时,最常用的SQL 语句是DELETE 语句。
在删除操作中,即可以一次删除一行数据,也可以一次删除多行数据,更可以删除表中的所有数据。
在DELETE 语句中,如果没有使用WHERE 条件表达式,那么将会删除表中的所有数据。
例如,下面语句将删除EMP 表中的ENAME 列为ATG 的记录行:SQL> delete from emp2 where ename='ATG';已删除1 行。
在Oracle 系统中,除了DELETE 语句外,还可以使用TRUNCATE TABLE 语句删除表中的所有数据。
相比之下,使用TRUNCATE 语句删除数据时,通常要比DELETE 语句快许多。
这是因为使用TRUNCA TE TABLE 语句删除数据时,它不会产生回退信息,因此执行TRUNCATE 操作也不能撤销。
例如,下面的语句将删除ACCOUNTING_EMPLOYEES 表中所有的记录:注 意在更新数据时,如果没有使用WHERE 条件表达式,那么系统将会更新表中所有的数据。
oracle基本操作
oracle基本操作Oracle是一种关系数据库管理系统,它是世界上最受欢迎的企业级数据库。
它被各种企业广泛使用,它的功能非常强大,包括数据安全、访问控制、事务处理、性能优化、数据备份和恢复等。
本文将介绍Oracle的基本操作,包括如何创建、修改和删除表,如何插入、更新和删除数据,以及如何查询和导出数据。
这些操作对于初学者来说非常重要,也是使用Oracle的基础。
1.创建表格在Oracle中,创建表的语法如下:CREATE TABLE table_name ( column1 datatype, column2 datatype, column3 datatype, .... );其中,table_name是要创建的表的名称,column1、column2等是列名,datatype是列的数据类型。
例如,创建一个名为“employees”的表格,并添加列“id”、“name”和“salary”,则可以使用以下命令:CREATE TABLE employees ( id NUMBER(4) NOT NULL, name VARCHAR2(15) NOT NULL, salary NUMBER(7,2), PRIMARY KEY (id) );注意,id和name列设置为NOT NULL,这表示这两列不能为空。
salary列的数据类型为NUMBER,并设置了精度和小数位数。
2.修改表格如果需要修改表格,可以使用ALTER TABLE命令。
例如,如果想向employees表格添加新的列“address”,可以使用以下命令:ALTER TABLE employees ADD address VARCHAR2(50);如果需要删除表格中的列,可以使用以下命令:ALTER TABLE employees DROP COLUMN address;3.删除表格如果需要删除一个表格,可以使用以下命令:DROP TABLE table_name;例如,删除名为“employees”的表格:DROP TABLE employees;如果不小心使用了错误的命令或者删除的表格不是自己想要的,则可以使用RECOVER命令来找回删除的表格。
增删改查简单-解释说明
增删改查简单-概述说明以及解释1.引言1.1 概述在现代信息时代,数据的管理和处理变得越来越重要。
无论是个人用户还是企业组织,都需要对数据进行增加、删除、修改以及查询等操作。
这些操作合称为增删改查(CRUD)操作,是数据管理中最基本、最常见的操作。
增删改查操作是数据管理的核心,它们在各个领域都得到广泛应用。
在个人数据管理方面,人们通过增加数据来记录生活中的重要事件、保存联系人信息等;删除数据可以清理不再需要的内容、释放存储空间;修改数据使其与当前状态保持一致;查询数据能够快速找到所需的信息。
而在企业层面,增删改查操作更是不可或缺的。
企业需要通过增加数据来记录各项业务活动,包括客户信息、订单记录、销售数据等,为后续的决策和分析提供基础;删除数据可以清理过时的、无效的或违规的内容;修改数据可以纠正错误或更新信息;查询数据则是企业分析和决策的重要依据。
在进行增删改查操作时,不仅需要掌握相应的方法和技术,还需要注意一些注意事项。
例如,在增加数据时,应确保数据的完整性和准确性,避免重复或错误的录入;在删除数据时,要谨慎操作,避免误删重要数据;在修改数据时,需要考虑影响范围和相关性,并确保相应的审批和权限控制;在查询数据时,要充分利用相关的搜索、过滤和排序功能,以提高查询效率。
评估增删改查操作的效果也是很重要的。
通过对增删改查操作的效果进行评估,可以不断改进和优化数据管理的流程和方法,提高工作效率和数据质量。
综上所述,增删改查操作是数据管理中不可或缺的基本操作,无论是个人用户还是企业组织,都需要掌握和运用这些操作技巧。
正确地进行增删改查操作,能够更好地管理和利用数据,提高工作效率和决策能力。
1.2 文章结构文章结构部分的内容如下:2. 正文2.1 增2.1.1 增加数据的重要性2.1.2 增加数据的方法2.1.3 增加数据的注意事项2.1.4 增加数据的效果评估2.2 删2.2.1 删除数据的重要性2.2.2 删除数据的方法2.2.3 删除数据的注意事项2.2.4 删除数据的效果评估2.3 改2.3.1 修改数据的重要性2.3.2 修改数据的方法2.3.3 修改数据的注意事项2.3.4 修改数据的效果评估2.4 查2.4.1 查询数据的重要性2.4.2 查询数据的方法2.4.3 查询数据的注意事项2.4.4 查询数据的效果评估以上是本文的文章结构。
ORACLE增删改查以及casewhen的基本用法
ORACLE增删改查以及casewhen的基本⽤法1.创建tablecreate table test01(id int not null primary key,name varchar(8) not null,gender varchar2(2) not null,age int not null,address varchar2(20) default ‘地址不详’ not null,regdata date);约束⾮空约束 not null主键约束 primary key外键约束唯⼀约束 unique检查约束 check联合主键constraint pk_id_username primary key(id,username);查看数据字典desc user_constraint修改表时重命名rename constraint a to b;--修改表删除约束--禁⽤约束 disable constraint 约束名字;删除约束 drop constraint 约束名字; drop primary key;直接删除主键外键约束create table typeinfo(typeid varchar2(20) primary key, typename varchar2(20));create table userinfo_f( id varchar2(10) primary key,username varchar2(20),typeid_new varchar2(10) references typeinfo(typeid));insert into typeinfo values(1,1);创建表时设置外键约束constraint 名字 foregincreate table userinfo_f2 (id varchar2(20) primary key,username varchar2(20),typeid_new varchar2(10),constraint fk_typeid_new foreign key(typeid_new) references typeinfo(typeid));create table userinfo_f3 (id varchar2(20) primary key,username varchar2(20),typeid_new varchar2(10),constraint fk_typeid_new1 foreign key(typeid_new) references typeinfo(typeid) on delete cascade外键约束包含删除外键约束禁⽤约束 disable constraint 约束名字;删除约束 drop constraint 约束名字;唯⼀约束与主键区别唯⼀约束可以有多个,只能有⼀个nullcreate table userinfo_u( id varchar2(20) primary key,username varchar2(20) unique,userpwd varchar2(20));创建表时添加约束constraint 约束名字 unique(列名);修改表时添加唯⼀约束 add constraint 约束名字 unique(列名);检查约束create table userinfo_c( id varchar2(20) primary key,username varchar2(20), salary number(5,0) check(salary>50));constraint ck_salary check(salary>50);/* 获取表:*/select table_name from user_tables; //当前⽤户的表select table_name from all_tables; //所有⽤户的表select table_name from dba_tables; //包括系统表select table_name from dba_tables where owner=’zfxfzb’/*2.修改表alter table test01 add constraint s_id primary key;alter table test01 add constraint CK_INFOS_GENDER check(gender=’男’ or gender=’⼥’)alter table test01 add constraint CK_INFOS_AGE(age>=0 and age<=50)alter table 表名 modify 字段名 default 默认值; //更改字段类型alter table 表名 add 列名字段类型; //增加字段类型alter table 表名 drop column 字段名; //删除字段名alter table 表名 rename column 列名 to 列名 //修改字段名rename 表名 to 表名 //修改表名3.删除表格truncate table 表名 //删除表中的所有数据,速度⽐delete快很多,截断表delete from table 条件//drop table 表名 //删除表4.插⼊语句insert into 表名(值1,值2) values(值1,值2);5.修改语句update 表名 set 字段=值 [修改条件]update t_scrm_db_app_user set password = :pwd where login_name = :user6.查询语句带条件的查询where模糊查询like % _范围查询in对查询结果进⾏排序order by desc||asc7.case whenselect username,case username when ‘aaa’ then ‘计算机部门’ when ‘bbb’ then ‘市场部门’ else ‘其他部门’ end as 部门 from users; select username,case username=’aaa’ then ‘计算机部门’ when username=’bbb’ then ‘市场部门’ else ‘其他部门’ as 部门 from users;8.运算符和表达式算数运算符和⽐较运算符 distinct 去除多余的⾏ column 可以为字段设置别名⽐如 column column_name heading new_name decode 函数的使⽤类似于case…when select username,decode(username,’aaa’,’计算机部门’,’bbb’,’市场部门’,’其他’) as 部门 from users;9.复制表create table 表名 as ⼀个查询结果 //复制查询结果insert into 表名值⼀个查询结果 //添加时查询10.查看表空间desc test01;11.创建表空间永久表空间create tablespace test1_tablespace datafile ‘testfile.dbf’ size 10m;临时表空间create temporary tablespace temptest1_tablespace tempfile ‘tempfile.dbf’ size 10m;desc dba_data_files;select file_name from dba_data_files where tablespace_name=’TEST1_TABLESPACE’;。
oracle数据库增删改查练习50例-答案(精)
oracle 数据库增删改查练习50例-答案一、建表--学生表drop table student;create table student (sno varchar2(10,sname varchar2(10,sage date,ssex varchar2(10;insert into student values('01','赵雷',to_date('1990/01/01','yyyy/mm/dd','男';insert into student values('02','钱电',to_date('1990/12/21','yyyy/mm/dd','男';insert into student values('03','孙风',to_date('1990/05/20','yyyy/mm/dd','男';insert into student values('04','李云',to_date('1990/08/06','yyyy/mm/dd','男';insert into student values('05','周梅',to_date('1991/12/01','yyyy/mm/dd','女';insert into student values('06','吴兰',to_date('1992/03/01','yyyy/mm/dd','女';insert into student values('07','郑竹',to_date('1989/07/01','yyyy/mm/dd','女';insert into student values('08','王菊',to_date('1990/01/20','yyyy/mm/dd','女';--课程表drop table course;create table course (cno varchar2(10,cname varchar2(10,tno varchar2(10;insert into course values ('01','语文','02';insert into course values ('02','数学','01';insert into course values ('03','英语','03';--教师表drop table teacher;create table teacher (tno varchar2(10,tnamevarchar2(10;insert into teacher values('01','张三';insert into teacher values('02','李四';insert into teacher values('03','王五';--成绩表drop table sc;create table sc (sno varchar2(10,cno varchar2(10,score number(18,1;insert into sc values('01','01',80.0;insert into sc values('01','02',90.0;insert into sc values('01','03',99.0;insert into sc values('02','01',70.0;insert into scvalues('02','02',60.0;insert into sc values('02','03',80.0;insert into scvalues('03','01',80.0;insert into sc values('03','02',80.0;insert into scvalues('03','03',80.0;insert into sc values('04','01',50.0;insert into scvalues('04','02',30.0;insert into sc values('04','03',20.0;insert into scvalues('05','01',76.0;insert into sc values('05','02',87.0;insert into scvalues('06','01',31.0;insert into sc values('06','03',34.0;insert into scvalues('07','02',89.0;insert into sc values('07','03',98.0;commit;二、查询1.1、查询同时存在"01"课程和"02"课程的情况select s.sno, s.sname, s.sage, s.ssex, sc1.score, sc2.score from student s, sc sc1, sc sc2 where s.sno = sc1.sno and s.sno = sc2.sno and o = '01' and o = '02';1.2、查询必须存在"01"课程,"02"课程可以没有的情况select t.*, s.score_01, s.score_02 from student t inner join (select a.sno, a.score score_01, b.score score_02 from sc a left join (select * from sc where cno = '02' b on (a.sno = b.sno where o = '01' s on (t.sno = s.sno;2.1、查询同时'01'课程比'02'课程分数低的数据select s.sno, s.sname, s.sage, s.ssex, sc1.score, sc2.score from student s, sc sc1, sc sc2 where s.sno = sc1.sno and s.sno = sc2.sno and o = '01' and o = '02' and sc1.score < sc2.score;2.2、查询同时'01'课程比'02'课程分数低或'01'缺考的数据select s.sno, s.sname, s.sage, s.ssex, t.score_01, t.score_02 from student s, (select b.sno, a.score score_01,b.score score_02 from (select * from sc where cno = '01' a, (select * from sc where cno = '02' b where a.sno(+ = b.sno t where s.sno = t.sno and (t.score_01 < t.score_02 ort.score_01 is null;3、查询平均成绩大于等于60分的同学的学生编号和学生姓名和平均成绩select s.sno, s.sname, t.avg_score avg_score from student s, (select sno, round(avg(score, 2 avg_score from sc group by sno having avg(score >= 60 order by sno t where s.sno = t.sno;4、查询平均成绩小于60分的同学的学生编号和学生姓名和平均成绩4.1、有考试成绩,且小于60分select s.sno, s.sname, t.avg_score avg_score from student s,(select sno, round(avg(score, 2 avg_score from sc group by sno having avg(score < 60 order by sno t where s.sno = t.sno;4.2、包括没有考试成绩的数据select g.* from (select s.sno, s.sname,nvl(t.avg_score, 0 avg_score from student s, (select sno, round(avg(score, 2 avg_score from sc group by sno order by sno t where s.sno = t.sno(+ g where g.avg_score < 60;5、查询所有同学的学生编号、学生姓名、选课总数、所有课程的总成绩5.1、查询所有成绩的(不含缺考的)。
oracle临时表空间的增删改查操作
操作oracle 临时表空间的增删改查1、查看临时表空间dba_temp_files视图v_$tempfile视图select tablespace_name,file_name,bytes/1024/1024 file_size,autoextensible from dba_temp_files;select status,enabled, name, bytes/1024/1024 file_size from v_$tempfile;--sys用户查看2、缩小临时表空间大小alter database tempfile 'D:\ORACLE\PRODUCT\' resize 100M;3、扩展临时表空间:方法一、增大临时文件大小:SQL> alter database tempfile ‘/u01/app/oracle/oradata/orcl/’ resize 100m;方法二、将临时数据文件设为自动扩展:SQL> alter database tempfile ‘/u01/app/oracle/oradata/orcl/’ autoextend on next 5m maxsize unlimited;方法三、向临时表空间中添加数据文件:SQL> alter tablespace temp add tempfile ‘/u01/app/oracle/oradata/orcl/’ size100m;4、创建临时表空间:SQL> create temporary tablespace temp1 tempfile ‘/u01/app/oracle/oradata/orcl/’ size 10M;5、更改系统的默认临时表空间:--查询默认临时表空间select from database_properties whereproperty_name='DEFAULT_TEMP_TABLESPACE';--修改默认临时表空间alter database default temporary tablespace temp1;所有用户的默认临时表空间都将切换为新的临时表空间:select username,temporary_tablespace,default_ from dba_users;--更改某一用户的临时表空间:alter user scott temporary tablespace temp;6、删除临时表空间删除临时表空间的一个数据文件:SQL> alter database tempfile ‘/u01/app/oracle/oradata/orcl/’ drop;删除临时表空间彻底删除:SQL> drop tablespace temp1 including contents and datafiles cascade constraints;7、查看临时表空间的使用情况GV_$TEMP_SPACE_HEADER视图必须在sys用户下才能查询GV_$TEMP_SPACE_HEADER视图记录了临时表空间的使用大小与未使用的大小dba_temp_files视图的bytes字段记录的是临时表空间的总大小SELECT ,total - used as "Free",total as "Total",roundnvltotal - used, 0 100 / total, 3 "Free percent"FROM SELECT tablespace_name, SUMbytes_used / 1024 / 1024 usedFROM GV_$TEMP_SPACE_HEADERGROUP BY tablespace_name temp_used,SELECT tablespace_name, SUMbytes / 1024 / 1024 totalFROM dba_temp_filesGROUP BY tablespace_name temp_totalWHERE =8、查找消耗资源比较的sql语句Select ,,,to_numberrtrim as Space,tablespace,segtype,sql_textfrom v$sort_usage su, v$parameter p, v$session se, v$sql swhere = 'db_block_size'and =and =and =order by ,9、查看当前临时表空间使用大小与正在占用临时表空间的sql语句select , segtype, blocks 8 / 1000 "MB", sql_textfrom v$sort_usage sort, v$session sess, v$sql sqlwhere =and =order by blocks desc;10、临时表空间组介绍1创建临时表空间组:create temporary tablespace tempts1 tempfile '/home/oracle/' size 2M tablespace group group1;create temporary tablespace tempts2 tempfile '/home/oracle/' size 2M tablespace group group2;2查询临时表空间组:dba_tablespace_groups视图select from dba_tablespace_groups;GROUP_NAME TABLESPACE_NAME------------------------------ ------------------------------GROUP1 TEMPTS1GROUP2 TEMPTS23将表空间从一个临时表空间组移动到另外一个临时表空间组:alter tablespace tempts1 tablespace group GROUP2 ;select from dba_tablespace_groups;GROUP_NAME TABLESPACE_NAME------------------------------ ------------------------------GROUP2 TEMPTS1GROUP2 TEMPTS24把临时表空间组指定给用户alter user scott temporary tablespace GROUP2;5在数据库级设置临时表空间alter database <db_name> default temporary tablespace GROUP2;6删除临时表空间组删除组成临时表空间组的所有临时表空间drop tablespace tempts1 including contents and datafiles;select from dba_tablespace_groups;GROUP_NAME TABLESPACE_NAME------------------------------ ------------------------------GROUP2 TEMPTS2drop tablespace tempts2 including contents and datafiles;select from dba_tablespace_groups;GROUP_NAME TABLESPACE_NAME11、对临时表空间进行shrink11g新增的功能--将temp表空间收缩为20Malter tablespace temp shrink space keep 20M;--自动将表空间的临时文件缩小到最小可能的大小ALTER TABLESPACE temp SHRINK TEMPFILE ’/u02/oracle/data/’;临时表空间作用Oracle临时表空间主要用来做查询和存放一些缓冲区数据;临时表空间消耗的主要原因是需要对查询的中间结果进行排序;重启数据库可以释放临时表空间,如果不能重启实例,而一直保持问题sql语句的执行,temp表空间会一直增长;直到耗尽硬盘空间;网上有人猜测在磁盘空间的分配上,oracle使用的是贪心算法,如果上次磁盘空间消耗达到1GB,那么临时表空间就是1GB;也就是说当前临时表空间文件的大小是历史上使用临时表空间最大的大小;临时表空间的主要作用:索引create或rebuild;Order by 或group by;Distinct 操作;Union 或intersect 或minus;Sort-merge joins;analyze.。
oracle基础SQL语句增删改
oracle基础SQL语句增删改⼀、SQL操作查询已创建的数据库:SELECT datname FROM pg_database;创建数据库:CREATE DATABASE wzxdb;删除数据库:DROP DATABASE wzxdb;查看已创建⽤户:SELECT usename FROM pg_user;创建⽤户并指定密码:CREATE USER wzx WITH PASSWORD '123456';删除⽤户:drop user wzx;修改⽤户密码:ALTER USER wzx WITH PASSWORD 'wzx123456'创建数据库并指定⽤户:CREATE DATABASE wzxdb WITH ENCODING='utf8' OWNER=wzx;查看已创建的表:SELECT tablename FROM pg_tables;创建表:创建表结构2:create table wzxstu (name varchar(80), -- 姓名age int, -- 年龄height int, -- ⾝⾼resg date -- 注册时间);删除表:drop table wzxstu;删除数据:delete from wzx;插⼊数据:insert into wzxstu1 values (2,'肥⾁', '男', 20, 2232.15, '2029-03-02');插⼊数据:insert into wzxstu1 (id,name,age, height, resg date) values(2,'得得', '男', 20, 22.15, '2019-03-02');查看版本信息:select version();查看当前搜索路径:show search_path;添加新模式到搜索路径:set search_path TO myschema,public;查询:select * from wzxstu1 limit 1;select count(*) from wzxstu1;select * from wzxstu1 where name like '%a%';。
oracle数据库增删改查基本语句举例
oracle数据库增删改查基本语句举例Oracle数据库是一种关系型数据库管理系统,是目前世界上使用最广泛的数据库之一。
在Oracle数据库中,常用的基本语句包括增加(INSERT)、删除(DELETE)、修改(UPDATE)和查询(SELECT),下面将分别介绍这些语句的使用方法,并给出相应的示例。
1. 增加(INSERT)语句INSERT语句用于向数据库表中插入新的数据记录。
其基本语法如下:INSERT INTO 表名 (列1, 列2, 列3, ...) VALUES (值1, 值2, 值3, ...);示例:向名为“employees”的表中插入一条新的员工记录:INSERT INTO employees (emp_id, emp_name, emp_salary) VALUES (1001, '张三', 5000);2. 删除(DELETE)语句DELETE语句用于从数据库表中删除指定的数据记录。
其基本语法如下:DELETE FROM 表名 WHERE 条件;示例:从名为“employees”的表中删除工资低于5000的员工记录:DELETE FROM employees WHERE emp_salary < 5000;3. 修改(UPDATE)语句UPDATE语句用于修改数据库表中的数据记录。
其基本语法如下:UPDATE 表名 SET 列名1 = 值1, 列名2 = 值2, ... WHERE 条件;示例:将名为“张三”的员工工资提高到6000:UPDATE employees SET emp_salary = 6000 WHERE emp_name = '张三';4. 查询(SELECT)语句SELECT语句用于从数据库表中检索数据记录。
其基本语法如下:SELECT 列1, 列2, ... FROM 表名 WHERE 条件;示例:查询所有工资超过5000的员工记录的姓名和工资:SELECT emp_name, emp_salary FROM employees WHERE emp_salary > 5000;5. 多表查询在实际应用中,常常需要从多个表中联合查询数据。
Oracle增删改(INSERT、DELETE、UPDATE)语句
Oracle增删改(INSERT、DELETE、UPDATE)语句Ø简介本⽂介绍 Oracle 中的增删改语句,即 INSERT、DELETE、UPDATE 语句的使⽤。
是时候展现真正的技术了,快上车:1.插⼊数据(INSERT)2.修改数据(UPDATE)3.删除数据(DELETE)4.使⽤ MERGE INTO 语句完成增删改操作5.回滚(rollback)的使⽤6.注意事项1.插⼊数据(INSERT)u语法:INSERT INTO TABLE_NAME [(column1[, column2, …]] VALUES(value1[, value2, …]);说明:1)INSERT 数据时可以指定列名,也可不指定列名。
如果不指定列名,必须为每⼀列都提供数据,并且顺序必须与列名的顺序⼀致;如果指定列名,提供的数据需要与指定的列名顺序⼀致;2)插⼊数据时数字类型的列可直接写⼊,字符或⽇期类型的列需要加单引号;3)插⼊的数据必须满⾜约束规则,主键和 NOT NULL 的列必须提供数据。
u插⼊数据的⽅式1)⾸先,可以在 PL/SQL Developer 中使⽤ FOR UPDATE 语句1.⾸先执⾏ SELECT 语句SELECT * FROM Table01 FOR UPDATE;2.点击锁表按钮3.编辑数据 -> 记⼊改变 -> 表解锁按钮4.最后点击提交l说明:低版本的 PL/SQL Developer 操作与以上类似。
2)使⽤ INSERT INTO 语句,插⼊⼀条数据INSERT INTO Table01(Id, Name) VALUES(2, '李四'); --指定所有列COMMIT; --必须执⾏提交命令提⽰:在平常开发中,建议显⽰指定插⼊的列名,有助于提⾼代码的可读性。
INSERT INTO Table01(Id) VALUES(3); --指定部分列,其他未指定的列表必须可以为空(即 NULL)COMMIT;INSERT INTO Table01 VALUES(4, '王五'); --不指定任何列,必须按顺序插⼊所有列COMMIT;3)使⽤ INSERT INTO SELECT 语句,插⼊多条数据INSERT INTO Table02 SELECT * FROM Table01; --将 Table01 中的所有数据插⼊ Table02 中(注意:可以指定插⼊的列;Table02 必须存在;可指定 Table01 的查询条件)COMMIT;4)另外,还可以使⽤ PL/SQL Developer 中使⽤变量的⽅式(该⽅式不怎么实⽤,不做详细介绍)INSERT INTO Table01 VALUE(&Id, &Name);5)同时插⼊多条(⽀持多表插⼊)INSERT ALLINTO Table01 VALUES(10, '张10')INTO Table01 VALUES(11, '张11')INTO Table02 VALUES(20, '李20') --同时插⼊ Table02SELECT * FROM DUAL;COMMIT;注意:1.INSERT ALL INTO 在效率上,⽐逐条执⾏ INSERT INTO 语句要⾼很多;2.在使⽤ INSERT ALL INTO 语句插⼊数据时,对于主键使⽤序列插⼊式,多条 INTO 会违反约束条件(即对于同⼀个序列的多条 INTO 会产⽣相同的序列号),所以使⽤序列插⼊时,并不适⽤使⽤ INSERT ALL INTO 同时插⼊多条数据!n注意事项:1.在插⼊数值(number)和字符(char)类型时,Oracle ⽀持数值与字符相互转换,例如:字符转数值:INSERT INTO Tab01(id)VALUES('12a');--ORA-01722:⽆效数字INSERT INTO Tab01(id)VALUES('123');--插⼊成功,结果为123INSERT INTO Tab01(id)VALUES('456.56');--插⼊成功,结果为457(四舍五⼊)数值转字符:INSERT INTO Tab01(name)VALUES(123);--插⼊成功,结果为123INSERT INTO Tab01(name)VALUES(123.56);--插⼊成功,结果为123.56提⽰:虽然 Oracle ⽀持这种转换,但是并不建议使⽤该⽅式去写⼊数据,不利于理解和阅读。
pythoncx_Oracle的基础使用方法(连接和增删改查)
pythoncx_Oracle的基础使⽤⽅法(连接和增删改查)问题使⽤python操作oracle数据库,获取表的某⼏个字段作为变量值使⽤。
使⽤Popen+sqlplus的⽅法需要对格式进⾏控制,通过流获取这⼏个字段值不简洁(个⼈观点……)。
(优点是能够使⽤sqlplus的⽅法直接访问sql⽂件,不需要考虑打开/关闭连接,并且通过流向⽂件中写⼊还挺好⽤的。
不过优点不是这次所关注的)使⽤cx-Oracle将查询结果返回为tuple格式,对返回结果的操作简洁,满⾜需求。
(要注意数据库连接创建与关闭、sql的编写、预处理与提交等等,看起来也不简洁(同样个⼈观点……))基础⽅法数据库连接1、使⽤tns串连接oracle_tns = cx_Oracle.makedsn('XXX.XXX.XXX.XXX', 1521,'oracleName')connectObj = cx_Oracle.connect('oracleUserName', 'password', oracle_tns)2、其他简洁⽅式db = cx_Oracle.connect('hr', 'hrpwd', 'localhost:1521/XE')db1 = cx_Oracle.connect('hr/hrpwd@localhost:1521/XE')数据库断开连接connectObj.close()建⽴游标cursorObj = connectObj.cursor()关闭游标cursorObj.close()增1、单条插⼊:sql = "INSERT INTO T_AUTOMONITOR_TMP(point_id) VALUES(:pointId)"cursorObj.prepare(sql)rown = cursorObj.execute(None, {'pointId' : pointId})mit()2、多条插⼊:sql = "INSERT INTO T_AUTOMONITOR_TMP(point_id) VALUES(:pointId)"cursorObj.prepare(sql)rown = cursorObj.executemany(None, recordList)mit()删sql = "DELETE FROM T_AUTOMONITOR_TMP t WHERE t.point_id = :pointId "cursorObj.prepare(sql)rown = cursorObj.execute(None, {'pointId' : pointId})mit()改sql = "UPDATE t_automonitor_other t\SET t.active = '2'\WHERE t.active = '1'\AND t.point_id = :pointId\"cursorObj.prepare(sql)cursorObj.execute(None, {'pointId' : pointId})mit()查sql = "SELECT t.describ FROM t_automonitor_tmp t WHERE t.point_id = :pointId"cursorObj.prepare(sql)cursorObj.execute(None, {'pointId' : pointId})Tips增、删、改操作都需要当前连接进⾏commit()若使⽤⼀个游标cursor进⾏N次查询,注意若再使⽤前N-1次查询结果可能会存在异常。
oracle数据库增删改使用注意事项
Oracle数据库是一种关系型数据库管理系统,被广泛应用于企业级应用的开发和管理中。
在使用Oracle数据库进行增删改操作时,需要注意一些事项,以保证数据的完整性和安全性。
下面将详细介绍Oracle数据库增删改操作的注意事项:一、增加数据时的注意事项:1. 插入数据时,需要确保插入的数据符合表结构的约束条件,包括主键、外键、唯一约束、非空约束等。
否则会出现插入失败的情况。
2. 在进行大批量数据插入时,建议使用批量插入的方式,例如使用INSERT INTO VALUES方式插入多条数据,而不是逐条插入,以提高插入效率。
3. 插入数据时,需要注意数据库的并发控制,确保插入的数据不会造成数据冲突和并发访问的问题。
二、删除数据时的注意事项:1. 删除数据前需要谨慎确认,确保删除操作不会对数据库的完整性和业务逻辑产生影响。
2. 在删除数据时,需要注意是否有其他表与当前表存在外键约束关系,避免因为删除主表数据而导致外键约束错误。
3. 删除大量数据时,建议使用DELETE语句加上条件进行删除,以避免误删整个表的数据。
三、修改数据时的注意事项:1. 在更新数据时,需要确保更新的数据符合表结构的约束条件,避免数据不一致性和错误的情况发生。
2. 修改数据时,需要考虑数据库的事务管理,确保更新操作的原子性和一致性。
3. 修改数据时,需要注意是否有其他表与当前表存在外键约束关系,以避免修改数据导致外键约束错误。
四、事务管理的注意事项:1. 在进行数据操作时,需要考虑事务管理,确保数据库操作的原子性、一致性、隔离性和持久性。
2. 在使用事务时,需要谨慎处理事务回滚和提交操作,以避免数据操作错误导致数据丢失或不一致的问题。
总结:在使用Oracle数据库进行增删改操作时,需要注意数据的完整性、约束条件、事务管理等方面的问题,以确保数据的安全性和一致性。
同时也需要考虑数据操作的效率和性能,以提高数据库的运行效率和可靠性。
希望以上内容能够帮助您更好地理解Oracle数据库增删改操作的注意事项。
oracle insert delete update 执行逻辑
oracle insert delete update 执行逻辑
执行逻辑如下:
Insert(插入):将一条或多条记录插入到数据库表中。
- 语法:INSERT INTO table_name (col1, col2, ...) VALUES (value1, value2, ...);
- 执行逻辑:检查插入的记录是否符合表定义的约束条件,如果符合则将记录插入到表中。
Delete(删除):从数据库表中删除一条或多条记录。
- 语法:DELETE FROM table_name WHERE condition;
- 执行逻辑:按照条件从表中查找需要删除的记录,并将其从表中删除。
Update(更新):修改数据库表中的一条或多条记录。
- 语法:UPDATE table_name SET col1=value1, col2=value2, ... WHERE condition;
- 执行逻辑:按照条件从表中查找需要修改的记录,并将指定字段的值更新为给定的新值。
在执行这些操作时,还需要注意以下一些重要的事项:
- 事务:这些操作通常在一个事务中执行,以确保数据的一致性和完整性。
- 锁:对于更新和删除操作,数据库会进行锁定,以防止其他会话对同一记录进行访问和修改。
- 触发器:在执行这些操作时,可能会触发由数据库中定义的触发器,这些触发器会在特定的操作发生时执行相关的逻辑。
- 日志:数据库会将这些操作的详细信息记录到事务日志中,以便在需要时进行恢复或回滚操作。
Oracle 10g数据库连接及增删改查
import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;public class JdbcConnection {public static void main(String[] args) {//getCon();// insertTbUser();updateUser();//query();//delTbUser();}public static void insertTbUser() {String url = "jdbc:oracle:thin:@localhost:1521:orcl";String driverClass = "oracle.jdbc.driver.OracleDriver";try {Class.forName(driverClass);Connection con = java.sql.DriverManager.getConnection(url, "mm","mm");// statement开辟一个通道java.sql.Statement st = con.createStatement();String insertSql = "insert intotb_user(userid,username,password)" +// 执行sql语句,返回操作所影响的条数。
"values(101,'zhuyu','zhuyu')";st.execute(insertSql);st.close();con.close();} catch (ClassNotFoundException e) {e.printStackTrace();} catch (SQLException e) {e.printStackTrace();}}public static void delTbUser(){String url="jdbc:oracle:thin:@localhost:1521:orcl";String driverClass="oracle.jdbc.driver.OracleDriver";Class.forName(driverClass);Connection con=DriverManager.getConnection(url,"mm","mm");java.sql.Statement st=con.createStatement();String delSql="delete from tb_user where userid='23'";st.execute(delSql);st.close();con.close();} catch (ClassNotFoundException e) {// TODO Auto-generated catch blocke.printStackTrace();} catch (SQLException e) {// TODO Auto-generated catch blocke.printStackTrace();}}public static void updateUser() {String url = "jdbc:oracle:thin:@localhost:1521:orcl";String driverClass = "oracle.jdbc.driver.OracleDriver";try {Class.forName(driverClass);Connection con = DriverManager.getConnection(url,"mm","mm");String updateSql = "update tb_user set password='1223423' where userid=5";Statement st = con.createStatement();st.execute(updateSql);st.close();con.close();} catch (ClassNotFoundException e) {e.printStackTrace();} catch (SQLException e) {e.printStackTrace();}}public static void query() {String url = "jdbc:oracle:thin:@localhost:1521:orcl";String driverClass = "oracle.jdbc.driver.OracleDriver";Connection con = null;Statement st = null;ResultSet rs = null;Class.forName(driverClass);con = DriverManager.getConnection(url, "mm", "mm");st = con.createStatement();String querySql = "select * from tb_user";rs = st.executeQuery(querySql);System.out.println("id\tusername\tpassword");while (rs.next()) {int id = rs.getInt("userid");String userName = rs.getString("username");String password = rs.getString("password");System.out.println(id + "\t"+ userName + "\t"+ password);}} catch (ClassNotFoundException e) {e.printStackTrace();} catch (SQLException e) {e.printStackTrace();}}public static void getCon() {String url = "jdbc:oracle:thin:@localhost:1521:orcl";String driverClass = "oracle.jdbc.driver.OracleDriver";// 加载驱动try {ng.Class.forName(driverClass).newInstance();// 获得连接java.sql.Connection con =java.sql.DriverManager.getConnection(url,"mm", "mm");System.out.println(con);} catch (InstantiationException e) {e.printStackTrace();} catch (IllegalAccessException e) {e.printStackTrace();} catch (ClassNotFoundException e) {e.printStackTrace();} catch (SQLException e) {e.printStackTrace();}}}。
Oracle存储过程的增、删、改、查的简单举例(精)
Oracle存储过程的增、删、改、查: Packages: create or replace packageemp_pags is type emp_cour is ref cursor;--定义游标类型的变量emp_cour-- --添加员工-- function saveEmp(e_ename emp.ename%TYPE, e_job emp.job%TYPE, e_sal emp.sal%TYPE, e_deptno emp.deptno%TYPE return integer;--定义返回类型-- --修改员工信息-- function updateEmp(e_empno emp.empno%TYPE, e_enameemp.ename%TYPE, e_job emp.job%TYPE, e_sal emp.sal%TYPE, e_deptnoemp.deptno%TYPE return integer;--定义返回类型-- --删除员工-- function deleteEmp(e_empno emp.empno%TYPE return integer ; --查询全部-- procedure queryAll(emps out emp_cour;--定义一个输出类型的参数emps-- --查询单条-- procedure queryById(e_empno in number,emps out emp_cour;--定义-- --两表查询-- procedure queryJoin(empJoin out emp_cour; end emp_pags; Package bodies: create or replace package body emp_pags is --添加员工-- function saveEmp(e_enameemp.ename%TYPE, e_job emp.job%TYPE, e_sal emp.sal%TYPE, e_deptnoemp.deptno%TYPE return integer is begin insert into emp (empno,ename,job,sal,deptno values (emp_sequence.nextval,e_ename,e_job,e_sal,e_deptno; commit; return 1; exception when others then return 0; end saveEmp; --修改员工信息-- function updateEmp(e_empno emp.empno%TYPE, e_ename emp.ename%TYPE, e_jobemp.job%TYPE, e_sal emp.sal%TYPE, e_deptno emp.deptno%TYPE return integer is begin update emp set ename = e_ename, job = e_job, sal = e_sal, deptno = e_deptno where empno = e_empno; commit; return 1; exception when others then return 0; end updateEmp; --删除员工-- function deleteEmp(e_empno emp.empno%TYPE return integer is begin delete from emp where empno = e_empno; commit; return 1;exception when others then return 0; end deleteEmp; --查询全部-- procedure queryAll(emps out emp_cour is begin open emps for --打开游标-- selectempno,ename,job,sal,deptno from emp; end queryAll; --查询单条-- 定义两个参数,第一个输入,第二个输出 procedure queryById(e_empno in number,emps out emp_cour is begin open emps for--打开游标-- select empno,ename,job,sal,deptno from emp where empno = e_empno; end queryById; --量表查询-- procedure queryJoin(empJoin outemp_couris begin open empJoin for select e.empno,e.ename,e.job,e.sal,d.dname,d.loc from emp e,dept d where e.deptno=d.deptno; end queryJoin; end emp_pags;。
Oracle操作数据库(增删改语句)
Oracle操作数据库(增删改语句) 对数据库的操作除了查询,还包括插⼊、更新和删除等数据操作。
后3种数据操作使⽤的 SQL 语⾔也称为数据操纵语⾔(DML)。
⼀、插⼊数据(insert 语句) 插⼊数据就是将数据记录添加到已经存在的数据表中,可以通过 insert 语句实现向数据表中⼀次插⼊⼀条记录,也可以使⽤ select ⼦句将查询结果批量插⼊数据表。
1、单条插⼊数据 语法:insert into table_name [ (column_name[,column_name2]...) ] values(express1[,express2]... )table_name:要插⼊数据的表名column_name1 和 column_name2:指定表的完全或部分列名称express1 和 express2 :表⽰要插⼊的值列表 EG:SQL > insert into dept(deptno,dname,loc) values(88,'Tony','tianjin') 注意: insert into 中指定添加数据的列,可以是数据表的全部列,也可以是部分列给指定列添加数据时,需要注意哪些列不能空;对于可以为空的列,添加数据可以不指定值;添加数据时,还应该数据添加数据和字段的类型和范围向表中所有列添加数据时,可以省略 insert into ⼦句后⾯的列表清单,使⽤这种⽅法时,必须根据表中定义列的顺序为所有的列提供数据添加数据时,还应该注意哪个字段是主键(主键的字段是不允许重复的),不能给主键字段添加重复的值 2、批量插⼊数据 insert 语句还可以⼀次向表中添加⼀组数据,可以使⽤ select 语句替换原来的 values ⼦句,语法如下:insert into table_name [ (column_name1[,column_name2...]...) ] selectSubquerytable_name:要插⼊数据的表名column_name1 和 column_name2 :表⽰指定的列名selectSubquery:任何合法的 select 语句,其所选列的个数和类型要与语句中的 column 对应。
C#连接oracle数据库执行简单的增删改查操作
以users表为例,有三个字段,自增长的编号id,int类型;名称name,nvarchar 类型,密码pwd,nvarchar类型首先在vs2005中引入System.Data.OracleClient;命名空间///<summary>///增加///</summary>///<param name="name">姓名</param>///<param name="pwd">密码</param>///<returns></returns>public int Insert(string name, string pwd){OracleConnection conn = new OracleConnection(@"Data Source=SBZX;UserID=simis;Password=zeda");//Data Source后面跟你数据库的名字,User ID为用户名,Password为密码 conn.Open();string sql = "insert into users(name,pwd) values(:name,:pwd)";OracleCommand cmd = new OracleCommand(sql, conn);OracleParameter parn = new OracleParameter(":name", name);cmd.Parameters.Add(parn);OracleParameter parp = new OracleParameter(":pwd", name);cmd.Parameters.Add(parp);int result = cmd.ExecuteNonQuery();//result接收受影响行数,也就是说result大于0的话表示添加成功conn.Close();cmd.Dispose();return result;}///<summary>///删除///</summary>///<param name="name">姓名</param>///<param name="pwd">密码</param>///<returns></returns>public int Update(int id){OracleConnection conn = new OracleConnection(@"Data Source=SBZX;UserID=simis;Password=zeda");//Data Source后面跟你数据库的名字,User ID为用户名,Password为密码 conn.Open();string sql = "delete from users where id=:id";OracleCommand cmd = new OracleCommand(sql, conn);OracleParameter pari = new OracleParameter(":id", id);cmd.Parameters.Add(pari);int result = cmd.ExecuteNonQuery();//result接收受影响行数,也就是说result大于0的话表示添加成功conn.Close();cmd.Dispose();return result;}///<summary>///修改///</summary>///<param name="name">姓名</param>///<param name="pwd">密码</param>///<returns></returns>public int Insert(string name, string pwd, int id){OracleConnection conn = new OracleConnection(@"Data Source=SBZX;UserID=simis;Password=zeda");//Data Source后面跟你数据库的名字,User ID为用户名,Password为密码 conn.Open();string sql = "update users set name=:name,pwd=:pwd where id=:id";OracleCommand cmd = new OracleCommand(sql, conn);OracleParameter parn = new OracleParameter(":name", name);cmd.Parameters.Add(parn);OracleParameter parp = new OracleParameter(":pwd", name);cmd.Parameters.Add(parp);OracleParameter pari = new OracleParameter(":id", id);cmd.Parameters.Add(pari);int result = cmd.ExecuteNonQuery();//result接收受影响行数,也就是说result大于0的话表示添加成功conn.Close();cmd.Dispose();return result;}///<summary>///查询///</summary>///<returns></returns>public DataTable Select(){OracleConnection conn = new OracleConnection(@"Data Source=SBZX;UserID=simis;Password=zeda");//Data Source后面跟你数据库的名字,User ID为用户名,Password为密码 conn.Open();string sql = "select * from users";OracleCommand cmd = new OracleCommand(sql, conn);OracleDataAdapter oda = new OracleDataAdapter(cmd);DataTable dt = new DataTable();oda.Fill(dt);conn.Close();cmd.Dispose();return dt;}方法写好后,下面举一个查询的例子,在form窗体中拖一个DataGridView,然后在Load方法中private void Form1_Load(object sender, EventArgs e){dataGridView1.DataSource = Select();}这样一运行,DataGridView中就会显示数据了。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
oracle 增删改查详细图文目录1用户模式 (2)2 查找数据(select) (3)2.1简单查询 (4)2.2 分组查询 (8)2.21 group by函数: 分类 (8)2.22 having子句 (9)2.3 连接 (9)2.3.1 表别名 (9)2.3.2 内连接 (10)2.3.3 外连接 (10)2.3.4 左外连接 (10)2.3.5 又外连接 (11)2.3.6 完全外连接 (11)2.3.7 自然连接 (12)2.3.8 自连接 (12)2.3.9交叉连接 (13)2.4 常用系统函数 (13)2.4.1 字符类函数 (13)2.4.2 数字类函数 (15)2.4.3 日期和时间类函数 (16)2.4.4 转换类函数 (16)2.4.5 聚集类函数 (17)2.5 子查询 (17)2.5.1 单行子查询 (17)2.5.2 多行子查询 (17)2.5.3 关联子查询 (18)3 插入数据(insert) (19)4更新数据(update) (20)5 删除数据(delete和truncate) (20)1用户模式1 模式和模式对象2 示例模式scott模式:是一系列逻辑结构或对象的集合模式对象是由用户创建的逻辑结构示例模式scott查询表select table_name from user_tables;如何在system模式下查询scott模式所拥有的数据表使用dba_tables数据表进入system模式conn system/passwordselect table_name from dba_tables where owner=’SCOTT’;部门表雇员表emp工资登记表salgrade工资补贴表bonus2 查找数据(select)selcet {[distinct|all] columns *}from {tables|views|other select} 用于指定数据来源,包括表,视图,和其他select语句[where conditions] 用于对检索的数据进行筛选,字句中不能用聚集函数如:avg(),max(),sum() [group by columns] 对检索结果分组显示与聚集函数一起使用时,group by创建组,聚集函数运算每组值[having conditions] 用于从使用group by 自居分组后的查询结果中筛选数据行,经常包括统计函数[order by columns [ASC|DESC]]对结果进行排序查询单个表中所有列在system模式下查询表表名前面要加上改表模式所属名称conn system/passwdselect * from scott.emp查询多个表中所有列scott 模式eg 同时查询dept和salgrade 表select * from dept,salgrade查询特定列select后面加想要查询的列名,用‘,’隔开eg:在scott模式下检索emp表中指定列(job,ename,empno)select job,ename,empno from emp为列指定别名eg:检索emp表员工编号,姓名和年基本公司,日基本工资信息。
sal = 月基本工资年基本工资= sal*12日基本工资= sal/30查询语句select empno,ename,sal*12,sal/30 from emp;使用列别名列名[AS]列别名ename as 员工姓名empno 员工编号select empno as “员工编号”,ename as “员工名称”’,sal*12 as ”年基本工资”sal/30 as “日基本工资”from emp;(注意引号为双引号)as可省略带有表达式的select子句select 语句中对于数字数据和日期都可以使用算术表达式,包括+-*/()eg:检索emp表的sal列,吧其值调整为原来的1.1倍select ename.sal,sal*(1+0.1) from emp;查询结果中包含重复行eg 显示emp表中job职务列消除重复:distinct 作用是消除重复内容,即一条完整数据全部是重复的,如果多行记录只有一列重复而其他列不重复,那么也是无法消除的;查询比较大的表时候尽量避免使用distinct关键字,因为结果进行排序,效率低egselect distinct deptno from emp;select deptno from dept;2.2 筛选查询选择行1 表达式比较where比较运算符格式: expression{=|<|<=|>|>=|<>|!=} expressioneg:查询emp中工资大于1500的数据记录2 模式匹配like谓词格式:string_expression [not] like string_expression[escape ‘escape_character’] like 运算符可以使用通配符’%’,’_”其中:‘%’:代表0个或者多个字符。
‘_’:代表一个且只能是一个字符。
注意(单引号)3 范围比较关键字:in (not in )between between and (not between and)在…中间4 空值比较查询emp表中无奖金的人select empno,ename,sal,job from emp where comm is null;2.2 分组查询2.21 group by函数: 分类经常与聚集函数一起使用,使用group by 子句和聚合函数可以实现对查询结果中每一组数据进行分类统计,所以在结果中每个数据都有一个与之对应的统计值select job,avg(sal),sum(sal),max(sal),count(job) from emp group by job;注意:select子句可以是被分组的列名和统计函数,不能是其他列名2.22 having子句having 子句通常与group by 子句一起使用,在完成对分组结果统计后,可以使用having子句对分组结果做进一步筛选eg:emp表中分组方式计算出每个部门平均工资,然后再通过having子句过滤出平局工资大于2000的记录信息排序order byorder by (order_by_expression [ASC](升序)|DESC(降序)])eg:select deptno,empno,ename from emp order by deptno,empno;2.3 连接2.3.1 表别名使用简短的表别名代替原有较长的表名称,这样就可以大大缩减语句的长度eg:通过deptno列来关联emp表和dept表,并检索这两个表中相关字段的信息别名设置在from 后面一旦使用别名就不能用表名了2.3.2 内连接内连接是一种常用的多表查询方式,一般使用关键字inner join 来实现,其中Inner关键字可以省略,当使用join关键字是语句指标是内连接操作,on 做连接条件2.3.3 外连接共分为三种:左外连接letf outer join 或left join又外连接right outer join 或者right join完全外连接full outer join 或full join2.3.4 左外连接左外连接的查询结果中不仅包含了满足连接条件的数据行,还包含了左边中不满足条件的数据行。
(右表需满足条件)eg:首先使用insert在emp表中插入新纪录(注意没有为deptno和dname列插入值,即他们的值为null),然后实现emp表和dept表之间通过deptno列进行左外连接结果如下图所示:左表中不满足条件的9527也显示出来了2.3.5 又外连接同理显示右表的全部信息dname为operations的右表数据数据在左表中没有记录,不满足条件,也显示出来了egfull join2.3.6 完全外连接将左右两表数据全部显示出来,将查询结果合并,并消除重复行。
如下图所示9527,operations数据行都显示出来了2.3.7 自然连接与内连接相似,检索多个表时,orcale会将第一个表列与第二个表中具有相同名称的列进行自动连接,自然连接不需要指定进行连接的列,由系统自动完成,自然连接使用”natural join’关键字自然连接中不能使用别名eg:在emp表中检索工资大于2000的记录,并实现emp表和dept表的自然连接2.3.8 自连接用于自参照表上显示上下级关系或层次关系,指在同一表中的不同列之间具有参照关系或者主从关系的表,例如emp表包含empno mgr列两者参照关系eg:查出所有管理者所管理的下属员工信息2.3.9交叉连接交叉连接就是不需要任何连接条件的连接,他是用cross join 关键字来实现。
他的结果集是笛卡尔积1 a2 b34该结果集为(1a 1b 2a 2b 3a 3b 4a 4b)4*2=8 (行数)2.4 常用系统函数2.4.1 字符类函数ASCLL(C)函数和CHR(i)函数concat(s1,s2)函数s2连接到s1后面INITCAP(s)函数首字母大写函数INSTR(S1,S2[,I][,J])函数LENGTH 返回字符串长度lower upper 将字符串全部换成小写,大写ltrim(s1,s2)函数,删除左边字符串s2rtrim(s1,s2)函数删除右边字符串s2trim(s1,s2)函数删除两边字符串s2replace(s1,s2[,s3] 函数将s1中的s2函数替换成s3;substr(s,I,[j])截取字符串从s中的l位置截取数据长度为j2.4.2 数字类函数abs(n)返回绝对值ceil(n) 返回大于或者等于数值n的最小整数floor(n)返回小鱼或者等于n的最大整数cos(n)返回n的余弦值,n为弧度exp(n)返回e的n次幂e=2.71828183log(n1,n2)返回以n1为底n2的对数mod(n1,n2) 返回n1/n2的余数power(n1,n2)返回n1的n2次方round(n1,n2)返回n1小说点后n2位sign(n)若n为负数则返回-1,若n为正数,则返回1,若n=0 则返回0sig(n) 返回n的正弦值,n为弧度sqrt(n)返回n的平方根n为弧度trunc(n1,n2)返回结尾到n2位小数的n1的值2.4.3 日期和时间类函数add_month(n1,n2)返回当前日期加上n2个月后的日期last_day(n)返回当前月最后一天month_between(d1,d2)返回d1和d2中间的数目new_time(d1,t1,t2)sysdate 返回系统当前日期2.4.4 转换类函数to_char(x[,format]) 将表达式转换成字符串to_date[s,format[lan]] 将字符串转换成date类型,format表示字符串格式lan 表示使用的语言to_number(s,format[lan])返回字符串s代表的数字,返回值按照format格式显示format表示字符串格式,lan表示语言2.4.5 聚集类函数avg(x[distinct|all]) 计算选择列表的平均值count()查询记录数max()查询最大值min()最小值sum()返回总和variance()统计方差stddev()返回列表项目的标准方差2.5 子查询2.5.1 单行子查询单行子查询指返回一行数据的子查询语句,当在where子句中引用单行子查询时候,可以使用单行比较运算符(=,>,<,>=,<=,<>)eg:在emp表中,查询出既不是最高工资,也不是最低工资的员工信息2.5.2 多行子查询多行子查询指返回多行数据的子查询语句,当在where子句中使用多行子查询时候,必须使用多行比较符(in,any,all);ineg:在emp表中,查询不是销售部门(sales)的员工信息any:只要匹配一个查询结果即可eg:查询工资大于部门编号是10的任意的一个员工的员工工资的员工信息;select empno,ename,salfrom empwhere sal > any (select sal from emp where deptno =10) and deptno <> 10;and 所有,满足所有条件eg:查询工资大于部门编号30的所有员工工资的员工信息select empno,ename,salfrom empwhere sal > all (select max(sal) from emp where deptno=30);2.5.3 关联子查询有一些查询中内外查询需要相互依赖。