0

だから私は本当にPostgreSQLに慣れていないので、過去3日間はこれにこだわっています。PostgreSQL データベースをインポートする必要があります。データベースはフォルダー内にあり、さまざまな .tab ファイルがあります。PostgreSQL 9.1 リリースがあります。データベースは、可能なすべての権限を付与したユーザー postgres によってインポートされます。また、その言語に可能なすべての権限を付与しました。

スクリプトによって実行されるコマンドは次のとおりです。

    CREATE OR REPLACE FUNCTION unique_toplevel_corpus_name() RETURNS TRIGGER AS $$
DECLARE
        count INTEGER := 0;
BEGIN
        IF NEW.top_level = 'y' THEN
                PERFORM * FROM corpus WHERE corpus.name = NEW.name AND corpus.t$
                GET DIAGNOSTICS count = ROW_COUNT;
                IF count != 0 THEN
                        RAISE EXCEPTION 'conflicting top-level corpus found: %'$
                END IF;
        END IF;
        RETURN NEW;
END;
$$ language plpgsql;

コードは私のものではありません。これは提供されており、ローカル マシン (Ubuntu 12.04) で正常に動作し、db を問題なくインポートしますが、Ubuntu サーバー (これも 12.04) でのみ問題があります。

これは私が取得し続ける例外です:

@valian:/opt/annis/annis-service-2.2.1/bin$ ./annis-admin.sh import /home/FilesForAnnis/Korpora/relANNIS/relANNIS/
19:38:45.755 CorpusAdministration INFO: Importing corpus from: /home/FilesForAnnis/Korpora/relANNIS/relANNIS/
19:38:45.758 SpringAnnisAdministrationDao INFO: creating staging area
19:38:45.788 SpringAnnisAdministrationDao INFO: bulk-loading data
19:38:46.236 SpringAnnisAdministrationDao INFO: computing top-level corpus
Exception in thread "main" org.springframework.jdbc.BadSqlGrammarException: StatementCallback; bad SQL grammar [-- find the top-level corpus
ALTER TABLE _corpus ADD top_level boolean;
CREATE TRIGGER unique_toplevel_corpus_name BEFORE UPDATE ON _corpus FOR EACH ROW EXECUTE PROCEDURE unique_toplevel_corpus_name();
UPDATE _corpus SET top_level = 'n';
UPDATE _corpus SET top_level = 'y' WHERE pre = (SELECT min(pre) FROM _corpus);

-- add the toplevel corpus to the node table
CREATE INDEX tmp_corpus_toplevel ON _corpus (id) WHERE top_level = 'y';
ALTER TABLE _node ADD toplevel_corpus bigint;
UPDATE _node SET toplevel_corpus = _corpus.id FROM _corpus WHERE _corpus.top_level = 'y';
DROP INDEX tmp_corpus_toplevel;
]; nested exception is org.postgresql.util.PSQLException: ERROR: function unique_toplevel_corpus_name() does not exist
    at org.springframework.jdbc.support.SQLStateSQLExceptionTranslator.doTranslate(SQLStateSQLExceptionTranslator.java:98)
    at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:72)
    at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:80)
    at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:80)
    at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:406)
    at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:427)
    at annis.administration.SpringAnnisAdministrationDao.executeSqlFromScript(SpringAnnisAdministrationDao.java:617)
    at annis.administration.SpringAnnisAdministrationDao.executeSqlFromScript(SpringAnnisAdministrationDao.java:608)
    at annis.administration.SpringAnnisAdministrationDao.computeTopLevelCorpus(SpringAnnisAdministrationDao.java:226)
    at annis.administration.CorpusAdministration.importCorpora(CorpusAdministration.java:85)
    at annis.administration.CorpusAdministration$$FastClassByCGLIB$$ce864c53.invoke(<generated>)
    at net.sf.cglib.proxy.MethodProxy.invoke(MethodProxy.java:191)
    at org.springframework.aop.framework.Cglib2AopProxy$CglibMethodInvocation.invokeJoinpoint(Cglib2AopProxy.java:688)
    at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:150)
    at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:110)
    at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
    at org.springframework.aop.framework.Cglib2AopProxy$DynamicAdvisedInterceptor.intercept(Cglib2AopProxy.java:621)
    at annis.administration.CorpusAdministration$$EnhancerByCGLIB$$b6899e79.importCorpora(<generated>)
    at annis.administration.AnnisAdminRunner.doImport(AnnisAdminRunner.java:176)
    at annis.administration.AnnisAdminRunner.run(AnnisAdminRunner.java:74)
    at annis.administration.AnnisAdminRunner.main(AnnisAdminRunner.java:49)
Caused by: org.postgresql.util.PSQLException: ERROR: function unique_toplevel_corpus_name() does not exist
    at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2062)
    at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:1795)
    at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:257)
    at org.postgresql.jdbc2.AbstractJdbc2Statement.execute(AbstractJdbc2Statement.java:479)
    at org.postgresql.jdbc2.AbstractJdbc2Statement.executeWithFlags(AbstractJdbc2Statement.java:353)
    at org.postgresql.jdbc2.AbstractJdbc2Statement.execute(AbstractJdbc2Statement.java:345)
    at org.springframework.jdbc.core.JdbcTemplate$1ExecuteStatementCallback.doInStatement(JdbcTemplate.java:420)
    at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:395)
... 16 more

jdbc posgtres コネクタも更新しました。すべてが完全に機能するローカルマシンとサーバーの唯一の違いは、ローカルマシンにJava 1.6ではなくJava 1.7があることですが、それが問題になるとは思いません。

他に何を試すことができるかわかりません...

4

1 に答える 1

0

これは Ubuntu の問題ではありません。これは、データベースのインポートに問題があります。データベースのインポート エラーは、トリガー機能が不足していることを示しています。

さらに、コードがあなたのものではないことも知っています。トリガーを部分的な一意のインデックスに置き換えることができる範囲で、パフォーマンスは大幅に向上します。

コードがあなたのものではない場合、関数がそこにない理由についてそれを書いた人にフォローアップする必要がありますが、そうするときは、トリガーをこれに置き換えることについてフォローアップすることをお勧めします:

 CREATE UNIQUE INDEX ON corpus(name) WHERE corpus.t;

これにより、パフォーマンスが向上し、メンテナンスが容易になります。

于 2013-05-02T00:53:11.297 に答える