sju*_*dǝʊ 5 sql heroku playframework-2.0
我正在尝试使用postgresql来运行我的play20应用程序,以便我可以使用并稍后部署到Heroku.我听了这个回答.
基本上,我连接到数据库(所以从本地应用程序连接到Heroku postgresql数据库工作),但我无法使用生成的1.sql进化初始化数据库.但是生成的sql没有工作,因为postgresql正在使用模式(它应该在没有模式的情况下工作,但显然我做错了或者数据库做错了什么).
create table user (
id bigint not null,
email varchar(255),
gender varchar(1),
constraint pk_user primary key (id));
Run Code Online (Sandbox Code Playgroud)
结果
ERROR: syntax error at or near "user"
Position: 14 [ERROR:0, SQLSTATE:42601]
Run Code Online (Sandbox Code Playgroud)
我通过向表名添加模式来修复它
create table public.user(
...
);
Run Code Online (Sandbox Code Playgroud)
好的,一切正常,直到我尝试读取或写入数据库.我再次获得sql语法异常,无法使用数据库.似乎sql查询有点错误.
有什么建议可能有问题吗?
在使用其他数据库而不是在生产中开发应用程序时,这是一个非常常见的错误,但幸运的是,这也是常见的解决方 您仍然可以使用User
模型,但是您必须确保创建具有更改名称的数据库表:
@Entity
@Table(name = "users")
public class User extends Model {
...
}
Run Code Online (Sandbox Code Playgroud)
在大多数情况下,在控制器和型号中,名称切换对您来说是透明的.只有你必须记住开关的地方才是RawSql查询.
顺便说一下,最好在本地安装相同的数据库进行开发,因为大多数流行的数据库之间存在很多差异,比如其他保留关键字,其他允许的类型,甚至其他自动递增的id方法,因此查找和修复正确的值更容易在localhost上.