这可能吗?我可以在连接URL上指定它吗?怎么做呢?
当前回答
在Go中使用"sql.DB"(注意带有下划线的搜索路径):
postgres://user:password@host/dbname?sslmode=disable&search_path=schema
其他回答
我认为没有办法在连接字符串中指定模式。看来你得执行了
set search_path to 'schema'
在建立连接以指定模式之后。
从9.4版开始,您可以在连接字符串中使用currentSchema参数。
例如:
jdbc:postgresql://localhost:5432/mydatabase?currentSchema=myschema
几年前,我向PostgreSQL JDBC驱动程序提交了一个更新版本的补丁来启用这个功能。你必须从源代码(在添加补丁后)构建PostreSQL JDBC驱动程序才能使用它:
http://archives.postgresql.org/pgsql-jdbc/2008-07/msg00012.php
http://jdbc.postgresql.org/
如果在你的环境中可能,你也可以将用户的默认模式设置为你想要的模式:
ALTER USER user_name SET search_path to 'schema'
我知道这个问题已经得到了回答,但是我在尝试为liquibase命令行指定模式时遇到了同样的问题。
更新 从JDBC v9.4开始,你可以像这样用新的currentSchema参数指定url:
jdbc:postgresql://localhost:5432/mydatabase?currentSchema=myschema
根据之前的补丁显示:
http://web.archive.org/web/20141025044151/http://postgresql.1045698.n5.nabble.com/Patch-to-allow-setting-schema-search-path-in-the-connectionURL-td2174512.html
建议的url是这样的:
jdbc:postgresql://localhost:5432/mydatabase?searchpath=myschema
推荐文章
- MySQL数据库表中的最大记录数
- 我如何得到一个字符串的前n个字符而不检查大小或出界?
- 我可以在Java中设置enum起始值吗?
- Java中的回调函数
- 从现有模式生成表关系图(SQL Server)
- c#和Java中的泛型有什么不同?和模板在c++ ?
- 在Java中,流相对于循环的优势是什么?
- Jersey在未找到InjectionManagerFactory时停止工作
- 在Java流是peek真的只是调试?
- Recyclerview不调用onCreateViewHolder
- 将JSON字符串转换为HashMap
- web - inf在Java EE web应用程序中用于什么?
- Java 8: Lambda-Streams,过滤方法与异常
- 将JsonNode转换为POJO
- 如何查看IntelliJ中的编译错误列表?