sql正常执行,在程序中报错

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql正常执行,在程序中报错相关的知识,希望对你有一定的参考价值。

2014-09-18 15:43:18,052 WARN [org.hibernate.util.JDBCExceptionReporter] - <SQL Error: 17410, SQLState: null>
2014-09-18 15:43:18,052 ERROR [org.hibernate.util.JDBCExceptionReporter] - <无法从套接字读取更多的数据>
org.hibernate.exception.GenericJDBCException: could not execute query
at org.hibernate.loader.custom.CustomLoader.list(CustomLoader.java:289)
at org.hibernate.impl.SessionImpl.listCustomQuery(SessionImpl.java:1695)
at org.hibernate.impl.AbstractSessionImpl.list(AbstractSessionImpl.java:142)
at org.hibernate.impl.SQLQueryImpl.list(SQLQueryImpl.java:152)
at com.smartdot.dcu.cws.caseSheet.dao.CwsCaseDao.findTaskListRegister(CwsCaseDao.java:802)
at com.smartdot.dcu.cws.caseSheet.service.CwsCaseManager.findTasklistRegister(CwsCaseManager.java:691)
at com.smartdot.dcu.cws.caseSheet.service.CwsCaseManager$$FastClassByCGLIB$$6bfbd85e.invoke(<generated>)
at net.sf.cglib.proxy.MethodProxy.invoke(MethodProxy.java:149)
Caused by: java.sql.SQLException: 无法从套接字读取更多的数据 at oracle.jdbc.driver.T4CPreparedStatement.fetch(T4CPreparedStatement.java:1023)
at oracle.jdbc.driver.OracleResultSetImpl.close_or_fetch_from_next(OracleResultSetImpl.java:290)
at oracle.jdbc.driver.OracleResultSetImpl.next(OracleResultSetImpl.java:212)
at org.apache.commons.dbcp.DelegatingResultSet.next(DelegatingResultSet.java:169)
at org.hibernate.loader.Loader.doQuery(Loader.java:697)

参考技术A 你好,看见你用hibernate了,这个引起的原因很多,可以查看下oracle的session,看是不是事务没有及时的关闭。除此之外可以从以下几点查看下原因:
1、检查程序,优化数据库操作及SQL语句,如该关闭的数据库链接要及时关闭、查询语句该简化的简化;
2、检查网络状况,排除网络原因;
3、调整数据库配置参数,比如:会话超时时间、每秒最大连接数、最大连接数等等;
4、看看数据库的版本,有没有升级的可能,也许会解决这个问题;追问

这个查询时分页的,如果分页中间的查询内容不使用order by排序,程序也不出错,但是加上order by 就出错。

追答

这样的话,你把你的sql语句粘出来,是先分页的,还是先排序的?

追问

追答

嗯,谢谢。关于这个先分页还是先排序的问题,其实你是先拍好序,之后读取到这个rownum里面某些特定的行数,这个和mysql里面的limit是一个功能,当然比mysql的功能更灵活一些。

本回答被提问者和网友采纳

linux中报错“把输出追加到nohup.out”啥意思?

这不是报错,只是提示,后台执行程序的输出都被重定向到nohup.out文件。

linux重定向及nohup不输出的方法:

一、linux重定向:

0、1和2分别表示标准输入、标准输出和标准错误信息输出,可以用来指定需要重定向的标准输入或输出。

在一般使用时,默认的是标准输出,既1

当我们需要特殊用途时,可以使用其他标号。例如,将某个程序的错误信息输出到log文件中:./program 2>log。这样标准输出还是在屏幕上,但是错误信息会输出到log文件中。

另外,也可以实现0,1,2之间的重定向。

2>&1 将错误信息重定向到标准输出。

Linux下还有一个特殊的文件/dev/null,它就像一个无底洞,所有重定向到它的信息都会消失得无影无踪。这一点非常有用,当我们不需要回显程序的所有信息时,就可以将输出重定向到/dev/null。

如果想要正常输出和错误信息都不显示,则要把标准输出和标准错误都重定向到/dev/null, 例如:

