当前位置: 首页 > news >正文

Oracle数据库入门大全

oracle数据库

Oracle 数据库、实例、用户、表空间、表之间的关系

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pSv0SArH-1675906973035)(vx_images/573695710268888.png =676x)]

数据库

数据库是数据集合。Oracle是一种数据库管理系统,是一种关系型的数据库管理系统。
通常情况了我们称的“数据库”,并不仅指物理的数据集合,他包含物理数据、数据库管理系统。也即物理数据、内存、操作系统进程的组合体。
查询当前数据库名:

select name from v$database;

数据库实例

用Oracle官方描述:实例是访问Oracle数据库所需的一部分计算机内存和辅助处理后台进程,是由进程和这些进程所使用的内存(SGA)所构成一个集合。
其实就是用来访问和使用数据库的一块进程,它只存在于内存中。就像Java中new出来的实例对象一样。
我们访问Oracle都是访问一个实例,但这个实例如果关联了数据库文件,就是可以访问的,如果没有,就会得到实例不可用的错误。
实例名指的是用于响应某个数据库操作的数据库管理系统的名称。她同时也叫SID。实例名是由参数instance_name决定的。
查询当前数据库实例名:

select instance_name from v$instance;

数据库实例名(instance_name)用于对外部连接。在操作系统中要取得与数据库的联系,必须使用数据库实例名。比如我们作开发,要连接数据库,就得连接数据库实例名:
jdbc:oracle:thin:@localhost:1521:orcl(orcl就为数据库实例名)
一个数据库可以有多个实例,在作数据库服务集群的时候可以用到。

表空间

Oracle数据库是通过表空间来存储物理表的,一个数据库实例可以有N个表空间,一个表空间下可以有N张表。
有了数据库,就可以创建表空间。
表空间(tablespace)是数据库的逻辑划分,每个数据库至少有一个表空间(称作SYSTEM表空间)。为了便于管理和提高运行效率,可以使用一些附加表空间来划分用户和应用程序。例如:USER表空间供一般用户使用,RBS表空间供回滚段使用。一个表空间只能属于一个数据库。
创建表空间语法:

Create TableSpace 表空间名称
DataFile 表空间数据文件路径
Size 表空间初始大小
Autoextendon

如:

create tablespace db_test
datafile 'D:\oracle\product\10.2.0\userdata\db_test.dbf'
size 50m
autoextend on;

查看已经创建好的表空间:

select d.username from dba_users d;

查看当前用户的缺省表空间:

select  username,default_tablespace from user_users;

用户

Oracle数据库建好后,要想在数据库里建表,必须先为数据库建立用户,并为用户指定表空间。
上面我们建好了数据库和表空间,接下来建用户:
创建新用户:

CREATE USER 用户名
IDENTIFIEDBY 密码
DEFAULT TABLESPACE 表空间(默认USERS)
TEMPORARY TABLESPACE 临时表空间(默认TEMP)

如:

CREATE USER wpp IDENTIFIED BY 1234 DEFAULT TABLESPACE SYSTEM TEMPORARY TABLESPACE TEMP;

(这里临时表空间不能使用我们创建的db_test,不知为何?)
有了用户,要想使用用户账号管理自己的表空间,还得给它分权限:

GRANT CONNECT TO wpp;
GRANT RESOURCE TO wpp;
GRANT dba TO wpp;--dba为最高级权限,可以创建数据库,表等。

查看数据库用户:

select username from dba_users;

为其设置了connect权限之后,就可以登录了
connect wpp

基本语法

create database {ORACLE_NAME}   --> # 数据库名,一般与ORACLE_SID相,创建数据库
show user 查看当前用户  
create user username identified by password; 创建新用户
create tablespace tablespacename datafile ‘d:\data.dbf’ size xxxm;创建表空间 ,例如

create tablespace animal  datafile 'animal.dbf' size 10M;

tablespacename:表空间的名字
d:\data.dbf’:表空间的存储位置
xxx表空间的大小,m单位为兆(M)
alter user username default tablespace tablespacename; 将空间分配给用户: 将名字为tablespacename的表空间分配给username
grant create session,create table,unlimited tablespace to zxin; 给用户授权

conn username/password; 以自己创建的用户登录,登录之后创建表即可。
select tablespace_name from user_tablespaces; 查询当前用户拥有的所的有表空间
select tablespace_name, table_name from user_tables where tablespace_name = ‘ZXINSYS’; 查看表空间下的表
select * from tab where tabtype=‘TABLE’  查看当前用户下的表
desc dept             察看表dept的结构
quit/exit             退出
clear screen          清除屏幕
select * from vversion;查看当前Oracle的版本connsystem/welcomeselect∗fromvversion;查看当前Oracle的版本 conn system/welcome select * from vversion;查看当前Oracle的版本connsystem/welcomeselectfromvtablespace; 查看表空间
grant create any table to zxinsys; 给用户添加存储过程权限
show errors; 查看上一个语句的错误信息

注意:
是Oracle的对象名字最多是30个字符,不能超过30

例子
create database zxin;
create user zxinsys identified by Aa#12345;
create tablespace zxinsys datafile ‘zxinsys.dbf’ size 10M;
alter user zxinsys default tablespace zxinsys;
grant create session,create table,unlimited tablespace to zxinsys;
conn zxinsys/Aa#12345;

