migration error with question2answer.rb のエラー

こんにちは、

Discourseプラットフォームへのサイト移行のために、question2answer.rb インポートスクリプトを使用しようとしています。しかし、移行中に以下のエラーが発生しています。

どのように修正すればよいでしょうか?:thinking: 使用しているのは、クリーンなUbuntu 18.04上のデフォルトのDockerコンテナです。

ユーザーのインポート中

**トレースバック**(最も最近の呼び出し順):

9: from script/import_scripts/question2answer.rb:560:in `\u0026lt;main\u0026gt;'

8: from /var/www/discourse/script/import_scripts/base.rb:47:in `perform'

7: from script/import_scripts/question2answer.rb:71:in `execute'

6: from script/import_scripts/question2answer.rb:85:in `import_users'

5: from script/import_scripts/question2answer.rb:555:in `mysql_query'

4: from /var/www/discourse/vendor/bundle/ruby/2.5.0/gems/rack-mini-profiler-1.0.2/lib/patches/db/mysql2.rb:22:in `query'

3: from /var/www/discourse/vendor/bundle/ruby/2.5.0/gems/mysql2-0.5.2/lib/mysql2/client.rb:130:in `query'

2: from /var/www/discourse/vendor/bundle/ruby/2.5.0/gems/mysql2-0.5.2/lib/mysql2/client.rb:130:in `handle_interrupt'

1: from /var/www/discourse/vendor/bundle/ruby/2.5.0/gems/mysql2-0.5.2/lib/mysql2/client.rb:131:in `block in query'

/var/www/discourse/vendor/bundle/ruby/2.5.0/gems/mysql2-0.5.2/lib/mysql2/client.rb:131:in `_query': **テーブル 'primary_db.users' が存在しません (** **Mysql2::Error** **)**

The users table that it’s looking for does not exist. Do you see a table called “users”? Do you have the right database?

I believe that I have the right database as I finished importing the database (on Discourse server) using

mysql -uroot -p -e 'CREATE DATABASE q2a' 

mysql -uroot -p q2a < q2a_dump.sql

I was able to back up my new database using

mysqldump -u username -p database_to_backup > backup_name.sql

and I downloaded it on my computer to verify that I have the proper database.

I have a table called qa_users

That’s the default. Did you change the db_prefix to “primary_dB” for some reason?

It was already included in the importer script as follows.

  # CHANGE THESE BEFORE RUNNING THE IMPORTER

  DB_HOST ||= ENV['DB_HOST'] || "localhost"
  DB_NAME ||= ENV['DB_NAME']
  DB_PW ||= ENV['DB_PW']
  DB_USER ||= ENV['DB_USER']
  TIMEZONE ||= ENV['TIMEZONE'] || "America/Los_Angeles"
  TABLE_PREFIX ||= ENV['TABLE_PREFIX'] || "qa_"
  MAIN_APP_DB_NAME = "primary_db"

So I didn’t change MAIN_APP_DB_NAME part as I am not familiar with that.

Did you set those environment variables? DB_NAME TABLE_PREFIX and so on?

I set all environment variables that I quoted above.

What did you set TABLE_PREFIX to?

export TABLE_PREFIX=“qa_”

Sorry. I’m in my logins and didn’t read the code carefully.

I’m pretty sure that I wrote that script, but I didn’t see that main all stuff down in the query; I’m sure I didn’t write that.

You’ll need to edit the script to have it use the database and prefix that you set in the environment variables.

What should I do about this one?

You’ll need to rewrite all of the dB queries.

I am sorry, Jay. I am not quite sure what you mean by that? Could you please give me some pointers here? I hope that you don’t mean by rewriting the importer script of question2answer.

Thanks

Not the whole script, just the database queries, and really just the FROM part. If you have a budget I can fix it for you.

I don’t have much budget but I would like to import small data from my old forum.

What do you have in mind?

Send an email to support@literatecomputing.com.

If I can log in remotely to the machine where you’re running the import it’ll help, as I’ll be able to see whether it works without sending it to you, having you import, tell me what’s wrong, and trying again.

It seems the question2answer importer was written for a case where there is an additional set of tables in the database for another app that was integrated with it. That is what the MAIN_APP_DB_NAME refers to.

We have done an import for a standalone q2a site recently and we have a modified version of the script which does not depend on this extra database. @RGJ was going to clean it up and submit it back in the next few weeks.

[こちら](https://gist.github.com/[Communiteq](https://www.communiteq.com) (旧 DiscourseHosting)/769eff2014d5482f0ab776de03dc3349) は、修正版のインポーターの Gist です。私が整理するのを待つ必要はありません。コードはすでにかなり問題ありません。

  • 他の謎のデータベース(おそらく独自のもの)への依存関係を削除
  • コメントをインポート
  • 最良の回答をインポート

Aw nice, thanks for that :beers:

最近、古いフォーラムから少量のデータを移行しようとした際、@RGJ さんが提供した[修正済みインポータースクリプト](https://gist.github.com/[Communiteq](https://www.communiteq.com) (formerly DiscourseHosting)/769eff2014d5482f0ab776de03dc3349)を使用すると、以下のエラーが発生しました。

既存のグループを読み込み中...

既存のユーザーを読み込み中...

既存のカテゴリを読み込み中...

既存の投稿を読み込み中...

既存のトピックを読み込み中...

ユーザーをインポート中

**トレースバック**(直近の呼び出し順):

11: from script/import_scripts/question2answer.rb:601:in `\u0026lt;main\u0026gt;'

10: from /var/www/discourse/script/import_scripts/base.rb:47:in `perform'

9: from script/import_scripts/question2answer.rb:70:in `execute'

8: from script/import_scripts/question2answer.rb:89:in `import_users'

7: from /var/www/discourse/script/import_scripts/base.rb:881:in `batches'

6: from /var/www/discourse/script/import_scripts/base.rb:881:in `loop'

5: from /var/www/discourse/script/import_scripts/base.rb:882:in `block in batches'

4: from script/import_scripts/question2answer.rb:106:in `block in import_users'

3: from /var/www/discourse/script/import_scripts/base.rb:247:in `create_users'

2: from /var/www/discourse/script/import_scripts/base.rb:247:in `each'

1: from /var/www/discourse/script/import_scripts/base.rb:278:in `block in create_users'

/var/www/discourse/script/import_scripts/base.rb:866:in `print_status': **undefined method `to_f' for #\u0026lt;Mysql2::Result:0x000056370b7c1f80\u0026gt; (** **NoMethodError** **)**

**もしかして: to_s**

**to_a**

**to_h**

このエラーの原因は何だと思われますか?:confused: