- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
在其他数据库语言中,您可以构造查询以定义表的实例,例如:
SELECT a.foo, a.bar FROM ACME a WHERE a.ID=1;
然后执行类似的操作
rs.getInt("a.foo");
获取此表第一行的值。我在 hsql 中执行这个看似基本的功能时遇到了麻烦,想知道是否有简单的解决方案或者其他人是否遇到过这个问题。如果我执行上述查询并尝试访问“a.foo”,我会使用 hsql 收到以下错误:
org.hsqldb.jdbc.Util.sqlException(Unknown Source)
org.hsqldb.jdbc.jdbcResultSet.findColumn(Unknown Source)
org.hsqldb.jdbc.jdbcResultSet.getInt(Unknown Source)
但是,如果我将访问权限更改为
rs.getInt("foo");
一切正常。是什么赋予了?以这种方式定义查询时,为什么 hsql 难以检索“a.foo”?这一系列命令在 MySQL 中运行良好。
最佳答案
我不知道其他 dbms 的行为如何使用这种语法,但 hsqldb 的行为似乎与
的规范相匹配 int java.sql.ResultSet.getInt(String columnLabel) throws SQLException
Retrieves the value of the designated column in the current row of this ResultSet object as an int in the Java programming language.
参数:
columnLabel the label for the column specified with the SQL AS clause. If the SQL AS clause was not specified, then the label is the name of the column Returns:
在您的查询中,**a.fo**
代表 fo
列。它不是别名。如果你想使用别名,你可以试试:
SELECT a.foo as 'myFoo', a.bar FROM ACME a WHERE a.ID=1;
然后得到这样的值:
rs.getInt("myFoo");
关于java - hsql Java表列访问问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41024995/
当我打开并连接 HSQL DB Manager (Swing) 时,Java 代码无法连接到数据库并抛出此错误: java.sql.SQLException: Database lock acquis
是否可以限制使用 Hibernate/HQL 更新的行数?例如: Query q = em.createQuery("UPDATE MyObj o Set o.prop = :prop"); q.se
我第一次使用 HSQL。当我使用 HSQL 数据库服务器引擎连接 DatabaseMAnagerSwing 时,我看到了 公共(public) 架构已经存在,并且它包含该架构下的一些表,例如客户等。
我在自动化组件测试中使用 HSQLDB 作为数据库。它模拟生产环境的 Oracle 数据库。 在我的 SQL 代码中,我在架构范围内定义了一个序列,例如 CREATE SEQUENCE THE_SCH
我正在使用嵌入式 HSQL 数据库服务器。有什么方法可以确定打开的 Activity 连接数吗? 最佳答案 是的。 SELECT COUNT(*) FROM INFORMATION_SCHEMA.SY
我得到以下信息: java -jar ./sqltool/sqltool.jar inlineRc=url=jdbc:hsqldb:hsql://192.168.99.100/test,user=sa
我正在使用 JUnit 来测试应用程序。我决定使用 HSQL 在运行时创建内存数据库。当我模拟 Oracle 数据库时,这工作得很好。然而,当我尝试模拟现有的 DB2 数据库时,我遇到了一个问题。我们
我有这个 postgres 表: CREATE TABLE News ( tags text[](10), contract varchar(40), ..
有什么方法可以在 HSQL 的创建表中为元素创建大写默认值 CREATE TABLE IF NOT EXISTS "job" ( "id" INTEGER IDENTITY, "jobI
我正在编写一个必须集成到现有旧架构中的系统应用程序。为此,我必须访问表中的位掩码字段;像这样: SELECT * FROM directory WHERE (status & 64) | (statu
我正在为使用分层子句连接的查询编写测试用例。HSQL Db 中似乎不支持此子句。 是否有任何替代方法可以测试查询或编写执行相同操作的不同查询。 查询很简单 SELECT seq.nextval FRO
在其他数据库语言中,您可以构造查询以定义表的实例,例如: SELECT a.foo, a.bar FROM ACME a WHERE a.ID=1; 然后执行类似的操作 rs.getInt("a.fo
我有一个 Oracle 数据库,我必须在其中使用序列作为主键。这一切都很好,因为我可以控制序列号。我的问题是我的测试。我使用 Spring 创建了一个 HSQL 数据库并对此进行了测试。这个数据库是通
我正在尝试使用 hsqldb-2.3.4 从 Spring 应用程序连接。 我使用以下详细信息创建了数据库 Type : HSQL Database Engine Standalone Driver:
我曾与 oracle 合作,在哪里选择查询是特定行范围内的数据: SELECT * from TABLE WHERE rownum>0 AND rownum<=10 HSQL 中对应的查询是什么? 最
如何关闭 HSQL 中表名和列名的强制大写模式? hsqldb 2.3.1 操作系统: Windows 7 x64 最佳答案 HSQLDB documentation 中解释了有关此问题的规则。 :
我想将类似@Version 的列更新为应用程序管理的悲观锁。 这些是我想采取的步骤: 获取序列的下一个编号 选择前 50 条记录并使用序列号更新类似 @version 的列。 现在选择回匹配该序列的那
我正在使用 Hibernate 创建 HSQL 内存数据库。 Hibernate 配置文件中的连接 URL 如下所示 jdbc:hsqldb:mem:mock_db 模式的默认名称是 Public .
我只是对某些事情感到好奇。我在我的项目中使用 hsql(当然是嵌入式的)。有时我觉得需要可视化 hibernate 正在生成的内容。我拿了一份 dbvisualizer 的免费副本。这是 hsqljd
我有一个名为 ProdTransaction 的实体。我正在保存两条 ProdTransaction 类型的记录。独立运行时,两个插入都会成功。我的意思是 tranDAO.save(record1)
我是一名优秀的程序员,十分优秀!