create tablespace testOracle datafile ‘oracle.dbf’ size 1M;
create table testTable(id varchar(3)) tablespace testOracle;
select tablespace_name, table_name from user_tables
where tablespace_name = ‘TESTORACLE’;

基础入门

创建表

CREATE TABLE schema_name.table_name (column_1 data_type column_constraint,column_2 data_type column_constraint,...table_constraint);

插入表

INSERT INTO table_name (column_1, column_2, column_3, ... column_n)
VALUES( value_1, value_2, value_3, ..., value_n);

if else

标准sql规范
复制代码

if a=..  then语句
end if;

2、decode函数

DECODE的语法:

DECODE(value,if1,then1,if2,then2,if3,then3,...,else)

表示如果value等于if1时,DECODE函数的结果返回then1,…,如果不等于任何一个if值,则返回else。
3、case when

case when a='1'then 'xxxx'when a='2' then 'ssss'
else'zzzzz'
end as

注意点:

1、以CASE开头,以END结尾
2、分支中WHEN 后跟条件,THEN为显示结果
3、ELSE 为除此之外的默认情况,类似于高级语言程序中switch case的default,可以不加
4、END 后跟别名

存储过程的创建

Oracle存储过程包含三部分:过程声明,执行过程部分,存储过程异常。

无参存储过程语法

create or replace procedure NoParProas  //声明;begin // 执行;exception//存储过程异常;end;

带参存储过程实例

create or replace procedure queryempname(sfindno emp.empno%type)
assName emp.ename%type;sjob emp.job%type;
begin....
exception....
end;

带参数存储过程含赋值方式

create or replace procedure runbyparmeters(isal in emp.sal%type,sname out varchar,sjob in out varchar)asicount number;begin select count(*) into icount from emp where sal>isal and job=sjob;if icount=1 then ....else....end if;
exceptionwhen too_many_rows theDBMS_OUTPUT.PUT_LINE('返回值多于1行');when others then DBMS_OUTPUT.PUT_LINE('在RUNBYPARMETERS过程中出错!');
end;

其中参数IN表示输入参数,是参数的默认模式。
OUT表示返回值参数,类型可以使用任意Oracle中的合法类型。
OUT模式定义的参数只能在过程体内部赋值,表示该参数可以将某个值传递回调用他的过程
IN OUT表示该参数可以向该过程中传递值,也可以将某个值传出去。

存储过程创建语法

create [or replace] procedure 存储过程名(param1 in type,param2 out type)
as
变量1 类型(值范围);
变量2 类型(值范围);
BeginSelect count(*) into 变量1 from 表A where列名=param1;If (判断条件) thenSelect 列名 into 变量2 from 表A where列名=param1;Dbms_output.Put_line(‘打印信息’);Elsif (判断条件) thenDbms_output.Put_line(‘打印信息’);ElseRaise 异常名(NO_DATA_FOUND);End if;
ExceptionWhen others thenRollback;
End;

param1为输入参数,param2为输出参数,在as里分别设置param1和param2的值范围,如:

create or replace procedure zxinsys.proc_insert_operpwdhistory (param1 in varchar2,param2 in varchar2,param3 in varchar2 default 'pwd', param4 out varchar2 default '0')
asiparam1   number(10);iparam2   number(10);iparam3   number(10);iparam4   number(10);

select count(*) into 变量为将获得的值传入参数,在后面可能会调用

基本结构

CREATE OR REPLACE PROCEDURE 存储过程名字
(参数1 IN NUMBER,参数2 IN NUMBER
) IS
变量1 INTEGER :=0;
变量2 DATE;
BEGIN--执行体
END 存储过程名字;

SELECT INTO STATEMENT

将select查询的结果存入到变量中,可以同时将多个列存储多个变量中,必须有一条记录,否则抛出异常(如果没有记录抛出NO_DATA_FOUND)
例子:

BEGIN
SELECT col1,col2 into 变量1,变量2 FROM typestruct where xxx;
EXCEPTION
WHEN NO_DATA_FOUND THENxxxx;
END;

事务嵌套

一般使用savepoint来进行事务部分回滚
SAVEPOINT t1;
回滚rollback to savepoint t1

查看存储过程

SELECT text
FROM user_source
WHERE NAME = ‘存储过程名’
ORDER BY line;

删除存储过程

DROP PROCEDURE procedure_name;

调用存储过程

exec pro_name(参数1…);
call pro_name(参数1…);
exec是sqlplus命令,只能在sqlplus中使用;call为SQL命令,没有限制.
存储过程没有参数时,exec可以直接跟过程名(可以省略()),但call则必须带上().
另一种方法

beginprocedure;--procedure是存储过程名
end;

Oracle程序调用过程让我们来看看如何调用上面创建的过程。参考以下示例代码

BEGINinsertuser(101,'Maxsu');dbms_output.put_line('record inserted successfully');
END;

返回参数

beginqueryEmpInformation(eno => 7839,pename => :pename,psal   => :psal,pjob   => :pjob);   --  =>也表示赋值的意思
end;
call
exec

一般使用的方法:pjob可以作为输入参数直接放入,也可以直接打印结果

set serveroutput on;
declare
pjob number;
begin
DBMS_OUTPUT.PUT_LINE('测试空格情况');
zxinsys.proc_remove_res_definition('');
DBMS_OUTPUT.PUT_LINE('测试null情况');
zxinsys.proc_remove_res_definition(null);
end;
/
show errors procedure zxinsys.proc_remove_res_definition;