ls 1>/dev/null 2>/dev/null

还有一种做法是将错误重定向到标准输出,然后再重定向到 /dev/null,例如:

ls >/dev/null 2>&1

注意:此处的顺序不能更改,否则达不到想要的效果,此时先将标准输出重定向到 /dev/null,然后将标准错误重定向到标准输出,由于标准输出已经重定向到了/dev/null,因此标准错误也会重定向到/dev/null,于是一切静悄悄:-)

由于使用nohup时,会自动将输出写入nohup.out文件中,如果文件很大的话,nohup.out就会不停的增大,这是我们不希望看到的,因此,可以利用/dev/null来解决这个问题。

(1)舍弃标准输出,将错误输出到log文件中

nohup node bin/www >/dev/null 2>log &

(2)如果错误信息也不想要的话:

nohup node bin/www >/dev/null 2>&1 &

注:其中node bin/www是项目node启动

二、关于重定向

1. 基本概念

a、I/O重定向通常与 FD有关,shell的FD通常为10个,即 0~9;(FD:file descripter,文件描述符)

b、常用FD有3个,为: 0(stdin,标准输入)、1(stdout,标准输出)、2(stderr,标准错误输出),默认与keyboard、monitor、monitor有关;

c、用 < 来改变读进的数据信道(stdin),使之从指定的档案读进;

d、用 > 来改变送出的数据信道(stdout, stderr),使之输出到指定的档案;

e、0 是 < 的默认值,因此 < 与 0<是一样的;同理,> 与 1> 是一样的;

f、在IO重定向 中,stdout 与 stderr 的管道会先准备好,才会从 stdin 读进资料;

g、管道“|”(pipe line):上一个命令的 stdout 接到下一个命令的 stdin;

h、tee 命令是在不影响原本 I/O 的情况下,将 stdout 复制一份到档案去;

i、bash(ksh)执行命令的过程:分析命令-变量求值-命令替代(``和$( ))-重定向-通配符展开-确定路径-执行命令;

j、( )  将 command group 置于 sub-shell 去执行,也称 nested sub-shell,它有一点非常重要的特性是:继承父shell的Standard input, output, and error plus any other open file descriptors。

k、exec 命令:常用来替代当前 shell 并重新启动一个 shell,换句话说,并没有启动子 shell。使用这一命令时任何现有环境都将会被清除,。exec 在对文件描述符进行操作的时候,也只有在这时,exec 不会覆盖你当前的 shell 环境。

2. 基本IO

cmd > file              把 stdout 重定向到 file 文件中

cmd >> file             把 stdout 重定向到 file 文件中(追加)

cmd 1> fiel             把 stdout 重定向到 file 文件中

cmd > file 2>&1         把 stdout 和 stderr 一起重定向到 file 文件中

cmd 2> file             把 stderr 重定向到 file 文件中

cmd 2>> file            把 stderr 重定向到 file 文件中(追加)

cmd >> file 2>&1        把 stderr 和 stderr 一起重定向到 file 文件中

cmd < file >file2       cmd 命令以 file 文件作为 stdin,以 file2 文件作为 stdout

cat <>file              以读写的方式打开 file

cmd < file              cmd 命令以 file 文件作为 stdin

cmd << delimiter        Here document,从 stdin 中读入,直至遇到delimiter 分界符

参考技术A 这不是报错,只是提示,后台执行程序的输出都被重定向到nohup.out文件 参考技术B 原程序的的标准输出被自动改向到当前目录下的nohup.out文件,起到了log的作用。 参考技术C 把报错的原来信息发出来,不要发翻译过了

以上是关于sql正常执行,在程序中报错的主要内容,如果未能解决你的问题,请参考以下文章

直接执行sql语句查询很快,在程序中报sql超时。

pip升级到18.0版本过程中报错解决方法

linux中报错“把输出追加到nohup.out”啥意思?

项目在eclipse中正常,在idea中报错

mybatis 中用insert into select ..... 报错命令未正确结束,但把这句sql放到plsql中执行正常

ojdbc.jar在maven中报错(下载不了)