ローカルにSQLをインストールして実行してみた
data:image/s3,"s3://crabby-images/cdad2/cdad20ac9f3b97b27d7217c30f27ffb5156ee31a" alt=""
はじめに
自宅にあるiMacでは、SQLを実行できる環境が整っている。
しかし、現在私は快活Clubにいる。
気分転換と運動を兼ねて、外をぶらぶらしており、疲れて休憩中だ。
そこで、ブログを書こうとなり、どうせならSQLに関する記事を書こうとなった。
最近、仕事でSQLのサブクエリや、テーブル結合に触れる機会があったからだ。
参考にする記事
こちらの記事を参考にする。
ローカルにSQL環境を構築してSQLの練習をする方法(XAMPP使用版) (ynmarketing.jp)
XAMPPをインストールする
以下のサイトからインストールしていこう。
Download XAMPP (apachefriends.org)
バージョンは最新のPHP8.2.12でいいだろう。
data:image/s3,"s3://crabby-images/d05bc/d05bc2a55c7d4f58213365aefd50f03541fe7d07" alt=""
ダウンロードボタンを押すと以下の画面に遷移した。
data:image/s3,"s3://crabby-images/53882/538825410d663bf2b7a3ed8ade91c804eaa8d86c" alt=""
右上のダウンロードで、保存をクリックしよう。
そうすると、以下の画面になる。
data:image/s3,"s3://crabby-images/03ce1/03ce12adfff46d2bb6d9c5bcec1828b8185a21ef" alt=""
開くを押すと、以下の画面になった。
data:image/s3,"s3://crabby-images/e94cb/e94cb46cc7912259281235b0a6bcd79844ab8427" alt=""
antivirus running(アンチウイルスが走っている)ので、In some cases, this may slow down the installation of the software(ソフトウェアのインストールが遅くなる場合がある)と書いてある。
迷わず「はい」をクリックすると、以下の画面になった。
data:image/s3,"s3://crabby-images/604e0/604e0b671a10f5e0205d7bea278f36aa81aab372" alt=""
Because an activated User Accont Control on your system some functions of XAMPP are possibly restricted(ユーザーアカウントコントロールシステムが作動したことにより、あなたのXAMPPのいくつかの機能が制限された可能性があります)ということが書かれている。
きっと快活ClubにあるPCのセキュリティシステムによるものだろう。
OKを押すと、問題なくセットアップウィザードが起動した。
data:image/s3,"s3://crabby-images/8c6a2/8c6a267e14b8d8f8d5a88f663aee2b0e23c2d715" alt=""
Nextを押して、以下の画面では、MySQLとphpMyAdminを選択した。
data:image/s3,"s3://crabby-images/16202/1620220453be48dcfa62a39be742945c7afe3cc1" alt=""
インストール先フォルダは、デフォルトのままにしておいた。
data:image/s3,"s3://crabby-images/fd9f1/fd9f12e393d604c7b4255de7b975690f899dda00" alt=""
言語は日本語が選べなかったので、デフォルトの英語にした。
インストールが始まった。
data:image/s3,"s3://crabby-images/7243b/7243b72406a63f50e9a24a0019857a5020d8535e" alt=""
完了したら、以下の画面になった。
data:image/s3,"s3://crabby-images/45201/452015c1ccf31a34dc0227d2148abca826bd9c6f" alt=""
MySQLを起動してみた
MySQLのStartを押してみた。
data:image/s3,"s3://crabby-images/61a32/61a3252b9b06bbae4319e4419bcdc87c93be78f9" alt=""
現在カーソルが当たっているところに、データベースを作成するコマンドを打ってみた。
Shellをクリックして出てきたコマンドプロンプトにも打ってみたけど、データベースを作成することはできなかった。
テーブルの作成手順(MySQL) #DB – Qiitaを参考にして、以下のコマンドを打ってみていた。
CREATE DATABASE test;
そもそも、mysqlにログインしていないことが考えられる。
phpMyAdminを起動したい
XAMMPのコントロールパネルには、phpMyAdminのショートカットキーがなかったので、右のExplorerをクリックしてみた。
data:image/s3,"s3://crabby-images/51ab2/51ab2d29b85a76a1b4888338a9d7c1d5698d82e0" alt=""
この中に、phpMyAdminのフォルダがあった。
phpMyAdminがあることは確認できた。
どうやって起動するのか?
Apacheも起動してみた
参考サイトには、Apacheも起動するように書いてあった。
data:image/s3,"s3://crabby-images/0fe03/0fe03d462b8ea7ed091e1bb3b79a5767e3283fbd" alt=""
そのため、ApacheのStartボタンも押した。
data:image/s3,"s3://crabby-images/025f7/025f7d924a59a70b01b3b7f7d516af78da93a35d" alt=""
MySQLのAdminを押すと、phpMyAdminを起動することができた
これは分からなかった。
data:image/s3,"s3://crabby-images/abf03/abf0332932dc78b98bba493d5978985b9c61f125" alt=""
でも、MySQLのAdminをクリックすると無事に、phpMyAdminの起動画面を開くことができた。
data:image/s3,"s3://crabby-images/c0e03/c0e03acfe218d468da4c3bb7082ab4f12e274a26" alt=""
testデータベースを利用する
もともとあったtestデータベースを使用していこう。
data:image/s3,"s3://crabby-images/b1341/b13414015951b95cec16b22493e77ce882bdb160" alt=""
支出を管理するテーブル「expense」を作成する。
data:image/s3,"s3://crabby-images/b8ca2/b8ca2882abb94907441802c4ac7b4b0598fdccc6" alt=""
TEXT型のitemカラムと、INT型のpriceカラムを作成する。
data:image/s3,"s3://crabby-images/b819a/b819a07d1628b57ba560201d45e2bd637948c144" alt=""
無事、作成できたようだ。
data:image/s3,"s3://crabby-images/eb015/eb015e213679c8581d519a88cc5261873021e2fe" alt=""
ダミーデータを投入してみる
表示タブに作成したカラムがある。
data:image/s3,"s3://crabby-images/67fc4/67fc4c898f884eb07b7ef6dfad9cf7bd3dd464be" alt=""
しかし、データは空だ。
ダミーデータを投入するSQL文を書いていこう。
data:image/s3,"s3://crabby-images/5b81c/5b81c26a34eb7bc156ffe0d04cff4be0bbf03bc5" alt=""
SQLタブに移動する。
data:image/s3,"s3://crabby-images/3ebce/3ebce4980246d54abc97162c682577c1bfbb1932" alt=""
ここで、SQL文を書いていこう。
刈谷のジャンカラの平日昼料金のデータを追加する。
data:image/s3,"s3://crabby-images/22ceb/22cebcb65e227b8087e506435ecf5f73254b7f26" alt=""
警告が出ていたが、挿入できたようだ。
data:image/s3,"s3://crabby-images/4529e/4529e5600e4d4c217b2ff98da6b71a07f7a9f3c7" alt=""
警告は、testデータベースのexpenseテーブルのitemカラムに挿入した文字列の値が正しくないという意味。
表示を確認すると、itemが????になっていた。
data:image/s3,"s3://crabby-images/c0f38/c0f384e2f1ae645021a77d5345245124af1ef864" alt=""
文字化けを解消していこう
SQLでデータを追加すると日本語部分が?となり表示されない。 | プログラミング学習サイト【侍テラコヤ】 (sejuku.net)を確認すると、文字コードがUTF-8になっていないことが原因のようだ。
また、phpMyAdminで解決する方法について、有り難き記事を見つけた。
data:image/s3,"s3://crabby-images/219ed/219edf4e257a8a50a2911370604aab94154115e5" alt=""
この記事と同じ方法で、照合順序を設定した。
そして、先ほどのデータは以下のSQL文で削除。
data:image/s3,"s3://crabby-images/22712/22712dd6099b2c17c573000c7724080dfa062f04" alt=""
(expense)だとエラーになった。
()を付けずに以下のDELETE文で、正常に実行できた。
data:image/s3,"s3://crabby-images/e6901/e690116384391406269600efc97d1a2808065c30" alt=""
カッコつけないほうが上手くいくようだ。
素直に生きていこう。
エラーもなく正常に挿入できたようだ。
data:image/s3,"s3://crabby-images/dafe1/dafe1947e3f0fecbd9a09d287053410af15dd746" alt=""
ただ、先ほどと同じく、itemが????のままだった。
data:image/s3,"s3://crabby-images/6ea2b/6ea2bc6d009776cf2c5fb48ecac7f8a13f41c607" alt=""
itemカラムの照合順序が元の状態だったので、ここを変更してみる。
data:image/s3,"s3://crabby-images/9dea4/9dea4f1f57ed86b704140e6846c8cf5c380c6a72" alt=""
utf8-general_ciに変更して、先ほどのデータをDELETE文で削除して、同じデータをINSERT文で挿入した。
上手く行ったことが確認できた。
data:image/s3,"s3://crabby-images/031bd/031bd57accb452fab3db98859a5348074a0d3c2f" alt=""
また一つ、成功体験を得た。
こうやって、着実に前に進んでいきたい。
コメントを残す