常用语句

to_char(sysdate,‘YYYY.MM.DD HH24:MI:SS’)
insert into 表名 select * from 表 where 条件;
v_date date 日期字段
v_date := to_date(v_updatedate,‘YYYY-MM-DD hh24:mi:ss’);将字符串转化为时间格式
as与is的区别
循环语句
for vRows in
LOOP
循环体
end LOOP
cursor

Case When

格式语法

casewhen 条件1 then action1when 条件2 then action2when 条件3 then action3when 条件N then actionNelse action
end

判断现在是几月

SQL> select case substr('20181118',5,2)2  when '08' then '8yue'3  when '09' then '9yue'4  when '10' then '10yue'5  when '11' then '11yue'6  when '12' then '12yue'7  else 'other'8  end9  from dual;CASESUBSTR('201
---------------
11yue

选出等级的值

select grade from
(select sno,casewhen score >=90 then 'A'when score >=80 then 'B'when score >=70 then 'C'when score >=60 then 'D'else 'F'end as grade9   from score);GRADE
----------
D
C
B
A

GROUP BY CASE WHEN 用法

SELECT  
CASE WHEN salary <= 500 THEN '1'  
WHEN salary > 500 AND salary <= 600  THEN '2'  
WHEN salary > 600 AND salary <= 800  THEN '3'  
WHEN salary > 800 AND salary <= 1000 THEN '4'  
ELSE NULL END salary_class, -- 别名命名
COUNT(*)  
FROM    Table_A  
GROUP BY  
CASE WHEN salary <= 500 THEN '1'  
WHEN salary > 500 AND salary <= 600  THEN '2'  
WHEN salary > 600 AND salary <= 800  THEN '3'  
WHEN salary > 800 AND salary <= 1000 THEN '4'  
ELSE NULL END;  

拼接字符串

1、拼接字符串

1)可以使用“||”来拼接字符串

1 select ‘拼接’||‘字符串’ as str from dual
2)通过concat()函数实现

1 select concat(‘拼接’, ‘字符串’) as str from dual
注:oracle的concat函数只支持两个参数的方法,即只能拼接两个参数,如要拼接多个参数则嵌套使用concat可实现,如:

1 select concat(concat(‘拼接’, ‘多个’), ‘字符串’) from dual
concat与EXECUTE IMMEDIATE 用法
需要注意:
在Oracle中,CONCAT函数将只允许您将两个值连接在一起。如果需要连接多个值,那么我们可以嵌套多个CONCAT函数调用。

SELECT CONCAT(CONCAT('A', 'B'),'C')
FROM dual;
-- Result: 'ABC'

以上这个例子将3个值连接在一起并返回’ABC’字符串值。

SELECT CONCAT(CONCAT(CONCAT('A', 'B'),'C'),'D')
FROM dual;
- Result: 'ABCD'

这个例子将连接4个值并返回’ABCD’。

连接单引号
由于CONCAT函数中的参数由单引号分隔,因此如何在CONCAT函数的结果中添加单引号字符并不简单。

我们来看一个相当简单的例子,它展示了如何使用CONCAT函数向结果字符串添加单引号。

SELECT CONCAT('Let''s', ' learn Oracle')
FROM dual;
-- Result: Let's learn Oracle

由于参数包含在单引号中,因此在引号内使用2个额外的单引号来表示生成的连接字符串中的单引号。

EXECUTE IMMEDIATE

它解析并马上执行动态的SQL语句或非运行时创建的PL/SQL块.动态创建和执行SQL语句性能超前,EXECUTE IMMEDIATE的目标在于减小企业费用并获得较高的性能,较之以前它相当容易编码
execute immediate
例如:

 sqlstr:='select * from zxinsys.oper_information2 where operid =' || '1';execute immediate sqlstr;

for loop的用法

为了对游标进行遍历,可以使用 FOR LOOP 语句实现,语法如下:
FOR record IN cursor_name
LOOP
process_record_statements;
END LOOP;
对游标进行 FOR LOOP 遍历时,省去了 %ROWTYPE 的声明,循环每次从查询结果中取出一行结果,当取完后,跳出循环。

打印输出

dbms_output.put_line(‘end’)

oracle查询某表是否存在,某字段是否存在某表

select count(0) as v_max_modify
from user_tab_columns
where UPPER(column_name)=‘max_modify’ AND TABLE_NAME = ‘zxin_pwdsafeset’;
SELECT table_name, column_name, data_type FROM all_tab_cols WHERE table_name = ‘ZXIN_PWDSAFESET’ AND UPPER(column_name) =‘MAX_MODIFY’;
SELECT * FROM user_tab_columns WHERE TABLE_NAME = ‘zxin_pwdsafeset’;
select * from dba_tab_columns where Table_Name=‘zxin_pwdsafeset’;
select * from all_tab_columns ;
SELECT count(*) FROM zxin.zxin_pwdsafeset;
select count(1) as b from all_tables where TABLE_NAME = ‘zxin_pwdsafeset’ and OWNER=‘select user from zxin’;

注意一定要大写,最后能成功的:
SELECT table_name, column_name, data_type FROM all_tab_cols WHERE table_name = ‘ZXIN_PWDSAFESET’ AND UPPER(column_name) =‘MAX_MODIFY’;

