Nas*_*ova 5 java database schema datasource derby
我创建了一个名为'movie_db'的数据库,将默认架构设置为APP.然后创建了一个名为"USERS"的示例表.
我与DB的连接如下:
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="org.apache.derby.jdbc.ClientDriver"/>
<property name="url" value="jdbc:derby://localhost:1527/movie_db"/>
<property name="username" value="root"/>
<property name="password" value="pass"/>
</bean>
Run Code Online (Sandbox Code Playgroud)
现在我想编写一些测试并尝试执行以下查询:
SELECT * FROM USERS;
Run Code Online (Sandbox Code Playgroud)
我得到了什么:
java.sql.SQLSyntaxErrorException: Table/View 'USERS' does not exist.
Run Code Online (Sandbox Code Playgroud)
当我准确指定我正在使用的架构时:
SELECT * FROM APP.USERS
Run Code Online (Sandbox Code Playgroud)
一切正常.
如何在查询中省略模式名称?
更新: 像Bryan说的那样,我创建了一个名为默认模式的用户,并使用此登录进行授权.这是在查询中省略模式名称的最简单方法.但是,如果我想使用多个模式,唯一的方法是明确设置模式.
基本上有两种方法来控制默认架构名称:
如果您尚未发出SET SCHEMA语句,则Derby将使用您的用户名作为模式名称.
因此,如果您以"APP"用户身份登录,并且未发出SET SCHEMA语句,则您的架构名称将为APP.