play20 ebean在postgresql上生成了sql throws语法错误

play20 ebean在postgresql上生成了sql throws语法错误,第1张

概述我正在尝试使用 postgresql来运行我的play20应用程序,以便我可以使用并稍后部署到Heroku.我跟着这个 answer. 基本上,我连接到数据库(所以从本地应用程序连接到Heroku postgresql数据库工作),但我无法使用生成的1.sql进化初始化数据库.但是生成的sql没有工作,因为postgresql正在使用schema(无论如何它应该没有架构,但显然我做错了或数据库做错 我正在尝试使用 postgresql来运行我的play20应用程序,以便我可以使用并稍后部署到Heroku.我跟着这个 answer.

基本上,我连接到数据库(所以从本地应用程序连接到Heroku postgresql数据库工作),但我无法使用生成的1.sql进化初始化数据库.但是生成的sql没有工作,因为postgresql正在使用schema(无论如何它应该没有架构,但显然我做错了或数据库做错了什么).

create table user (ID                        bigint not null,email                     varchar(255),gender                    varchar(1),constraint pk_user primary key (ID));

结果

ERROR: Syntax error at or near "user"  position: 14 [ERROR:0,sqlSTATE:42601]

我通过向表名添加模式来修复它

create table public.user(  ...);

好的,一切正常,直到我尝试读取或写入数据库.我再次获得sql语法异常,无法使用数据库.似乎SQL查询有点错误.

有什么建议可能有问题吗?

在使用其他数据库而不是在生产中开发应用程序时,这是一个非常常见的错误,但幸运的是,这也是常见的解决方您仍然可以使用用户模型,但是您必须确保创建具有更改名称的数据库表:
@Entity@table(name = "users")public class User extends Model {    ...}

在大多数情况下,在控制器和型号中,名称切换对您来说是透明的.只有你必须记住交换机的地方才有RawSql个查询.

顺便说一下,最好在本地安装相同的数据库进行开发,因为大多数流行的数据库之间存在很多差异,比如其他保留关键字,其他允许的类型,甚至其他自动递增的ID方法,因此查找和修复正确的值更容易在localhost上.

总结

以上是内存溢出为你收集整理的play20 ebean在postgresql上生成了sql throws语法错误全部内容,希望文章能够帮你解决play20 ebean在postgresql上生成了sql throws语法错误所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1181573.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存