表空间与表

查询表空间所有表:select table_name from all_tables where TABLESPACE_NAME=‘表空间’ 表空间名字一定要大写。
查询表所在的表空间:select * from user_tables where table_name=‘表名’;表名一定要大写;

if insert的用法

Oracle 动态游标实现动态sql循环

CURSOR <游标名称> IS <游标名称>%ROWTYPE;

复制内容到剪贴板/ 程序代码
CURSOR <游标名称> IS
<游标名称>%ROWTYPE;
BEGINOPEN <游标名称>LOOPFETCH <游标名称> INTO ;EXIT WHEN <游标名称>%NOTFOUND;<其它要执行的代码>END LOOP;CLOSE <游标名称>;
END <存储过程名称>;
/

实例:

create or replace procedure P_TEST_SQL is
TYPE ref_cursor_type IS REF CURSOR;  --定义一个动态游 
tablename varchar2(200) default 'ess_client';
v_sql varchar2(1000);
mobile varchar2(15);
usrs ref_cursor_type;
begin--使用连接符拼接成一条完整SQLv_sql := 'select usrmsisdn from '||tablename||' where rownum < 11';  --打开游标open usrs for v_sql ;loopfetch usrs into mobile;exit when usrs%notfound;insert into tmp(usrmsisdn) values(mobile);end loop;close usrs;commit;
end P_TEST_SQL;

Cursor FOR Loop格式

Create or REPLACE PROCEDURE <存储过程名称> IS
CURSOR <游标名称> IS
BEGINFOR IN <游标名称>LOOP<其它要执行的代码>END LOOP;
END <存储过程名称>;
/

实例

TRUNCATE TABLE loop_test;
DECLARE
CURSOR ao_cur ISSelect SUBSTR(object_name,1,5) FIRSTFIVEFROM all_objsWhere SUBSTR(object_name,1,5) BETWEEN 'N' AND 'W';
BEGINFOR ao_rec IN ao_cur LOOPInsert INTO loop_test VALUES (ao_rec.firstfive);END LOOP;COMMIT;
END;
/Select COUNT(*) FROM loop_test;

oracle游标的用法

Oracle游标是通过关键字CURSOR的来定义一组Oracle查询出来的数据集,类似数组一样,把查询的数据集存储在内存当中,然后通过游标指向其中一条记录,通过循环游标达到循环数据集的目的。
Oracle游标可以分为显式游标和隐式游标两种之分。

显式游标:指的是游标使用之前必须得先声明定义,一般是对查询语句的结果事进行定义游标,然后通过打开游标循环获取结果集内的记录,或者可以根据业务需求跳出循环结束游标的获取。循环完成后,可以通过关闭游标,结果集就不能再获取了。全部操作完全由开发者自己编写完成,自己控制。

隐式游标:指的是PL/SQL自己管理的游标,开发者不能自己控制操作,只能获得它的属性信息。

声明游标:

声明游标是给游标命名并给游标关联一个查询结果集,具体声明语法如下:

declare cursor cursor_name(游标名)
is select_statement(查询语句);

打开游标:

游标声明完,可以通过打开游标打开命令,初始化游标指针,游标一旦打开后,游标对应的结果集就是静态不会再变了,不管查询的表的基础数据发生了变化。打开游标的命令如下:

open cursor_name;

读取游标中数据:

读取游标中的数据是通过fetch into语句完成,把当前游标指针指向的数据行读取到对应的变量中(record 变量)。游标读取一般和循环LOOP一起使用,用于循环获取数据集中的记录。

fetch cursor_name into record变量

关闭游标:

游标使用完,一定要关闭游标释放资源。关闭后,该游标关联的结果集就释放了,不能够再操作了,命令如下:

close cursor_name;

案例

创建一个游标循环打印学生信息表中学生基本信息,代码如下:

declare--定义游标cursor cur_xsjbxx isselect * from stuinfo order by stuid;--定义记录变量  ls_curinfo cur_xsjbxx%rowtype;
beginopen cur_xsjbxx;--打开游标loopFETCH cur_xsjbxxINTO ls_curinfo;--获取记录值EXIT WHEN cur_xsjbxx%NOTFOUND;dbms_output.put_line('学号:' || ls_curinfo.stuid || ',姓名:' ||ls_curinfo.STUNAME);end loop;close cur_xsjbxx;--关闭游标
end;

调试技巧

show errors procedure 存储过程名字; 可以列出存储过程出现的问题
SET SETVEROUTPUT ON 加上这句才能使得输出语句生效

注意

您不能在 PL/SQL 块中将 DDL 作为静态 SQL 发出。如果要将这些命令放在 PL/SQL 块中,则需要使用动态 SQl

插入语句之前查看是否存在

insert
when (not exists (select 1 from form where formid =xxx)) then
into form(formid) select XXX from dual

insert into zxinsys.portal_sysparam
USING (SELECT 1 from zxinsys.portal_sysparam) s
ON (d.id = s.id)
WHEN MATCHED THEN UPDATE SET d.name = s.name
WHEN NOT MATCHED THEN INSERT (id, name) VALUES (s.id, s.name);
insert when (not exists (select 1 from zxinsys.portal_sysparam where param_name =1)) then
into (param1,param2);
SELECT when (not exists (select 1 from zxinsys.portal_sysparam where param_name =‘SPAN_SHOW_DEFAULT’)) then
INSERT into zxinsys.portal_sysparam VALUES(‘test’);

