ホームページ データベース mysql チュートリアル DBM数据导入到mysql数据库方法

DBM数据导入到mysql数据库方法

Jun 07, 2016 pm 05:51 PM
mysqlデータベース

本文章分享一篇关于DBM数据导入到mysql数据库方法,有需要的同学可以参考一下本实例。

首先说明一下,我以前使用PERL,保存文件 用DBM,有5万多条记录,每条记录有15个字段。现在想用MYSQL,要吧记录导过来。
第一步,将所有的DBM记录导入到了一个文本文件,每个字段之间用TAB分开(就是"t"),每条记录换行结束。
第二部,将数据读入数组,并且打开数据库和定义预处理如下:

 代码如下 复制代码


$dbline=file("g:/allrecord.txt");  //将数据库记录读入到数组
$collen=array(8,50,80,20,20,30,3,20,1,1,20,35,35,35,2); #表里面每个字段的长度数值

$db=new i('localhost','me','mypass','allrecdb');
if(mysqli_connect_errno()) {
    echo "Can not connect db!";
    exit;
}
$q->query("SET names 'gb2312'");

$q="INSERT INTO customers VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)";

$s=$db->prepare($q); #预定义插入记录

//


数据库有15个字段,为了方便导入,已经设定全部类型为CHAR,长度从1到100不等,具体等同$collen的数值;
并且没有任何字段设置UNIQUE或者PRIMARY KEY;
在命令行用INSERT命令插入记录成功
//

 代码如下 复制代码
foreach($dbline as $line) {
    $rec=("t",trim($line));
    //这里反复测试过,$rec数组有15个值,并且我都把它strval了
    //    for($j=0;$j         $rec[$j]=substr($rec[$j],0,$collen[$j]);
    }
    for($i=0;$i         $rec[$i]=strval($rec[$i]);
    }
    $s->bind_param("sssssssssssssss",$rec[0],$rec[1],$rec[2],$rec[3],$rec[4],$rec[5],$rec[6],$rec[7],$rec[8],$rec[9],$rec[10],$rec[11],$rec[12],$rec[13],$rec[14]);
     $s->execute();
}
$s->close();
$db->close();
?>


经过几个小时的调试,发现任何字串超过字段长度就不能添加,所以做了如下处理。
1) 先把每个记录的每个字段的长度进行了处理,代码如下:
 

 代码如下 复制代码
   for($j=0;$j         $rec[$j]=substr($rec[$j],0,$collen[$j]);
    }

2)再处理插入

 代码如下 复制代码
$s->bind_param("sssssssssssssss",$rec[0],$rec[1],$rec[2],$rec[3],$rec[4],$rec[5],$rec[6],$rec[7],$rec[8],$rec[9],$rec[10],$rec[11],$rec[12],$rec[13],$rec[14]);

     $s->execute();
这样就可以插入记录了。


目前剩下的问题是,任何带有汉字的记录,都不能插入(在命令行可以)。
查了资料,在命令行alter  database crm character set 'gb2312',在脚本查询前加入$db->query("SET names 'gb2312'")
都没用。
也没找到my.ini去改default-character-set=gb2312
难道php5.5暂时不支持中文?

MYSQL太多稀奇古怪的提示,解决不了问题,所有装上了SQLITE,在命令行导入文本记录,发现了问题:

1)某些字段中存在换行符,但是在任何文本编译器中不换行或者不显示。这样会在导入的时候,1行变成2行,列参数自然不对了。
解决方案: 用str_replace($line,char(13));把每行内的换行符替换掉,然后把所有记录存入tmp.txt

2)再进行命令行的导入

 代码如下 复制代码
sqlite3>.import tmp.txt customers
sqlite3> count(*) from cusomers;

57491

显示导入成功。

可见,批量导入的时候,一定要处理好那些隐藏的特殊字符。
由于时间关系,没有测试MYSQL的情况。晚上有空再确认一下同样方案是否可行。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

PHP 開発の実践: PHPMailer を使用して MySQL データベース内のユーザーに電子メールを送信する PHP 開発の実践: PHPMailer を使用して MySQL データベース内のユーザーに電子メールを送信する Aug 05, 2023 pm 06:21 PM

PHP 開発の実践: PHPMailer を使用して MySQL データベース内のユーザーに電子メールを送信する はじめに: 現代のインターネットの構築において、電子メールは重要なコミュニケーション ツールです。 ECにおけるユーザー登録やパスワードのリセット、注文確認など、メール送信は欠かせない機能です。この記事では、PHPMailer を使用してメールを送信し、メール情報を MySQL データベースのユーザー情報テーブルに保存する方法を紹介します。 1. PHPMailer ライブラリをインストールする PHPMailer は

Go 言語と MySQL データベース: ホット データとコールド データを分離するには? Go 言語と MySQL データベース: ホット データとコールド データを分離するには? Jun 18, 2023 am 08:26 AM

