質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

2回答

4270閲覧

MySQLの区切り文字について

corazon

総合スコア10

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

0クリップ

投稿2016/09/20 07:05

MySQL(A5SQLを利用)を利用しています。
ファイルクラスのgetAbsolutePath()でcsvファイルのファイルパスを取得して
LoaderでDBに一括登録する仕組みを作っているのですが
ファイルパスの区切り文字が""になってしまい
MySQLだと"/"しか区切り文字として認識しないために上手く実行できません。
getAbsolutePath()の区切り文字をバックスラッシュからスラッシュに変更する方法、
あるいは、SQL文でバックスラッシュを許容させることが実現可能な方法など
ご存知の方おられましたらご教示の程お願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

getAbsolutePath()を実行すると
”\”
がファイルパスの区切り文字として返ってきます。

MYSQLで有効なファイルパスの区切り文字は
"\"or "/" なので変換してはいかがでしょうか?

具体的には
path = getAbsolutePath().replaceAll("", "/")
or
path = getAbsolutePath().replaceAll("", "\")
としてはいかがでしょうか?

投稿2016/09/20 21:15

Yatsurugi

総合スコア1628

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

MySQLは詳しくありませんが、調べました。

MySQLでは、バックスラッシュはエスケープするための文字です。
エスケープすることによって、「\t」をタブ文字、「\n」を改行文字として扱えるようになるわけです。また、バックスラッシュそのものを格納したい場合は「\」とすれば良いです。詳細はマニュアルを参照してください。
https://dev.mysql.com/doc/refman/5.6/ja/string-literals.html

エスケープする必要がないという前提、つまり、タブ文字や改行文字を格納しなくても良いという前提であれば、NO_BACKSLASH_ESCAPESを有効にすれば良いようです。詳細は、次を参照してください。
https://dev.mysql.com/doc/refman/5.6/ja/sql-mode.html

一方、Javaの話になりますが、Windowsでもスラッシュ「/」が使えます。たとえば、「D:\docs\a.txt」というパスを、「D:/docs/a.txt」と書くことができます。

Java

1 File file = new File("D:/docs/a.txt");

以上から、2つの対応策が考えられます。

  1. MySQLでNO_BACKSLASH_ESCAPESを有効にする(そのかわり、エスケープができなくなる)
  2. Javaプログラムで、"\"を"/"に変換し、MySQLに格納する

投稿2016/09/20 07:48

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

corazon

2016/09/20 08:49

ご回答ありがとうございます。 getAbsolutePath()で取得するファイルパスの区切り文字は、「\」です。 これを「\\」若しくは「/」にすることで正しく通るようです。 教えていただいた、1の方法は試しました(SQL文「SET GLOBAL sql_mode = 'NO_BACKSLASH_ESCAPES'」の実行)が「\」を区切り文字と認識していないらしく解決できませんでした。 2のjavaプログラムで「\」→「\\」or「/」に置換する方法ですが、どのように実装すればよいでしょうか。
退会済みユーザー

退会済みユーザー

2016/09/20 09:08

String.replace("\\", "/")で一括変換できます。
KSwordOfHaste

2016/09/20 09:12

横から失礼します。 一度java.lang.StringのAPIドキュメントを調べてみることをお勧めします。「ほほぉこんな機能が!?」というのが色々見つかります。きっとあなたのこれからのプログラミングに役に立つと思います。特定の部分文字列を置換してくれるメソッドもそこに書いてありますよ。
退会済みユーザー

退会済みユーザー

2016/09/20 09:31

先程のAPIには誤りがありました。replaceではなくreplaceAllでした。 String path = file.getAbsolutePath().replaceAll("\\", "/")でやってみてください。
corazon

2016/09/23 00:32

>sipadan2003さん お礼が遅れましてすみません。 教えていただいた方法で正常に置換できました。ありがとうございました。 >KSwordOfHasteさん ご親切にありがとうございます。 一度調べさせていただきました。 時間があるときに改めてみてみようかなと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問