database - H2数据库用户

标签 database h2

我在我的客户端-服务器应用程序中使用可嵌入的数据库 H2。

对于某些我需要创建的用户,只能查看表而无权更改它们。我认为创建非管理员用户足以满足我的情况。但是我在尝试执行查询 SELECT * FROM ADDRESS 时遇到以下异常:

org.h2.jdbc.JdbcSQLException: Недостаточно прав на объект "PUBLIC.ADDRESS"
Not enough rights for object "PUBLIC.ADDRESS"; SQL statement:
SELECT * FROM ADDRESS [90096-164] 
at org.h2.message.DbException.getJdbcSQLException(DbException.java:329) 
at org.h2.message.DbException.get(DbException.java:169) 
at org.h2.message.DbException.get(DbException.java:146) 
at org.h2.engine.User.checkRight(User.java:98) 
at org.h2.table.TableFilter.<init>(TableFilter.java:122) 
at org.h2.command.Parser.readTableFilter(Parser.java:1084) 
at org.h2.command.Parser.parseSelectSimpleFromPart(Parser.java:1686) 
at org.h2.command.Parser.parseSelectSimple(Parser.java:1793) 
at org.h2.command.Parser.parseSelectSub(Parser.java:1680) 
at org.h2.command.Parser.parseSelectUnion(Parser.java:1523) 
at org.h2.command.Parser.parseSelect(Parser.java:1511) 
at org.h2.command.Parser.parsePrepared(Parser.java:405) 
at org.h2.command.Parser.parse(Parser.java:279) 
at org.h2.command.Parser.parse(Parser.java:251) 
at org.h2.command.Parser.prepareCommand(Parser.java:217) 
at org.h2.engine.Session.prepareLocal(Session.java:415) 
at org.h2.server.TcpServerThread.process(TcpServerThread.java:250) 
at org.h2.server.TcpServerThread.run(TcpServerThread.java:146) 
at java.lang.Thread.run(Unknown Source) 

at org.h2.engine.SessionRemote.done(SessionRemote.java:565) 
at org.h2.command.CommandRemote.prepare(CommandRemote.java:67) 
at org.h2.command.CommandRemote.<init>(CommandRemote.java:46) 
at org.h2.engine.SessionRemote.prepareCommand(SessionRemote.java:437) 
at org.h2.jdbc.JdbcConnection.prepareCommand(JdbcConnection.java:1121) 
at org.h2.jdbc.JdbcStatement.executeInternal(JdbcStatement.java:164) 
at org.h2.jdbc.JdbcStatement.execute(JdbcStatement.java:152) 
at org.h2.server.web.WebApp.getResult(WebApp.java:1311) 
at org.h2.server.web.WebApp.query(WebApp.java:1001) 
at org.h2.server.web.WebApp$1.next(WebApp.java:964) 
at org.h2.server.web.WebApp$1.next(WebApp.java:967) 
at org.h2.server.web.WebThread.process(WebThread.java:166) 
at org.h2.server.web.WebThread.run(WebThread.java:93) 
at java.lang.Thread.run(Unknown Source)`

有没有实现目标的方法?

最佳答案

您必须授予创建的用户选择权。

GRANT SELECT ON TEST TO READONLY

更多信息:http://www.h2database.com/html/grammar.html#grant_right

关于database - H2数据库用户,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10198545/

相关文章:

使用 UNION/UNION ALL 和 Group By 的 MySQL 查询错误

php - MySQL 数据库连接类,函数不返回任何结果

spring-boot - Spring Boot H2 版本警告

intellij-idea - 无法连接到 Intellij 中的 h2 数据库

kubernetes - 将 JHipster 项目部署到 Kubernetes 上时获取 "Error while creating file "/target""

java - H2 数据库 : How to have lowercase for tablename?

php - 并发访问PHP+MySQL出现ID生成问题

database - 我的服务器使用 node.js,需要设置用户帐户,我应该使用哪个数据库程序?

php - 上传图片的更好方法?

h2 - 如何在 Quarkus 应用程序中设置 H2 数据库控制台 url