当前位置:网站首页 > Java基础 > 正文

java基础入门详解

数据库笔试题 DBA

1、事务是什么?

解:事务:事务是用于确保数据库数据的一致性,它由一组相关的dml语句组成。该组dml 语句要么全部执行,要么全不部执行;

2、oracle中truncate和delete命令有何区别?

解:delete 删除所有记录,表结构还在,写日志,可以恢复的,速度慢、

truncate 删除表中所有记录,表结构还在,不写日志。不可恢复、

3、Oracle中char和varchar2数据类型有什么区别?有数据"test"分别存放到char(10)和varchar2(10)类型的字段中,其存储长度及类型有何区别?

解:char是不可以变长的字符串,varchar2是可变长字符串。test 存储在char(10)和varchar(10)在char中是test而在varchar2()中是“test ”.

4、参见如下表结构

出版社:

出版社代码 char(2),

出版社名称 varchar2(32)

图书:

图书编号 char(8),

图书名称 varchar2(128),

出版社代码 char(2),

作者代号 char(4),

图书简介 varchar2(128)

作者:

作者代号 char(4),

作者名称 varchar2(10),

性别 char(1),

年龄 number(3),

文学方向 varchar2(64)

获奖名单:

获奖日期 date,

获奖人员 char(4)

编写SQL语句,找出"作者"库中没有出现在"获奖名单"库中所有作者信息的SQL语句(提示:使用not in、not exists以及外关联三种方法,并说明哪种方法最优。

解:select * from 作者 where 作者 not in (select 获奖人员 from 获奖名单);

select 作者,获奖人员 from 作者,获奖名单 where 作者。作者(+)=获奖名单。获奖人员;

select * from 作者 where 作者 not exists(select 获奖人员 from 获奖名单);

5、Oracle数据库表存在伪列rowid,请利用rowid编写一个SQL语句,从以下记录中找到唯一记录,并将其flag列更新为Y

No name sex flag

1 张三 1 N

1 张三 1 N

1 张三 1 N

解:select * from 表 a where (select count(no) from 表 b where a.no=b.no)=1;

update 表 set flag='y' where (select count(ROWID) from 表 b where 表.no=b.no)=1;

6、Oracle中,需要在查询语句中把空值(NULL)输出为0,如何处理?

解:select nvl(字段,0) from 表;

7、见第四题"获奖名单"表,写出SQL语句,查询出在上一个月获奖的人员。

8、见第四题"图书"表,在表上对图书名称、出版社代码、作者代号创建了组合索引,请问在执行如下语句时会不会利用到索引。

Select * from 图书 where 图书名称='xxxx'

Select * from 图书 where 图书名称='xxxx' and 出版社代码='bb'

Select * from 图书 where 图书名称='xxxx' and 作者代号='ddd'

Select * from 图书 where 出版社代码='yyy'

9、编写一个简单的Oracle存储过程,输出参数必须有一个是结果集。

史上最强的几道oracle数据库面试题

oracle Certification Program (OCP认证)的题目

(1) A 表中有100条记录.

Select * FROM A Where A.COLUMN1 = A.COLUMN1

这个语句返回几条记录? (简单吧,似乎1秒钟就有答案了:)

(2) Create SEQUENCE PEAK_NO

Select PEAK_NO.NEXTVAL FROM DUAL --> 假设返回1

10秒中后,再次做

Select PEAK_NO.NEXTVAL FROM DUAL --> 返回多少?

(3) SQL> connect sys as sysdba

Connected.

SQL> insert into dual values ( 'Y');

1 row created.

SQL> commit;

Commit complete.

SQL> select count(*) from dual;

COUNT(*)

----------

2

SQL> delete from dual;

commit;

-->DUAL里还剩几条记录?

一些高难度的SQL面试题

以下的null代表真的null,写在这里只是为了让大家看清楚

根据如下表的查询结果,那么以下语句的结果是(知识点:not in/not exists+null)

SQL> select * from usertable;

USERID USERNAME

----------- ----------------

1 user1

2 null

3 user3

4 null

5 user5

6 user6

SQL> select * from usergrade;

USERID USERNAME GRADE

---------- ---------------- ----------

1 user1 90

2 null 80

7 user7 80

8 user8 90

执行语句:

select count(*) from usergrade where username not in (select username from usertable);

select count(*) from usergrade g where not exists

(select null from usertable t where t.userid=g.userid and t.username=g.username);

结果为:语句1( 0 ) 语句2 ( 3 )

A: 0 B:1 C:2 D:3 E:NULL

2

在以下的表的显示结果中,以下语句的执行结果是(知识点:in/exists+rownum)

SQL> select * from usertable;

USERID USERNAME

----------- ----------------

1 user1

2 user2

3 user3

4 user4

5 user5

SQL> select * from usergrade;

USERNAME GRADE

---------------- ----------

user9 90

user8 80

user7 80

user2 90

user1 100

user1 80

执行语句

Select count(*) from usertable t1 where username in

(select username from usergrade t2 where rownum <=1);

Select count(*) from usertable t1 where exists

(select 'x' from usergrade t2 where t1.username=t2.username and rownum <=1);

以上语句的执行结果是:(0 ) (2)

A: 0 B: 1 C: 2 D: 3

根据以下的在不同会话与时间点的操作,判断结果是多少,其中时间T1<T2<……<Tn。(知识点:封锁与并发)

原始表记录为;

select * from emp;

EMPNO DEPTNO SALARY

----- ------ ------

100 1 55

101 1 50

select * from dept;

DEPTNO SUM_OF_SALARY

------ -------------

1 105

2

可以看到,现在因为还没有部门2的员工,所以总薪水为null,现在,

有两个不同的用户(会话)在不同的时间点(按照特定的时间顺序)执行了一系列的操作,那么在其中或最后的结果为:

time session 1 session2

----------- ------------------------------- -----------------------------------

T1 insert into emp

values(102,2,60)

T2 update emp set deptno =2

where empno=100

T3 update dept set sum_of_salary =

(select sum(salary) from emp

where emp.deptno=dept.deptno)

where dept.deptno in(1,2);

T4 update dept set sum_of_salary =

(select sum(salary) from emp

where emp.deptno=dept.deptno)

where dept.deptno in(1,2);

T5 commit;

T6 select sum(salary) from emp group by deptno;

问题一:这里会话2的查询结果为:

T7 commit;

=======到这里为此,所有事务都已完成,所以以下查询与会话已没有关系========

T8 select sum(salary) from emp group by deptno;

问题二:这里查询结果为

T9 select * from dept;

问题三:这里查询的结果为

问题一的结果( ) 问题二的结果是( ) 问题三的结果是( )

A: B:

---------------- ----------------

1 50 1 50

2 60 2 55

C: D:

---------------- ----------------

1 50 1 115

2 115 2 50

E: F:

---------------- ----------------

1 105 1 110

2 60 2 55

有表一的查询结果如下,该表为学生成绩表(知识点:关联更新)

select id,grade from student_grade

ID GRADE

-------- -----------

1 50

2 40

3 70

4 80

5 30

6 90

表二为补考成绩表

select id,grade from student_makeup

ID GRADE

-------- -----------

1 60

2 80

5 60

现在有一个dba通过如下语句把补考成绩更新到成绩表中,并提交:

update student_grade s set s.grade = (select t.grade from student_makeup t where s.id=t.id);

commit;

请问之后查询:

select GRADE from student_grade where id = 3;结果为: c

A: 0 B: 70 C: null D: 以上都不对

根据以下的在不同会话与时间点的操作,判断结果是多少,

其中时间T1<T2<……<Tn。(知识点:DDL与封锁)

session1 session2

-------------------------------------- ----------------------------------------

T1 select count(*) from t;

--显示结果(1000)条

T2 delete from t where rownum <=100;

T3 begin

delete from t where rownum <=100;

commit;

end;

/

T4 truncate table t;

T5 select count(*) from t;

--这里显示的结果是多少

A: 1000 B: 900 C: 800 D: 0

某数据集团数据库初试笔试题(数据库面试 笔试题)

1)Which statement shows the maximum salary paid in each job category of each department?___b____