insert when (not exists (select 1 from zxinsys.portal_sysparam where param_name =‘SPAN_SHOW_DEFAULT’)) then
into zxinsys.portal_sysparam(param_name,param_value,param_desc,paramgroup,description) select ‘BlsSecretKey’,v_param_value,‘Bls Secret Key ENABLE’,‘BlsSecretKey’,‘是否启用BlsSecretKey服务的开关 false: 关闭 true:开启’ from dual

对列进行操作

增加一列:

alter table emp4 add test varchar2(10);

修改一列:

alter table emp4 modify test varchar2(20);

删除一列:

alter table emp4 drop column test;

Oracle创建视图(View)

视图:是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改。视图基于的表称为基表,Oracle的数据库对象分为五种:表,视图,序列,索引和同义词。
视图是存储在数据字典里的一条select语句。通过创建视图可以提取数据的逻辑上的集合或组合。
视图的优点:
1.对数据库的访问,因为视图可以有选择性的选取数据库里的一部分。
2.用户通过简单的查询可以从复杂查询中得到结果。
3.维护数据的独立性,试图可从多个表检索数据。
4.对于相同的数据可产生不同的视图。
视图分为简单视图和复杂视图:
1、简单视图只从单表里获取数据,复杂视图从多表;
2、简单视图不包含函数和数据组,复杂视图包含;
3、简单视图可以实现DML操作,复杂视图不可以。
语法结构:创建视图

CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW view_name[(alias[, alias]...)]AS subquery[WITH CHECK OPTION [CONSTRAINT constraint]][WITH READ ONLY]

语法解析:

OR REPLACE :若所创建的试图已经存在,则替换旧视图;

FORCE:不管基表是否存在ORACLE都会自动创建该视图(即使基表不存在,也可以创建该视图,但是该视图不能正常使用,当基表创建成功后,视图才能正常使用);

NOFORCE :如果基表不存在,无法创建视图,该项是默认选项(只有基表都存在ORACLE才会创建该视图)。

alias:为视图产生的列定义的别名;

subquery :一条完整的SELECT语句,可以在该语句中定义别名;

WITH CHECK OPTION :插入或修改的数据行必须满足视图定义的约束;

WITH READ ONLY :默认可以通过视图对基表执行增删改操作,但是有很多在基表上的限制(比如:基表中某列不能为空,但是该列没有出现在视图中,则不能通过视图执行insert操作),WITH READ ONLY说明视图是只读视图,不能通过该视图进行增删改操作。现实开发中,基本上不通过视图对表中的数据进行增删改操作。

使用drop view 命令删除视图

格式:
drop view 视图名

利用视图操作基本表

—添加数据行(直接影响基本表)
insert into tb_user_view1 values(8,‘insert’,5)
—修改数据行(影响基本表)
update tb_user_view1 set username=‘update’ where bh=3
—删除数据行(直接影响基本表)
delete from tb_user_view1 where bh=2
多表关联创建视图
格式:CREATE OR REPLACE FORCE VIEW 视图名(列表名1,列表名2,……,列表名n)as select 查询子句
例子:
CREATE OR REPLACE FORCE VIEW tb_username_address (bh, username, address_id, address) AS
SELECT u.bh,u.username,a.bh,a.address FROM tb_user u,tb_address a WHERE u.address_id=a.bh
修改视图
格式:CREATE OR REPLACE FORCE VIEW 视图名(列表名1,列表名2,……,列表名n)as select 查询子句
例子:
CREATE OR REPLACE FORCE VIEW tb_username_address (bh, username, address_id, address) AS
SELECT u.bh,u.username,a.bh,a.address FROM tb_user u,tb_address a WHERE u.address_id=a.bh and a.address=‘xinxiang’
drop view 命令删除视图

oracle中sql%rowcount的作用

sql%rowcount来判断是否更新了记录的状态
sql%rowcount只会记录未被提交的最后一条SQL语句的影响行数。这点很重要,如果想统计多个sql的合计影响行数,就必须在每个sql后面,用一个变量保存当前的sql%rowcount。

commit

commit(提交)的作用
在数据库的插入、删除和修改操作时,只有当事务在提交到数据库时才算完成。在Oracle 数据库中,
在事务提交前,只有操作数据库的这个人才能有权看到所做的事情,别人只有在最后提交完成时才能看见。
如果没有提交的话,则数据会保存到内存中去,但是并没有保存到数据文件。
它执行的时候,你不会有什么感觉。commit在数据库编程的时候很常用,当你执行DML操作时,数据库并不会立刻修改表中数据,这时你需要commit,数据库中的数据就立刻修改了,如果在没有commit之前,就算你把整个表中数据都删了,如果rollback的话,数据依然能够还原。
测试语句

 begin
<<fst_loop>>
loopdbms_output.put_line('v_rlt = '||v_rlt);insert into wpp.user1 values(v_rlt);dbms_output.put_line('influence row number'||sql%rowcount);select count(*) into vcount  from wpp.user1;dbms_output.put_line('select='||vcount);v_rlt:=v_rlt+1;exit fst_loop when v_rlt > 10;rollback 或者 commit;
end loop;
dbms_output.put_line('nums:'||sql%rowcount);dbms_output.put_line('LOOP循�m~N�已�[m~O�S�~_�A');
end;
/
select * from wpp.user1;

