sql >> データベース >  >> RDS >> PostgreSQL

エラー:ライブラリ「/opt/PostgreSQL/9.0/lib/postgresql/plperl.so」を読み込めませんでした:libperl.so:

    言語plperluを作成しようとしたときに、上記のエラーがスローされました。これは、ライブラリlibperl.soが欠落していることを示しています。この問題を解決し、PostgreSQLでplperlu言語を正常に作成するために実行された手順を確認してください。

    方法1(libperl.soを検索し、その場所へのソフトリンクを作成する)

    postgres=# create LANGUAGE plperlu;
    ERROR: could not load library "/opt/PostgreSQL/9.0/lib/postgresql/plperl.so": libperl.so: cannot open shared object file: No such file or directory
    postgres=# q

    次に、ボックスでファイルlibperl.soを検索し、その場所をLD_LIBRARYPATHに追加します。ユーザーをpostgresに切り替えることを忘れないでください。

    [root@localhost /]# find -name libperl.so
    ./usr/lib/perl5/5.10.0/i386-linux-thread-multi/CORE/libperl.so
    ./usr/lib/perl5/CORE/libperl.so
    ./usr/lib/perl5/5.10.0/i386-linux-thread-multi/CORE

    [root@localhost /]# su - postgres

    LD_LIBRARY_PATHを設定します

    -bash-4.1$ export LD_LIBRARY_PATH=/usr/lib/perl5/5.10.0/i386-linux-thread-multi/CORE:$LD_LIBRARY_PATH

    クラスタを再起動して変更を有効にします。

    -bash-4.1$ pg_ctl restart
    waiting for server to shut down....... done
    server stopped
    server starting

    これで、言語を作成する準備が整いました。

    -bash-4.1$ psql
    psql (9.0.1)
    Type "help" for help.

    postgres=# create LANGUAGE plperlu;
    CREATE LANGUAGE

    方法2(最新のActivePerlをインストールする)

    ステップ1:
    ActivePerlをインストールした後、LD_LIBRARY_PATHを設定します。

    postgres@localhost:/opt/ActivePerl-5.12/lib/CORE> export LD_LIBRARY_PATH=/opt/ActivePerl-5.12/lib/CORE:/opt/PostgreSQL/9.0/lib/postgresql

    ステップ2:

    postgres@localhost:/opt/PostgreSQL/9.0/lib/postgresql> ldd plperl.so 
    linux-vdso.so.1 => (0x00007fff8cf79000)
    libperl.so => /opt/ActivePerl-5.12/lib/CORE/libperl.so (0x00007fbd3d654000)
    libnsl.so.1 => /lib64/libnsl.so.1 (0x00007fbd3d40a000)
    libdl.so.2 => /lib64/libdl.so.2 (0x00007fbd3d206000)
    libm.so.6 => /lib64/libm.so.6 (0x00007fbd3cfb0000)
    libcrypt.so.1 => /lib64/libcrypt.so.1 (0x00007fbd3cd74000)
    libutil.so.1 => /lib64/libutil.so.1 (0x00007fbd3cb71000)
    libpthread.so.0 => /lib64/libpthread.so.0 (0x00007fbd3c954000)
    libc.so.6 => /lib64/libc.so.6 (0x00007fbd3c5f5000)
    /lib64/ld-linux-x86-64.so.2 (0x00007fbd3dad8000)

    ステップ3:

    postgres@localhost:/opt/PostgreSQL/9.0/lib/postgresql> pg_ctl restart
    postgres@localhost:/opt/PostgreSQL/9.0/lib/postgresql> psql
    psql (9.0.2)
    Type "help" for help.

    postgres=# create language plperlu;
    CREATE LANGUAGE

    コメントを投稿してください。


    1. MySQLのLEN()と同等のものは何ですか?

    2. MariaDBでのREGEXP_REPLACE()のしくみ

    3. SQL Serverの2つの日付間の時間差(10進数)を計算するにはどうすればよいですか?

    4. OracleシステムがUnicodeまたはマルチバイト文字をサポートするように設定されているかどうかを確認するにはどうすればよいですか?