A. select dept_id, job_cat,max(salary) from employees where salary > max(salary);

B. select dept_id, job_cat,max(salary) from employees group by dept_id,job_cat;

C. select dept_id, job_cat,max(salary) from employees;

D. select dept_id, job_cat,max(salary) from employees group by dept_id;

E. select dept_id, job_cat,max(salary) from employees group by dept_id,job_cat,salary;

2)description of the students table:

sid_id number

start_date date

end_date date

which two function are valid on the start_date column?___ce______。

A. sum(start_date)

B. avg(start_date)

C. count(start_date)

D. avg(start_date,end_date)

E. min(start_date)

F. maximum(start_date)

3)for which two constraints does the oracle server implicitly create a unique index?___be___。

A. not null

B. primary

C. foreign java基础入门详解 key

D. check

E. unique

版权声明


相关文章:

  • java基础教程第2版答案2024-11-16 21:18:03
  • 只会java基础怎么找工作2024-11-16 21:18:03
  • java基础在线题库2024-11-16 21:18:03
  • java基础教程强制类型转换2024-11-16 21:18:03
  • java基础3原码反码补码转换2024-11-16 21:18:03
  • java基础入门图片2024-11-16 21:18:03
  • 有js基础学java2024-11-16 21:18:03
  • java入门零基础操作2024-11-16 21:18:03
  • Java好学么 零基础2024-11-16 21:18:03
  • java网页基础知识2024-11-16 21:18:03