日期与函数

SELECT EXTRACT( YEAR FROM SYSDATE ) FROM DUAL;
select extract (month from sysdate)*30.1+extract (day from sysdate) day from dual;
select floor(extract (hour from sysdate)*30.1 +extract (day from sysdate))day from dual;

出现的问题

ORA-00937: not a single-group group function
SCOTT@PROD> select deptno,sum(sal) from emp;
select deptno,sum(sal) from emp
ERROR at line 1:
ORA-00937: not a single-group group function
原因:这句话不会运行,因为deptno要求每行都显示,而sum要求统计后再显示,违反了原则。在有组函数的select中,不是组函数的列,一定要放在group by子句中。
正确语句:select deptno,sum(sal) from emp group by deptno;

语句concat

CONCAT()函数在Oracle中可以用于将两个字符串连接在一起,那么CONCAT()函数的语法及使用方法是什么呢?下面一起来看看。
CONCAT()函数语法
CONCAT( string1, string2 )
string1:第一个要连接的字符串。
string2:第二个要连接的字符串。
返回值
CONCAT函数返回string1连接string2后的一个字符串值。
适用版本
CONCAT()函数可用于以下版本的Oracle:

Oracle 12c、 Oracle 11g、 Oracle 10g、 Oracle 9i

在Oracle中,CONCAT函数将只允许您将两个值连接在一起。如果需要连接多个值,那么我们可以嵌套多个CONCAT函数调用。

相关文章:

Oracle数据库入门大全

oracle数据库 Oracle 数据库、实例、用户、表空间、表之间的关系 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pSv0SArH-1675906973035)(vx_images/573695710268888.png 676x)] 数据库 数据库是数据集合。Oracle是一种数据库管理系统&#xff…...

C语言操作符详解(下)

提示&#xff1a;本篇内容是C语言操作符详解下篇 文章目录前言八、条件表达式九、逗号表达式十、 下标引用、函数调用和结构成员1. [ ] 下标引用操作符2. ( ) 函数调用操作符3.结构成员访问操作符十一、表达式求值1. 隐式类型转换举例说明1举例说明2举例说明32.算数转换3.操作…...

【五六七人口普查】我国省市两级家庭户住房状况

人口数据是我们在各项研究中最常使用的数据&#xff01;之前我们分享过第七次人口普查&#xff08;简称七普&#xff09;的数据&#xff01;很多小伙伴拿到数据后都反馈数据非常好用&#xff0c;同时很多小伙伴咨询有没有前面几次人口普查的数据&#xff0c;这样方便做人口变化…...

大数据框架之Hadoop:入门(二)从Hadoop框架讨论大数据生态

第2章 从Hadoop框架讨论大数据生态 2.1 Hadoop是什么 Hadoop是一个由Apache基金会所开发的分布式系统基础架构。主要解决&#xff0c;海量数据的存储和海量数据的分析计算问题。广义上来说&#xff0c;Hadoop通常是指一个更广泛的概念-Hadoop生态圈。 2.2 Hadoop发展历史 1&…...

负载均衡反向代理下的webshell上传+apache漏洞

目录一、负载均衡反向代理下的webshell上传1、nginx 负载均衡2、搭建环境3、负载均衡下的 WebShell连接的难点总结难点一、需要在每一台节点的相同位置都上传相同内容的 WebShell难点二、无法预测下次的请求交给哪台机器去执行。难点三、下载文件时&#xff0c;可能会出现飘逸&…...

打造安全可信的通信服务,阿里云云通信发布《短信服务安全白皮书》

随着数字化经济的发展&#xff0c;信息保护和数据安全成为企业、个人关注的焦点。近日&#xff0c;阿里云云通信发布《短信服务安全白皮书》&#xff0c;该白皮书包含安全责任共担、安全合规、安全架构三大板块&#xff0c;呈现了阿里云云通信在信息安全保护方面的技术能力、安…...

Python项目实战——外汇牌价(附源码)

前言 几乎每个人都在使用银行卡&#xff0c;今天我们就来爬取某行外汇牌价&#xff0c;获取我们想要的数据。 环境使用 python 3.9pycharm 模块使用 requests 模块介绍 requestsrequests是一个很实用的Python HTTP客户端库&#xff0c;爬虫和测试服务器响应数据时经常会用到&…...

String、StringBuffer、StringBuilder有什么区别?

第5讲 | String、StringBuffer、StringBuilder有什么区别&#xff1f; 今天我会聊聊日常使用的字符串&#xff0c;别看它似乎很简单&#xff0c;但其实字符串几乎在所有编程语言里都是个特殊的存在&#xff0c;因为不管是数量还是体积&#xff0c;字符串都是大多数应用中的重要…...

python基于django+vue的高铁地铁火车订票管理系统

目录 1 绪论 1 1.1课题背景 1 1.2课题研究现状 1 1.3初步设计方法与实施方案 2 1.4本文研究内容 2 2 系统开发环境 4 2.1 使用工具简介 4 2.2 环境配置 4 2.4 MySQL数据库 5 2.5 框架介绍 5 3 系统分析 6 3.1系统可行性分析 6 3.1.1经济可行性 6 3.1.2技术可行性 6 3.1.3运行可…...

