Java 重写(Override)与重载(Overload)
#########################
重写(Override)
重写是子类对父类的允许访问的方法的实现过程进行重新编写, 返回值和形参都不能改变。即外壳不变,核心重写!
重写的好处在于子类可以根据需要,定义特定于自己的行为。 也就是说子类能够根据需要实现父类的方法。
重写方法不能抛出新的检查异常或者比被重写方法申明更加宽泛的异常。例如: 父类的一个方法申明了一个检查异常 IOException,但是在重写这个方法的时候不能抛出 Exception 异常,因为 Exception 是 IOException 的父类,只能抛出 IOException 的子类异常。
在面向对象原则里,重写意味着可以重写任何现有方法。
方法的重写规则
参数列表与被重写方法的参数列表必须完全相同。
返回类型与被重写方法的返回类型可以不相同,但是必须是父类返回值的派生类(java5 及更早版本返回类型要一样,java7 及更高版本可以不同)。
访问权限不能比父类中被重写的方法的访问权限更低。例如:如果父类的一个方法被声明为 public,那么在子类中重写该方法就不能声明为 protected。
父类的成员方法只能被它的子类重写。
声明为 final 的方法不能被重写。
声明为 static 的方法不能被重写,但是能够被再次声明。
子类和父类在同一个包中,那么子类可以重写父类所有方法,除了声明为 private 和 final 的方法。
子类和父类不在同一个包中,那么子类只能够重写父类的声明为 public 和 protected 的非 final 方法。
重写的方法能够抛出任何非强制异常,无论被重写的方法是否抛出异常。但是,重写的方法不能抛出新的强制性异常,或者比被重写方法声明的更广泛的强制性异常,反之则可以。
构造方法不能被重写。
如果不能继承一个类,则不能重写该类的方法。
Super 关键字的使用
当需要在子类中调用父类的被重写方法时,要使用 super 关键字。
#########################
重载(Overload)
重载(overloading) 是在一个类里面,方法名字相同,而参数不同。返回类型可以相同也可以不同。
每个重载的方法(或者构造函数)都必须有一个独一无二的参数类型列表。
最常用的地方就是构造器的重载。
重载规则:
被重载的方法必须改变参数列表(参数个数或类型不一样);
被重载的方法可以改变返回类型;
被重载的方法可以改变访问修饰符;
被重载的方法可以声明新的或更广的检查异常;
方法能够在同一个类中或者在一个子类中被重载。
无法以返回值类型作为重载函数的区分标准。
#########################
重写与重载之间的区别
区别点 重载方法 重写方法
参数列表 必须修改 一定不能修改
返回类型 可以修改 一定不能修改
异常 可以修改 可以减少或删除, 一定不能抛出新的或者更广的异常
访问 可以修改 一定不能做更严格的限制(可以降低限制)
总结
方法的重写(Overriding)和重载(Overloading)是java多态性的不同表现,重写是父类与子类之间多态性的一种表现,重载可以理解成多态的具体表现形式。
(1)方法重载是一个类中定义了多个方法名相同,而他们的参数的数量不同或数量相同而类型和次序不同,则称为方法的重载(Overloading)。
(2)方法重写是在子类存在方法与父类的方法的名字相同,而且参数的个数与类型一样,返回值也一样的方法,就称为重写(Overriding)。
(3)方法重载是一个类的多态性表现,而方法重写是子类与父类的一种多态性表现。
sql:
判断是否为空用is null
不为空,用is not null
而非
=null
外查询的条件where id=(子查询),子查询的必须查询id的值只能有一个,
如果多于一个那么数据库就不知道具体跟哪一个值对等
SELECT empno “emp number”,SUM(sal) “SALARY” FROM emp
WHERE sal>1500 GROUP BY “emp number” ORDER BY 2;
这里的2是指查询结果中的第二个字段.
IMS是IBM公司的数据库,是层次型数据库
MongoDB是基于分布式文件存储的数据库
nvl(expr1,expr2)将null转换为非null值
如果expr1位null,则取值expr2,expr2是实际值
expr1和expr2可以是任何数据类型,但两个参数的数据类型必须是一致的
对分完组的数据做限定输出用having 条件
第三种删除语句
运用 TRUNCATE TABLE 的指令。
在这个指令之下,表格中的资料会完全消失,可是表格本身会继续存在。
TRUNCATE TABLE 的语法为下:
TRUNCATE TABLE “表格名”;
所以,我们如果要清除在 SQL Create Table
那一页建立的顾客表格之内的资料,我们就打入:
TRUNCATE TABLE Customer;
UNIQUE是唯一约束
COUNT是求记录数
DISTINCT去掉重复记录
UNION是联合查询
######################################
表person 的结构如下:(共5分)
ID int(9)
NAME VARCHAR2(25)
MANAGER_ID int(9)
在这里,部门的管理者也看作是雇员,写出SQL语句查询每个雇员的姓名以及管理者的姓名,若某雇员没有上级领导,显示空 :
考察表的自联结查询,做连接查询
select p1.name as name,p2.name as mgrname from person p1 LEFT JOIN person p2 ON p1.manager_id=p2.id
######################################
现有员工表employee(id,dept_id,ename,salary) --(共30分,每题5分)
部门表dept(id,name,location) ,求各部门平均工资的最高值。
法一:
select max(tmp.avgsal),d.name
from
(
select dept_id, AVG(salary) avgsal from employee GROUP BY dept_id
) tmp,dept d
where
d.id=tmp.dept_id
法二:
SELECT NAME, AVG(salary)
FROM DEPT,EMPLOYEE
GROUP BY NAME
ORDER BY AVG(salary) DESC
LIMIT 1
######################################