データ量が増加し続けるにつれて、データベースのパフォーマンスがますます重要な問題になっています。ホット データとコールド データの分離処理は、ホット データとコールド データを分離できる効果的なソリューションであり、それによってシステムのパフォーマンスと効率が向上します。この記事では、Go 言語と MySQL データベースを使用してホット データとコールド データを分離する方法を紹介します。 1. ホットデータとコールドデータの分離処理とは ホットデータとコールドデータの分離処理とは、ホットデータとコールドデータを分類する方法です。ホット データとは、アクセス頻度が高く、パフォーマンス要件が高いデータを指します。

MySQL データベースのスキルをどの程度まで開発すれば、うまく活用できるでしょうか? MySQL データベースのスキルをどの程度まで開発すれば、うまく活用できるでしょうか? Sep 12, 2023 pm 06:42 PM

MySQL データベースのスキルをどの程度まで開発すれば、うまく活用できるでしょうか?情報化時代の急速な発展に伴い、データベース管理システムはあらゆる分野で不可欠かつ重要なコンポーネントになりました。一般的に使用されるリレーショナル データベース管理システムとして、MySQL には幅広い応用分野と雇用機会があります。では、MySQL データベースのスキルを適切に活用するには、どの程度まで開発する必要があるのでしょうか?まず、MySQL の基本原理と基礎知識を習得することが最も基本的な要件です。 MySQL はオープンソースのリレーショナル データベース管理です

Go 言語を使用して MySQL データベースの増分データ バックアップを実行する方法 Go 言語を使用して MySQL データベースの増分データ バックアップを実行する方法 Jun 17, 2023 pm 02:28 PM

データ量が増加するにつれて、データベースのバックアップの重要性がますます高まります。 MySQL データベースの場合、Go 言語を使用して自動増分バックアップを実現できます。この記事では、Go 言語を使用して MySQL データベース データの増分バックアップを実行する方法を簡単に紹介します。 1. Go 言語環境をインストールする まず、Go 言語環境をローカルにインストールする必要があります。公式 Web サイトにアクセスして、対応するインストール パッケージをダウンロードしてインストールできます。 2. 対応するライブラリをインストールする Go 言語には、MySQL データベースにアクセスするための多くのサードパーティ ライブラリが用意されています。

MySQL データベースを時系列分析に使用するにはどうすればよいですか? MySQL データベースを時系列分析に使用するにはどうすればよいですか? Jul 12, 2023 am 08:39 AM

MySQL データベースを時系列分析に使用するにはどうすればよいですか?時系列データとは、時間的な連続性と相関性を持つ、時系列に並べられたデータの集合のことです。時系列分析は、将来の傾向の予測、周期的な変化の発見、外れ値の検出などに使用できる重要なデータ分析手法です。この記事では、MySQL データベースを使用して時系列分析を行う方法とコード例を紹介します。データ テーブルを作成する まず、時系列データを保存するデータ テーブルを作成する必要があります。数値を分析したいとします。

画像処理に MySQL データベースを使用するにはどうすればよいですか? 画像処理に MySQL データベースを使用するにはどうすればよいですか? Jul 14, 2023 pm 12:21 PM

画像処理に MySQL データベースを使用するにはどうすればよいですか? MySQL は強力なリレーショナル データベース管理システムであり、データの保存と管理に加えて、画像処理にも使用できます。この記事では、画像処理に MySQL データベースを使用する方法を紹介し、いくつかのコード例を示します。始める前に、MySQL データベースがインストールされており、基本的な SQL ステートメントに精通していることを確認してください。データベーステーブルの作成 まず、画像データを保存するための新しいデータベーステーブルを作成します。テーブルの構造は次のようになります。

Go 言語を使用して信頼性の高い MySQL データベース接続を確立するにはどうすればよいですか? Go 言語を使用して信頼性の高い MySQL データベース接続を確立するにはどうすればよいですか? Jun 17, 2023 pm 07:18 PM

大量のデータの保存と処理が必要なため、MySQL はアプリケーション開発で最も一般的に使用されるリレーショナル データベースの 1 つになりました。 Go 言語は、効率的な同時実行処理と簡潔な構文により、開発者の間でますます人気が高まっています。この記事は、読者が Go 言語を介して信頼性の高い MySQL データベース接続を実装し、開発者がデータをより効率的にクエリおよび保存できるようにする方法を示します。 1. Go 言語で MySQL データベースに接続するためのいくつかの方法 Go 言語で MySQL データベースに接続するには、通常、次の 3 つの方法があります: 1. サードパーティ ライブラリ

MySQL データベースと Go 言語: データ キャッシュを実行するにはどうすればよいですか? MySQL データベースと Go 言語: データ キャッシュを実行するにはどうすればよいですか? Jun 17, 2023 am 10:05 AM

近年、Go 言語は開発者の間でますます人気が高まっており、高パフォーマンスの Web アプリケーションを開発するために推奨される言語の 1 つとなっています。 MySQL も広く使用されている人気のあるデータベースです。これら 2 つのテクノロジーを組み合わせるプロセスにおいて、キャッシュは非常に重要な部分です。 Go言語を使ってMySQLデータベースのキャッシュを扱う方法を紹介します。キャッシュの概念 Web アプリケーションにおいて、キャッシュはデータ アクセスを高速化するために作成された中間層です。主に、頻繁に要求されるデータを保存するために使用されます。

See all articles