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

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

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

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

Q&A

解決済

1回答

2313閲覧

mysqlの多数桁インポートについて

pegy

総合スコア243

MySQL

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

0グッド

0クリップ

投稿2018/08/01 06:10

  1. ローカルのxlsファイルについて

以下の値が入っております。

586922070734.895
  1. これをインポートするためにcsvファイルに変換すると以下のように置き換わります。
586922070735
  1. UTF-8Nでインポートすると何故か、

CSV 入力のカラム数が不正です (行: 1)。というerrorが出力されるため
これをTeraPadでUTF-8で保存して、再度インポートすると以下の値がレコードに保存されます。
構造は 桁数が多いものが予想されるため、bigint(30)を指定しております。他に、特段の指定はないです。

586

検索して、大抵は文字形式の問題で“CSV 入力のカラム数が不正です (行: 1)”のエラー解決するとあり
実際に、BOMの変更でインポートはできるようになったのですが、今度は何故か勝手に922...以降が切り捨てられて
格納されてしまいます。
問題の所在と解決方法について、アドバイスを頂けますでしょうか。
宜しくお願い申し上げます。


サーバ: localhost via TCP/IP
サーバの種類: MySQL
サーバのバージョン: 5.5.49-log - MySQL Community Server (GPL)
プロトコル バージョン: 10
ユーザ: root@localhost
サーバの文字セット: UTF-8 Unicode (utf8)

Apache/2.2.31 (Win32) DAV/2 mod_ssl/2.2.31 OpenSSL/1.0.2e mod_fcgid/2.3.9 mod_wsgi/3.4 Python/2.7.6 PHP/7.0.9 mod_perl/2.0.8 Perl/v5.16.3
データベースクライアントのバージョン: libmysql - 5.5.49
PHP 拡張: mysqli ドキュメント
PHP version: 7.0.9

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

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

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

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

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

guest

回答1

0

ベストアンサー

bigintでは小数点以下のデータを持てないです。
整数型 (真数値) - INTEGER、INT、SMALLINT、TINYINT、MEDIUMINT、BIGINT

浮動小数点型 (概数値) - FLOAT、DOUBLE を利用されては?

投稿2018/08/01 06:32

Orlofsky

総合スコア16415

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

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

pegy

2018/08/01 07:18

有難うございます。 小数点未満は自動で切り捨てて欲しいため、敢えて切り捨てないデータでbigint型を選択してみました。 586で切れてしまっているのは、3桁カンマ区切りが原因であることが分かりました。 csv(エクセル)上、書式でカンマ区切りを設定するだけでも、mysqlでインポートすると カンマ認識されてしまうんですね、、
Orlofsky

2018/08/01 07:25

CSVではカンマを入れたら別項目に分かれます。
Orlofsky

2018/08/01 08:16

Excelでは小数点以下の桁数を0にすると小数点以下1位で四捨五入されるのがデフォルトだったと思います。 浮動小数点型のワークテーブルを用意し、CSVを取り込んで TRUNCATE(カラム名) FROM ワークテーブル の結果をターゲットテーブルにINSERTされては?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問