全栈自动化测试技术笔记(一):前期调研怎么做

昨天下午在家整理书架&#xff0c;把很多看完的书清理打包好&#xff0c;预约了公益捐赠机构上门回收。 整理的过程中无意翻出了几年前的工作记事本&#xff0c;里面记录了很多我刚开始做自动化和性能测试时的笔记。 虽然站在现在的角度来看&#xff0c;那个时候无论是技术细…...

专家培养计划

1、先知道一百个关键词 进入一个行业&#xff0c;如果能快速掌握其行业关键词&#xff0c;你会发现&#xff0c;你和专家的距离在迅速缩短。 若不然&#xff0c;可能同事间的日常交流&#xff0c;你都会听得云里雾里&#xff0c;不知所云。 比如做零售&#xff0c;就要了解零售…...

583. 两个字符串的删除操作 72. 编辑距离

583. 两个字符串的删除操作 dp[i][j]:以i-1结尾的word1和j-1结尾的word2 变成相同字符串最少的步骤为dp[i][j] 初始化dp[i][0],dp[0][j]为空字符串和第一个字符匹配的最少步骤&#xff0c;即i/j&#xff0c;删除对应的字符个数。dp[i][0]i,dp[0][j]j; 遍历两个字符串。 若word1…...

[多线程进阶] 常见锁策略

专栏简介: JavaEE从入门到进阶 题目来源: leetcode,牛客,剑指offer. 创作目标: 记录学习JavaEE学习历程 希望在提升自己的同时,帮助他人,,与大家一起共同进步,互相成长. 学历代表过去,能力代表现在,学习能力代表未来! 目录: 1. 常见的锁策略 1.1 乐观锁 vs 悲观锁 1.2 读写…...

Scala - Idea 项目报错 Cannot resolve symbol XXX

一.引言 Idea 编译 Scala 项目大面积报错 Cannot resolve symbol xxx。 二.Cannot resolve symbol xxx 1.问题描述 Idea 内的 Scala 工程打开后显示下述异常&#xff1a; 即 Scala 常规语法全部失效&#xff0c;代码出现大面积红色报错。 2.尝试解决方法 A.设置 Main Sourc…...

信息化发展与应用的新特点

一、信息化发展与应用二、国家信息化发展战略三、电子政务※四、电子商务五、两化融合&#xff08;工业和信息化&#xff09;六、智慧城市 一、信息化发展与应用 我国在“十三五”规划纲要中&#xff0c;将培育人工智能、移动智能终端、第五代移动通信(5G)先进传感器等作为新…...

软件测试】测试时间不够了,我很慌?项目马上发布了......

目录&#xff1a;导读前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09;前言 常见的几种情况&…...

MapReduce编程规范

MapReduce编程规范 MapReduce的开发一共有八个步骤,其中Map阶段分为2个步骤&#xff0c;Shuffle阶段4个步骤&#xff0c;Reduce阶段分为2个步骤。 Map阶段2个步骤 设置InputFormat类,将数据切分为Key-Value(K1和V1)对,输入到第二步。 自定义Map逻辑,将第一步的结果转换成另外的…...

Unity 如何实现游戏Avatar角色头部跟随视角转动

文章目录功能简介实现步骤获取看向的位置获取头部的位置修改头部的朝向限制旋转角度超出限制范围时自动回正如何让指定动画不受影响功能简介 如图所示&#xff0c;当相机的视角转动时&#xff0c;Avatar角色的头部会同步转动&#xff0c;看向视角的方向。 实现步骤 获取看向的…...

深度学习优化算法总结

深度学习的优化算法 优化的目标 优化提供了一种最大程度减少深度学习损失函数的方法&#xff0c;但本质上&#xff0c;优化和深度学习的目标不同。 优化关注的是最小化目标&#xff1b;深度学习是在给定有限数据量的情况下寻找合适的模型。 优化算法 gradient descent&#xf…...

CMake详细使用

1、CMake简介CMake是一个用于管理源代码的跨平台构建工具可以方便地根据目标平台和编译工具产生对应的编译文件主要用于C/C语言的构建&#xff0c;但是也可以用于其它编程语言的源代码。如同使用make命令工具解析Makefile文件一样cmake命令工具依赖于一个CMakeLists.txt的文件该…...

【数据结构与算法】前缀树的实现

&#x1f320;作者&#xff1a;阿亮joy. &#x1f386;专栏&#xff1a;《数据结构与算法要啸着学》 &#x1f387;座右铭&#xff1a;每个优秀的人都有一段沉默的时光&#xff0c;那段时光是付出了很多努力却得不到结果的日子&#xff0c;我们把它叫做扎根 目录&#x1f449;…...

canvas 制作2048

效果展示 对UI不满意可以自行调整&#xff0c;这里只是说一下游戏的逻辑&#xff0c;具体的API调用不做过多展示。 玩法分析 2048 的玩法非常简单&#xff0c;通过键盘的按下&#xff0c;所有的数字都向着同一个方向移动&#xff0c;如果出现两个相同的数字&#xff0c;就将…...

playwright: 全局修改页面等待超时时间

等待超时时间默认是30s, 可以通过以下几个方法设置&#xff1a; browser_context.set_default_navigation_timeout()browser_context.set_default_timeout()page.set_default_navigation_timeout()page.set_default_timeout() set_default_navigation_timeout set_default_n…...

