- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
无论如何,我有一个像这样的java程序,它完全可以工作。
1 import java.sql.*;
2 import org.netezza.*;
class Conn {
public static void main (String args []) throws SQLException {
6 try{Class.forName ("org.netezza.Driver");
7 }
8 catch (ClassNotFoundException e) {
9 System.out.println("You made it to here");
10 e.printStackTrace();
11 }
12
13 Connection conn = DriverManager.getConnection("jdbc:netezza://server/dbname", "user", "pass");
14
15 Statement stmt = conn.createStatement();
16 ResultSet rset = stmt.executeQuery("SELECT 'foo'");
17 while (rset.next()){
18 System.out.println(rset.getString(1));
19 }
20 stmt.close();
21 conn.close();
22 }
23 }
但是,当我尝试遵循互联网上的每一个普通 JDBC + Jruby 教程时,我都会收到此代码中普遍存在的错误“NativeException:java.sql.SQLException:没有合适的驱动程序”。
1 require 'java'
2 require 'jruby'
3 require 'nzjdbc.jar'
4 #F = java.io.File
5 #class_loader = JRuby.runtime.jruby_class_loader
6 #class_loader.add_url(F.new('path').to_url)
7 #class_loader.add_url(F.new('nzjdbc.jar').to_url)
8
9 include_class "java.sql.DriverManager"
10 include_class "org.netezza.Driver"
11
12 p $CLASSPATH
13 p $LOAD_PATH
14
15 server = 'server'
16 databaseName = 'dbname'
17 user = 'user'
18 pass = 'pass'
19
20 p DRVRMAN = org.netezza.Driver.new
21
22 begin
23 #clazz = Java::JavaClass.for_name("org.netezza.Driver")
24 clazz = java.lang.Class.for_name("org.netezza.Driver", true, JRuby.runtime.jruby_class_loader)
25 #java.lang.Thread.currentThread.setContextClassLoader(JRuby.runtime.jruby_class_loader)
26 #java.sql.DriverManager.registerDriver(Java::OrgNetezza::Driver.new)
27 url = "jdbc:netezza://" + server + "/" + databaseName
28 p url
29 conn = DriverManager.getConnection(url, user, pass)
30 stmt = conn.create_statement
31 rs = stmt.execute_query("SELECT 2 + 2")
32
33 while rs.next
34 p [rs.get_int(1)]
35 end
36 ensure
37 rs.close rescue nil
38 stmt.close rescue nil
39 conn.close rescue nil
40 end
我已经尝试了所有我能找到的方法来解决这个问题,包括检查 activerecord-jdbc 和 dbi-jdbc 实现。这非常令人沮丧,我想除了类加载器、加载路径和类路径有问题之外,我真的不明白发生了什么。不管怎样,我希望有人能一步步解释 DriverManager 如何在 Java 中注册驱动程序,以及为什么 java 代码完全成功,而 ruby 代码(看起来等效)却不能帮助我减轻这些错误。
(此外,任何“安装 X gem”在这种情况下都不起作用,因为必须克服大量官僚主义才能允许任何新内容进入该系统)
最佳答案
我在使用 Apache CXF 时遇到过这种情况。我最喜欢的解决方案是
not waste time making jruby code work and simply have a java class do that for you
,100% 保证有效。在你的情况下,你可以编译/jar你的Conn类并从jruby调用它,就像
Java::Conn.main()
你的jar可以放在jruby/lib中。
PS:我发现您已经尝试了多种方法来使其发挥作用。可能Nick Sieger可以提供对这些类加载问题的一些见解。
关于java - Jruby、JDBC、Netezza,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6128643/
在 tomcat 内的 jruby/rack 中使用 jruby 时,如何/在哪里为 jruby 设置 --fast 模式? 此 --fast 模式在此页面中进行了说明 jruby performan
任何教程或博客都可以从 JRuby on Rails 开始 哪个指导我安装和小型 JRuby on Rails 应用程序? 我已经浏览了本演练和教程(https://github.com/jruby/
无法使用 jruby 启动 rails5,出现以下错误。 gavinyap@gavin-ubuntu ~/Development/rails5app rails s DEPRECATION W
我制作了一个 NSIS 脚本来为 Rails 应用程序创建安装程序。该应用程序使用 JRuby 和 Java。 在安装程序的第一部分中,我设置了环境变量:我将 jruby\bin 添加到 PATH 并
当我的 jruby 程序意外启动并向我提供堆栈跟踪时,这几乎是不可理解的。它充满了显然来自内部解释器的行,这让我很难弄清楚我的实际程序的实际调用堆栈是什么。 类似的东西(只是摘录): from
如何/在何处为在 jruby-rack/tomcat 中运行的 jruby 设置 --profile.api 选项? 此选项记录在如何分析代码块中 here 最佳答案 使用 JRUBY_OPTS 将无
我无法让 jruby 在没有 hack 的情况下使用 Rails 4: 在 railties/lib/rails/engine.rb 中,我必须用 const_get 初始化 Railties,否则
我需要将我的 JRuby 应用程序编译成一个独立的 JAR 文件。我怎样才能做到这一点? 最佳答案 Warbler 1.3.0 或更新版本也可用于制作可执行 JAR 文件。 快速说明。确保您在此处使用
我正在尝试将 Rails 应用程序转换为 jruby on Rails。目前,jruby script/delayed_job run给出: /usr/lib/jruby/lib/ruby/gems/
我通过在 config/application.rb 中添加了一些外部 jar 到我的 CLASSPATH : require 'java' $CLASSPATH << "#{File.dirname
目前在 Jruby 中编写类似的 java 类时遇到问题。 示例: 在 Java 中: public class Client extends ClientConnection { //do s
jruby 1.7.23 (1.9.3p551) 2015-11-24 f496dd5 在 Java HotSpot(TM) 64 位服务器 VM 1.7.0_79-b15 +jit [Windows
我正在尝试通过最新版本的 Jruby (1.5.1)、Ruby 1.8.7 和 Java 1.6.0_06 执行一些自定义 Java 代码。我已经尝试了类文件并将其放入 jar 方法中。当我尝试 re
文档似乎表明,为了将 Java 类导入到 JRuby 中,它们必须位于 JAR 文件中: “为了使用 JRuby 中的 jar 文件中的资源,jar 文件必须位于类路径上,或者您可以使用 requir
我在 Windows/JRuby 上使用 watir-webdriver。我的开发一直使用 Firefox。 Watir::Browser.new :firefox 对于部署,我需要一个 headle
我正在使用 JRuby 编写 Java 脚本。通过使用 JRebel,我可以自动将更改的 Java 类重新加载到 JRuby JVM 中,而无需重新启动。当我添加一个新的 Java 方法时,JRebe
我试图在 JRuby 中传递一个二进制字符串作为 byte[]通过一些Java库并再次进入JRuby,我想将其转换回字符串,但我无法弄清楚如何在不弄乱字符串的情况下进行操作。 具体来说,我将 Ruby
在Java中运行Ruby脚本时,我们使用ScriptEngine jruby = new ScriptEngineManager().getEngineByName("jruby");,如果只需要调用
当前的 Trinidad gem 依赖于 jruby-rack 1.1.0,它在我的每一项 Assets 的开发日志中显示了一些错误 /Users/bijan/.rvm/gems/jruby-1.7.
环境 JRuby 版本:jruby 9.0.0.0 (2.2.2) 2015-07-21 e10ec96 Java HotSpot(TM) 64 位服务器 VM 25.65-b01,位于 1.8.0_
我是一名优秀的程序员,十分优秀!