mysql 自定义异常_Java自定义异常

如果 Java 提供的内置异常类型不能满足程序设计的需求,这时我们可以自己设计 Java 类库或框架,其中包括异常类型。实现自定义异常类需要继承 Exception 类或其子类,如果自定义运行时异常类需继承 RuntimeException 类或其子类。

自定义异常的语法形式为:

在编码规范上,一般将自定义异常类的类名命名为 XXXException,其中 XXX 用来代表该异常的作用。

自定义异常类一般包含两个构造方法:一个是无参的默认构造方法,另一个构造方法以字符串的形式接收一个定制的异常消息,并将该消息传递给超类的构造方法。

例如,以下代码创建一个名称为 IntegerRangeException 的自定义异常类:

class IntegerRangeException extends Exception {

public IntegerRangeException() {

super();

}

public IntegerRangeException(String s) {

super(s);

}

}

以上代码创建的自定义异常类 IntegerRangeException 类继承自 Exception 类,在该类中包含两个构造方法。

例 1

编写一个程序,对会员注册时的年龄进行验证,即检测是否在 0~100 岁。

1)这里创建了一个异常类 MyException,并提供两个构造方法。MyException 类的实现代码如下:

public class MyException extends Exception {

public MyException() {

super();

}

public MyException(String str) {

super(str);

}

}

2)接着创建测试类,调用自定义异常类。代码实现如下:

import java.util.InputMismatchException;

import java.util.Scanner;

public class Test07 {

public static void main(String[] args) {

int age;

Scanner input = new Scanner(System.in);

System.out.println("请输入您的年龄:");

try {

age = input.nextInt(); // 获取年龄

if(age < 0) {

throw new MyException("您输入的年龄为负数!输入有误!");

} else if(age > 100) {

throw new MyException("您输入的年龄大于100!输入有误!");

} else {

System.out.println("您的年龄为:"+age);

}

} catch(InputMismatchException e1) {

System.out.println("输入的年龄不是数字!");

} catch(MyException e2) {

System.out.println(e2.getMessage());

}

}

}

3)运行该程序,当用户输入的年龄为负数时,则拋出 MyException 自定义异常,执行第二个 catch 语句块中的代码,打印出异常信息。程序的运行结果如下所示。

请输入您的年龄:

-2

您输入的年龄为负数!输入有误!

当用户输入的年龄大于 100 时,也会拋出 MyException 自定义异常,同样会执行第二个 catch 语句块中的代码,打印出异常信息,如下所示。

请输入您的年龄:

110

您输入的年龄大于100!输入有误!

在该程序的主方法中,使用了 if…else if…else 语句结构判断用户输入的年龄是否为负数和大于 100 的数,如果是,则拋出自定义异常 MyException,调用自定义异常类 MyException 中的含有一个 String 类型的构造方法。在 catch 语句块中捕获该异常,并调用 getMessage() 方法输出异常信息。

提示:因为自定义异常继承自 Exception 类,因此自定义异常类中包含父类所有的属性和方法。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java定义了一个枚举类型后,可以使用JDBC将其映射到MySQL数据库的一个字段。具体实现方法如下: 1. 定义一个枚举类型: ```java public enum Gender { MALE, FEMALE, OTHER } ``` 2. 在MySQL定义一个枚举类型: ```sql CREATE TYPE gender_enum AS ENUM ('MALE', 'FEMALE', 'OTHER'); ``` 3. 在Java定义一个类型处理器,用于将枚举类型映射到MySQL的枚举类型: ```java public class GenderTypeHandler extends BaseTypeHandler<Gender> { @Override public void setNonNullParameter(PreparedStatement ps, int i, Gender parameter, JdbcType jdbcType) throws SQLException { ps.setString(i, parameter.toString()); } @Override public Gender getNullableResult(ResultSet rs, String columnName) throws SQLException { String value = rs.getString(columnName); return value != null ? Gender.valueOf(value) : null; } @Override public Gender getNullableResult(ResultSet rs, int columnIndex) throws SQLException { String value = rs.getString(columnIndex); return value != null ? Gender.valueOf(value) : null; } @Override public Gender getNullableResult(CallableStatement cs, int columnIndex) throws SQLException { String value = cs.getString(columnIndex); return value != null ? Gender.valueOf(value) : null; } } ``` 4. 在MyBatis配置类型处理器: ```xml <typeHandlers> <typeHandler handler="com.example.GenderTypeHandler" javaType="com.example.Gender"/> </typeHandlers> ``` 5. 在Mapper使用枚举类型: ```xml <resultMap id="userResultMap" type="com.example.User"> <id property="id" column="id"/> <result property="name" column="name"/> <result property="gender" column="gender" typeHandler="com.example.GenderTypeHandler"/> </resultMap> <select id="getUser" resultMap="userResultMap"> SELECT * FROM user WHERE id = #{id} </select> ``` 这样,就可以将Java的枚举类型映射到MySQL的一个枚举类型。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值