error处理

在编写应用的时候,为了调试程序方便,可以在异常处理代码中把异常信息显示出来,这样可以根据错误提示调试代码。异常处理代码通常可以写成这样:

try{

}catch(Exception e){

   System.out.println(e.toString());

}

下面是一些常见的错误信息:

(1)驱动程序不存在

提示的错误信息如下:

java.lang.ClassNotFoundException: com.mysql.jdbc.Drive

后半部分是您在程序中写的驱动程序的名字。

解决方法:仔细检查类名是否写错,如果类名没有写错,则是驱动程序所在的压缩包没有引入工程,想办法引入。

(2)URL写错

提示的错误信息如下:

java.sql.SQLException: No suitable driver

解决方法:仔细检查URL的格式是否正确,不同数据库的URL格式不同。

(3)主机IP地址不正确或者网络不通

提示的错误信息如下:

com.mysql.jdbc.CommunicationsException: Communications link failure due to underlying exception:


(4)端口错误或者数据库服务器没有启动

提示的错误信息如下:

com.mysql.jdbc.CommunicationsException: Communications link failure due to underlying exception:


(5)数据库名字不正确

提示的错误信息如下:

java.sql.SQLException: Unknown database 'test2'

解决方法:查看数据库是否存在。

(6)用户名或者口令不正确

提示的错误信息如下:

java.sql.SQLException: Access denied for user 'roo'@'localhost' (using password: YES)

解决方法:确认用户名和口令是否正确。

(7)表名错误

提示的错误信息如下:

java.sql.SQLException: Table 'test.student1' doesn't exist

解决方法:查看表是否存在,表名是否写错。

(8)列名错误

提示的错误信息如下:

java.sql.SQLException: Unknown column 'sid' in 'field list'

解决方案:仔细查看数据库表中的列名。

(9)处理结果集的时候,要获取的列的序号大于列数,或者小于0

提示的错误信息如下:

java.sql.SQLException: Column Index out of range, 4 > 3.

这个错误产生的背景是:数据库表中只有3列,而在取信息的时候使用了rs.getString(4),尤其是在使用循环处理的时候容易犯这样的错误。

(10)执行insert语句的时候,表中的列数与插入语句中的不相同

提示的错误信息如下:

java.sql.SQLException: Column count doesn't match value count at row 1

该错误产生的背景是:数据库表中有3列,而插入的时候给了4个值,SQL语句如下:

insert into student values('0011323','李旭',22,99)。

(11)执行insert语句的时候,主键重复。

提示的错误信息如下:

java.sql.SQLException: Duplicate entry '0011323' for key 1

该错误产生的背景是:1条SQL语句连续执行了两遍,第二遍就出错了。

(12)执行insert语句的时候,值过长

提示的错误信息如下:

java.sql.SQLException: Data too long for column 'id' at row 1

解决方案,查看数据库中列的长度。

在 Go 语言中,错误处理是一种非常重要的机制,可以帮助我们在程序运行时检测到错误,并采取相应的措施来解决问题。Go 语言中的错误类型是内置的 error 接口类型,其定义如下: ```go type error interface { Error() string } ``` 可以看到,这个接口只有一个方法 Error(),它返回一个字符串,表示错误的描述信息。因此,如果你想定义一个错误类型,只需要实现 error 接口的 Error() 方法即可。 在 Go 语言中,我们通常会使用函数返回值来传递错误信息。如果函数执行成功,通常会返回一个 nil 错误;如果函数执行失败,通常会返回一个非空的错误值,表示出错的具体信息。 例如,下面的代码演示了如何在打开一个文件时进行错误处理: ```go file, err := os.Open("test.txt") if err != nil { // 处理错误 fmt.Println("打开文件失败:", err.Error()) return } // 文件打开成功,进行操作 ``` 在这个代码中,我们使用 os.Open 函数打开一个文件。如果函数执行失败,会返回一个非空的错误值 err;否则,函数返回一个文件对象 file。我们可以使用 if err != nil 来检查 err 是否为空,如果不为空,表示函数执行失败,我们需要采取相应的措施来解决问题,例如打印错误信息并返回。如果 err 为空,则表示函数执行成功,我们可以继续操作文件对象。 除了使用 if err != nil 来检查错误之外,Go 语言还提供了一个更加简洁的语法,即使用 defer 和 panic 函数来处理错误。例如,下面的代码演示了如何在除数为零时触发 panic: ```go func divide(x, y int) int { defer func() { if err := recover(); err != nil { fmt.Println("出现了一个错误:", err) } }() if y == 0 { panic("除数不能为零") } return x / y } ``` 在这个代码中,我们使用 defer 和匿名函数来定义一个错误处理函数。在 divide 函数中,如果除数为零,我们会使用 panic 函数触发一个 panic,表示程序遇到了无法处理的错误。此时,defer 语句会立即执行匿名函数,该函数调用 recover 函数来捕获 panic,并打印错误信息。注意,在 defer 函数中使用 recover 函数可以避免程序崩溃,并返回一个错误信息。 总的来说,Go 语言提供了多种方式来处理错误,可以根据实际情况选择适合自己的方式。在实际开发中,我们通常会将错误信息记录到日志中,或者通过 HTTP 接口返回给客户端。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值