序文 多くの MySQL テスト シナリオでは、テスト用に一部のテスト データを手動で生成する必要があります。この記事では、ユーザー名、携帯電話番号、生年月日などのフィールドを生成できる MySQL の大規模テーブル ストレージを構築する手順について説明します。重複する携帯電話番号を除外して、実際のシナリオをシミュレートすることもできます。 1. スクリプトを生成する 組み立て手順: 次のストアド プロシージャは、ユーザー名、携帯電話番号、生年月日などのフィールドを含む大きなテーブルをバッチ生成するために使用されます。 このストアド プロシージャは uid を主キーとして使用するため、少数の重複した携帯電話番号が生成されます。重複をフィルタリングする SQL スクリプトは後で提供されます。 一度に一意の携帯電話番号を生成する場合は、次のスクリプトを変更して uid を削除し、mobile 列を主キーとして使用することを検討してください。 big_tableが存在する場合はテーブルを削除します。 prc_gen_user が存在する場合はプロシージャを削除します。 テーブル `big_table` を作成します ( `uid` int(11) NOT NULL AUTO_INCREMENT, `mobile` char(11) デフォルト NULL, `passwd` varchar(50) デフォルト NULL, `name` varchar(50) デフォルト NULL, `sex` tinyint デフォルト NULL, `birthday` 日時 デフォルト NULL、 `updated_time` 日時 デフォルト NULL、 主キー (`uid`) )ENGINE=InnoDB デフォルト文字セット=utf8; プロシージャprc_gen_user(l_cnt int)を作成します。 始める x INT DEFAULT 0 を宣言します。 p char(11) を宣言します。 x < l_cnt の場合 する x = x + 1 を設定します。 設定p = 連結('1', 部分文字列(キャスト(3 + (rand() * 10) % 7 AS char(50)), 1, 1), 右(左(トリム(キャスト(rand() AS char(50))), 11), 9)); big_tableにINSERT(モバイル、 パスワード、 名前、 セックス、 誕生日、 更新日時 値 ( p、 md5(天井(rand() * 1000000))、 連結( 部分文字列( 'Zhao Qiansun li Zhou Zheng Wang Feng Chen Zhu Wei Jiang Chen Han Yang Zhu Qin He Lu Shi Zhang Kong Cao Yan Hua Jin Jian Eng Bao Shi Tang Fei Lian Cen Xue Lei he ni tang yin luo hao wu an chang le yu yu shi fu pi qi yu yu yuan bu gu meng ping huang Zhu Dong Liang Du Ruan Lan Xi Ji Ma Qiang Lu Lou Wei Jiang Tong Yan Guo heng Lin Diao Zhon Zuo Shi Cui Ji Niu Gong '、 フロア(1 + 190 * ランド())、 1)、 部分文字列( : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : フロア(1 + 400 * ランド())、 1)、 部分文字列( : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : フロア(1 + 400 * ランド())、 1))、 天井(rand() * 10) % 2, 日付( 今() - 間隔 (20 + 天井(rand() * 100) % 40) 年)、 連結('2018-', 1 + 天井(rand() * 100) % 12, '-'、 1 + 天井(rand() * 100) % 28)) 重複キー更新の場合 updated_time = now(); 終了しながら; 終わり 2. データ入力 prc_gen_user(1000)を呼び出します。 クエリは正常、1 行が影響を受けました (1.38 秒) big_tableからcount(*)を選択します。 +----------+ | カウント(*) | +----------+ | 1000 | +----------+ セット内の 1 行 (0.00 秒) 「Leshami」著者、「http://blog.csdn.net/leshami」ブログを選択します。 +---------+------------------------------+ | 著者 | ブログ | +---------+------------------------------+ | レシャミ | http://blog.csdn.net/leshami | +---------+------------------------------+ 3. 重複するSQL文のフィルタリング big_tableから削除 WHERE mobile IN (SELECT mobile (u1.mobileから選択) big_table u1 から u1.mobileによるグループ カウント(*) > 1) a) AND uid NOT IN (SELECT uid FROM (SELECT min(u2.uid) AS uid big_table u2 から u2.mobileによるグループ count(*) > 1) b); を満たす IV. その他 この記事では、ユーザーデータ(名前/携帯電話番号/誕生日/パスワード)のMySQLバッチ作成を実装する次のコードを参照します。 batchGenerateUsers が存在する場合は削除プロシージャを実行します。 区切り文字 $$ CREATE PROCEDURE batchGenerateUsers() 始める DECLARE x INT デフォルト 0; p char(11) を宣言します。 x < 10000 の場合 x=x+1 を設定します。 p=concat('1', cast(3+(rand()*10)%7 as char(1)), right(left(trim(cast(rand() as char (20))), 11),9));を設定します。 my_users(mobile, passwd, name, sex, birthday, updated_time) に挿入します。 値(p, md5(天井(rand()*1000000))、 : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : 天井(rand()*10)%2、 日付(現在()-間隔(20+上限(rand()*100)%40)年)、 連結('2015-', 1+天井(rand()*100)%12,'-',1+天井(rand()*100)%28)) 重複キーの更新について 更新日時=現在(); 終了しながら; 終了 $$ #batchGenerateUsers() を呼び出します。 適切に修正してください。 要約する 上記はこの記事の全内容です。この記事の内容が皆さんの勉強や仕事に一定の参考学習価値を持つことを願っています。ご質問があれば、メッセージを残してコミュニケーションしてください。123WORDPRESS.COM を応援していただきありがとうございます。 以下もご興味があるかもしれません:
|
目次1. サブクエリとは何ですか? 2. サブクエリはどこに表示されますか? 3. Whereサブク...
SQL の基礎知識がある友人は、「クロステーブル クエリ」について聞いたことがあるはずですが、クロス...
目次1. データ操作言語 (DML) 2. データを追加する(挿入) 3. 既存のテーブルをコピーし...
背景まず最初に、私はフロントエンド開発の専門家ではないことを述べておきたいと思います。私の以前のコン...
目次1. 新しいプロジェクトを作成する2. 依存関係を追加する3. SpringコンテナにDrive...
弊社のネットワーク管理センターは管理センター兼サーバーとして機能します!各管理対象デバイスは、TCP...
目次これ方法オブジェクト内これを隠した厳密モードこれを変更してこれいつものように、まずはコードを見て...
目次MySQL クエリツリー構造1. ツリー構造について2. MySQLでカスタム関数を定義する方法...
本日、ローカル開発環境で突然「入力ファイルが指定されていません」というエラーが発生してしまいました。...
目次質問解決質問この問題には多くの理由があるようです。私の問題は、パラメータ付きのURLを更新できな...
目次1. scrapy_splash とは何ですか? 2. scrapy_splashの役割3. s...
ダウンロードダウンロードアドレス: https://redis.io/download /usr/l...
思いつきで、小さなボールが跳ね返るケーススタディを書いてみました。具体的な内容は以下のとおりです。主...
コンテンツ1. 読者に留まる理由を与える。ウェブページを面白く魅力的なものにしましょう。しかし、まず...
目次1. はじめに2. 設定手順1. はじめに1. NAT モード (VMnet8) は、仮想マシン...