JFinal

登录 注册

SQLServerException: '`' 附近有语法错误

public class DbTest {

	public static void main(String[] args) {
		Prop prop = PropKit.use("jdbc.properties");
		DruidPlugin dp = new DruidPlugin(prop.get("jdbc.url"), prop.get("jdbc.username"), prop.get("jdbc.password"),
				prop.get("jdbc.driver"));
		ActiveRecordPlugin arp = new ActiveRecordPlugin(dp);
		arp.addMapping("base_article", Article.class);
		dp.start();
		arp.start();
		System.out.println(JSON.toJSONString(Article.dao.findById(1)));
	}
}


运行如上代码,总是提示


Can not create Table object, maybe the table base_article is not exists.

Exception in thread "main" com.jfinal.plugin.activerecord.ActiveRecordException: com.microsoft.sqlserver.jdbc.SQLServerException: '`' 附近有语法错误。


但是数据库base_article 是存在的,使用beetlsql、hibernate测试都没问题,唯独使用ActiveRecord提示这个错误


使用的是 jFinal2.2

数据库使用的是SqlServer2008


评论

  • 08-22 22:57
    没设置方言造成的,添加一行代码: arp.setDialect(new SqlServerDialect());
  • 08-23 00:00
    @JFinal 谢谢,现在又遇到一个问题,当数据表的主键不是id而是如UserID这样的情况的时候,貌似没法使用findById的方法来直接查询,这种情况下如何快速的根据主键查询一个对象呢?
  • 08-23 00:01
    主键不是 id 的时候这样映射: arp.addMapping("user", "UserId", User.class);
  • 08-23 00:02
    此外,jfinal 2.2 已经将映射自动化生成了,不需要自己处理,在这里下载这个 demo,改改配置就可以生成了: http://www.jfinal.com/download?file=GeneratorDemo.java
  • 08-23 00:03
    如果使用的是 Db 查询这类非 "id" 为主键的表,可以用 Db.findById(tableName, "UserId", 123) 这种指定主键名的方式来做
  • 08-23 00:08
    @JFinal 明白了,初次接触jFinal,谢谢您的帮助。
  • 08-23 00:10
    @darren 感谢支持 jfinal 社区,多多关注社区动态
  • 08-23 09:26
    @JFinal 使用GeneratorDemo 生成代码的时候报“SQLServerException: 对象名 'CHECK_CONSTRAINTS' 无效。”,已经设置过方言了。
  • 08-23 10:27
    @darren 看是哪个表名无效,然后用 generator.addExcludedTable(tableName) 将这个表排除在外,因为可能是反射出来了一些生成器无权读取的表

    如果这类处理不了的表很多,可以通过 class MyMetaBuilder extends MetaBuilder 并覆盖掉其中的 isSkipTable(...) 方法来跳过这些表的处理。通过 generator.setMetaBuilder(new MyMetaBuilder()) 将自己实现的类注入进去
  • 09-21 12:50
    @JFinal public static DataSource getDataSource() {
    Prop p = PropKit.use("a_little_config.txt");
    C3p0Plugin c3p0Plugin = new C3p0Plugin(p.get("jdbc.url").trim(), p.get("jdbc.username").trim(), p.get("jdbc.password").trim(), p.get("jdbc.driverClassName").trim());
    ActiveRecordPlugin arp = new ActiveRecordPlugin(c3p0Plugin);
    arp.setDialect(new SqlServerDialect());
    c3p0Plugin.start();
    arp.start();
    return c3p0Plugin.getDataSource();
    }

    public static void main(String[] args) {
    // base model 所使用的包名
    String baseModelPackageName = "com.chine.model.base";
    // base model 文件保存路径
    String baseModelOutputDir = PathKit.getWebRootPath() + "/../src/com/chine/model/base";

    // model 所使用的包名 (MappingKit 默认使用的包名)
    String modelPackageName = "com.chine.model";
    // model 文件保存路径 (MappingKit 与 DataDictionary 文件默认保存路径)
    String modelOutputDir = baseModelOutputDir + "/..";

    // 创建生成器
    Generator gernerator = new Generator(getDataSource(), baseModelPackageName, baseModelOutputDir, modelPackageName, modelOutputDir);
    // 设置数据库方言
    //gernerator.setDialect(new MysqlDialect());
    gernerator.setDialect(new SqlServerDialect());
    // 添加不需要生成的表名
    //gernerator.addExcludedTable("adv");
    // 设置是否在 Model 中生成 dao 对象
    gernerator.setGenerateDaoInModel(true);
    // 设置是否生成字典文件
    gernerator.setGenerateDataDictionary(false);
    // 设置需要被移除的表名前缀用于生成modelName。例如表名 "osc_user",移除前缀 "osc_"后生成的model名为 "User"而非 OscUser
    gernerator.setRemovedTableNamePrefixes("t_");
    // 生成
    gernerator.generate();
    }

    数据库是sql server2008R2自动生成时总是报下面的错误:

    Build TableMeta ...
    Exception in thread "main" java.lang.RuntimeException: com.microsoft.sqlserver.jdbc.SQLServerException: 对象名 'CHECK_CONSTRAINTS' 无效。
    at com.jfinal.plugin.activerecord.generator.MetaBuilder.build(MetaBuilder.java:102)
    at com.jfinal.plugin.activerecord.generator.Generator.generate(Generator.java:210)
    at com.chine.model.GeneratorModel.main(GeneratorModel.java:54)
    Caused by: com.microsoft.sqlserver.jdbc.SQLServerException: 对象名 'CHECK_CONSTRAINTS' 无效。
    at com.microsoft.sqlserver.jdbc.SQLServerException.makeFromDatabaseError(SQLServerException.java:217)
    at com.microsoft.sqlserver.jdbc.SQLServerStatement.getNextResult(SQLServerStatement.java:1635)
    at com.microsoft.sqlserver.jdbc.SQLServerStatement.doExecuteStatement(SQLServerStatement.java:865)
    at com.microsoft.sqlserver.jdbc.SQLServerStatement$StmtExecCmd.doExecute(SQLServerStatement.java:762)
    at com.microsoft.sqlserver.jdbc.TDSCommand.execute(IOBuffer.java:6276)
    at com.microsoft.sqlserver.jdbc.SQLServerConnection.executeCommand(SQLServerConnection.java:1793)
    at com.microsoft.sqlserver.jdbc.SQLServerStatement.executeCommand(SQLServerStatement.java:184)
    at com.microsoft.sqlserver.jdbc.SQLServerStatement.executeStatement(SQLServerStatement.java:159)
    at com.microsoft.sqlserver.jdbc.SQLServerStatement.executeQuery(SQLServerStatement.java:661)
    at com.mchange.v2.c3p0.impl.NewProxyStatement.executeQuery(NewProxyStatement.java:327)
    at com.jfinal.plugin.activerecord.generator.MetaBuilder.buildColumnMetas(MetaBuilder.java:216)
    at com.jfinal.plugin.activerecord.generator.MetaBuilder.build(MetaBuilder.java:97)
    ... 2 more
  • 04-20 15:19
    @JFinal 在哪里下载demo呢
  • 03-15 10:00
    我这边生成时也报错,出错原因是 旧项目数据表 用的sql server关键字,经调试,建议:SqlServerDialect的forTableBuilderDoBuild改成"select * from [" + tableName + "] where 1 = 2";,表名加上[]就好啦
  • 03-15 12:03
    @WMN 可以通过继承 SqlServerDialect 扩展一个自己的 MyDialect 出来,覆盖掉 forTableBuilderDoBuild 方法,添加上 []

    sql server 目前没有对表名为关键字的问题添加 []
  • 03-15 14:13
    @JFinal 好的,多谢
  • 发送