C++类和对象(中)

✨个人主页&#xff1a; Yohifo &#x1f389;所属专栏&#xff1a; C修行之路 &#x1f38a;每篇一句&#xff1a; 图片来源 I do not believe in taking the right decision. I take a decision and make it right. 我不相信什么正确的决定。我都是先做决定&#xff0c;然后把…...

Docker安装EalasticSearch、Kibana,安装Elasticvue插件

使用Docker快速安装部署ES和Kibana的前提&#xff1a;首先需要确保已经安装了Docker环境。 如果没有安装Docker的话&#xff0c;先在Linux上安装Docker。 有了Docker环境后&#xff0c;就可以使用Docker安装部署ES和Kibana了 一、安装ES 1、拉取EalasticSearch镜像 docker p…...

算法训练营 day39 贪心算法 无重叠区间 划分字母区间 合并区间

算法训练营 day39 贪心算法 无重叠区间 划分字母区间 合并区间 无重叠区间 435. 无重叠区间 - 力扣&#xff08;LeetCode&#xff09; 给定一个区间的集合 intervals &#xff0c;其中 intervals[i] [starti, endi] 。返回 需要移除区间的最小数量&#xff0c;使剩余区间互…...

c/c++开发,无可避免的文件访问开发案例

一、缓存文件系统 ANSI C标准中的C语言库提供了fopen, fclose, fread, fwrite, fgetc, fgets, fputc, fputs, freopen, fseek, ftell, rewind等标准函数&#xff0c;这些函数在不同的操作系统中应该调用不同的内核API&#xff0c;从而支持开发者跨平台实现对文件的访问。 在Lin…...

MySQL学习笔记

MySQL学习笔记一、基础配置二、数据库操作三、表的操作1.创建表2.表选项3.查看表4.修改表5.删除表6.复制表7.检查优化修复表四、数据操作基础增删改查五、字符集编码六、数据类型&#xff08;列类型&#xff09;1.数值类型2.字符串类型3.日期时间类型4.枚举和集合七、列属性&am…...

ccs导入工程失败的处理方法

文章目录当导入CCS新工程时出现下述错误怎么办&#xff1f;方法一 从TI官网下载安装包进行安装&#xff0c;下载链接&#xff1a;软件下载完成 安装路径为上面的文件夹点击安装完成后&#xff0c;导入安装路径&#xff0c;并点击Refresh按钮&#xff0c;依据路径进行更新&#…...

探针台常见的故障及解决方法

症状、 可能原因、 解决方法 移动样品后画面变模糊 —显微镜不垂直&#xff0c;调垂直显微镜 样品台不水平 —调水平样品台 显微镜视场亮度不足&#xff0c;边缘切割或看不到像—转换器不在定位位置上 把转换器转到定位位置上 管镜转盘不在定位位置上 —把管镜转盘转到定…...

做学习交流网站/合肥seo推广培训班

如何使用JavaScript从excel导入数据到HTML页面参考《Windows脚术》该会有一点。Untitled Pagefunction importXLS(fileName){objCon new ActiveXObject("ADODB.Connection");objCon.Provider "Microsoft.Jet.OLEDB.4.0";objCon.ConnectionString "…...

python做软件的网站/流量点击推广平台

车架号车型发动机和变速箱型号行驶里程4JGDF7DE7DA120825GL550276928和72290967345故障现象(陈述)&#xff1a;此车在车库放了3个月&#xff0c;去启动无反应&#xff0c;接到客户救援电话最后直接拿上一个原厂电瓶给客户换上&#xff0c;换上之后车能正常启动&#xff0c;但是…...

手机网站宽度自适应/营销推广费用方案

如何识别架构设计复杂度 架构设计&#xff1a;识别复杂度 我在前面讲过&#xff0c;架构设计的本质目的是为了解决软件系统的复杂性&#xff0c;所以在我们设计架构时&#xff0c;首先就要分析系统的复杂性。只有正确分析出了系统的复杂性&#xff0c;后续的架构设计方案才不会…...

个人网页设计作品介绍/荥阳seo推广

一、面向对象和面向过程的区别&#xff1f;面向过程优点&#xff1a;性能比面向对象高&#xff0c;因为类调用时需要实例化&#xff0c;开销比较大&#xff0c;比较消耗 资源;比如单片机、嵌入式开发、Linux/Unix 等一般采用面向过程开发&#xff0c;性能是 最重要的因素。缺点…...

word里面网站超链接怎么做/百度推广哪家做的最好

不少人买平板电脑的目的就是用来玩吃鸡的&#xff0c;然而有的人发现买回来后玩吃鸡会有一点点卡&#xff0c;这是什么原因呢?主要与配置和设置有关系&#xff0c;因为吃鸡对配置要求还是比较高的&#xff0c;如果选择一些配置较差的低端品牌自然会卡顿&#xff0c;那么它对于…...

辽宁建设官方网站/百度关键词优化策略

前语&#xff1a;不要为了读文章而读文章&#xff0c;一定要带着问题来读文章&#xff0c;勤思考。在此&#xff0c;建议大家为本公众号加“星标”。如文章写得好&#xff0c;望大家阅读后在右下边“在看”处点个赞&#xff0c;以示鼓励&#xff01;作者:LiWenD 来源&#xff…...