草庐IT

oracle-call-interface

全部标签

java - 使用 jdbc 与 oracle 11.2 通信时 ResultSet.next() 挂起

我们有一个使用jdbc与oracle11.2通信的java应用程序。我们正在使用oracle-jdbc-7.jarCreated-By:20.12-b01(SunMicrosystemsInc.)Implementation-Vendor:OracleCorporationImplementation-Title:JDBCImplementation-Version:12.1.0.1.0我们也在使用Statement.setQueryTimeout()但是,每隔几天,与oracle通信的线程就会在执行ResultSet.next()时挂起。代码如下所示:PreparedStatemen

java - 谁能解释 Proguard 配置设置 : -keep @interface *

这是有问题的配置设置:-keep@interface*这篇文章中引用了此设置:https://stackoverflow.com/a/17437740/367544Proguard手册中的此处:https://www.guardsquare.com/en/proguard/manual/troubleshooting#notkept但手册(或帖子)并未解释此配置设置的工作原理或原因。我认为此配置值会保留在您的应用程序中定义的任何注释。我在这里强调defined这个词是因为我想将它与used注释的地方进行比较。因此,如果我在我的代码中定义了一个注释,如public@interfaceMy

java - 事务回滚后oracle undo sequence会增加吗?

我有一个Spring应用程序,其中Hibernate作为ORM,Oracle数据库作为RDBMS。假设我在数据库中的表名是entity_tbl,entity_seq是我的表的序列。在@Transaction的保存方法中,实体被保存,保存行后,我抛出回滚事务的异常。如下所示,@ServiceclassEntityServiceextendsGenericService{@AutowiredEntityRepositoryrepo;@Transactional@Overridepublicvoidsave(Entityentity){repo.save(entity);if(true)th

java - 将 Types.NVARCHAR 与 oracle JDBC 驱动程序一起使用以处理西里尔字符

我正在尝试使用"NewMethodsforNationalCharacterSetTypeDatainJDK1.6",以获得处理西里尔字符的标准JDBC解决方案,但是当执行到达具有NVARCHAR类型的任何行时,例如:preparedSelect.setObject(3,"суббота",Types.NVARCHAR);然后我得到这个异常:java.sql.SQLException:Invalidcolumntypeatoracle.jdbc.driver.SQLStateMapping.newSQLException(SQLStateMapping.java:70)atoracle

java - 使用@annotations 来标记监听器方法而不是带有方法的接口(interface)是个好主意吗?

首先是的——这是主观的。我最近注意到一些库似乎在某些类中使用让用户标记监听器方法作为监听器使用不同的注释来记录不同的事件。Infinispan和WELD就是这种方法的例子。我讨厌这种模式的地方没有类型安全需要阅读doco以找出事件的正确类型签名,而不仅仅是实现。对于实现者来说,这会非常困惑,因为他们需要更多的支持代码来发现和验证提交的监听器类、保留该方法并分派(dispatch)它等。反射分派(dispatch)的东西使触发事件变慢。当然,可以使用ASM生成一个真正的类,但与触发一个简单的listener.onEvent相比,这需要做更多的工作...可能的原因使细粒度的监听器成为可能。

java - 具有反向关系的通用接口(interface)

我想创建两个具有反向关系的接口(interface)。publicinterfaceItem>>{publicCgetCategory();publicvoidsetCategory(Ccategory);}我不确定表达式CextendsCategory>是否正确是正确的,但至少没有编译错误。publicinterfaceCategory{publicListgetItems();publicvoidsetItems(Listitems);}IextendsItem发出警告Itemisarawtype.ReferencestoItemshouldbeparametrized.我试过了I

java - Eclipse 中的接口(interface)绑定(bind)

我在Eclipse(Helios)/STS中有以下代码,它在运行Java应用程序时运行并打印控制台输出,尽管存在明显的编译问题publicinterfaceITest{Stringfunc();}publicstaticclassTestimplementsITest{voidprintFunc(){System.out.println("InsideTestFunction");}}publicstaticvoidmain(String[]args){Testtest=newTest();test.printFunc();}任何人都可以查明此Eclipse功能背后的原因。注意:在外部

java - Oracle JDBC 类型通过 getObject() 映射到 Java 对象类型 - 错误的文档?

这是文档链接:"MappingSQLandJavaTypes"让我们看看8.9.3JDBC类型映射到Java对象类型在行:TIMESTAMP-java.sql.Timestamp但是当我在TIMESTAMP列上使用getObject()和oracle数据库时,返回类型是oracle.sql.TIMESTAMP,它不能转换为java.sql.Timestamp我知道我可以使用getTimestamp(),但我需要getObject()来处理任何类型的结果集。是文档错了还是我错了? 最佳答案 文档是正确的,OracleJDBC驱动程序有

java - 线程 "main"com.google.apphosting.api.ApiProxy$CallNotFoundException : The API package 'mail' or call 'Send()' was not found 中的异常

我编写了一个使用gmail发送邮件的程序,如果我单独执行它,它工作正常,但是当我与googleappengine集成时,它给我以下错误,Exceptioninthread"main"com.google.apphosting.api.ApiProxy$CallNotFoundException:TheAPIpackage'mail'orcall'Send()'wasnotfound.atcom.google.apphosting.api.ApiProxy.makeSyncCall(ApiProxy.java:104)atcom.google.apphosting.api.ApiProx

java - Oracle Java KeyStore 实现是线程安全的吗?

我希望实现一个使用客户端证书身份验证的多线程SSL客户端,因此我需要为SSLContext提供一个KeyStore。我需要在多个线程上执行此操作。使用KeyStore的一个实例是否安全?我不会自己修改keystore,而且我假设SSL实现也不需要,因此该对象应该是有效的不可变的。 最佳答案 一般来说,JCA服务不是线程安全的,KeyStoreSpi不会对实现者强加任何线程安全要求。但是,如果您的key存储实际上是不可变的,并且您确保其初始化状态对所有线程可见,就没有问题。例如,将KeyStore存储在volatile变量中,或从类初