ホームページ > php教程 > PHP开发 > 一般的に使用される MySQL コマンドの包括的なリスト

一般的に使用される MySQL コマンドの包括的なリスト

高洛峰
リリース: 2016-12-14 11:07:49
オリジナル
1589 人が閲覧しました

以下は、私たちがよく使用する非常に便利な MySQL コマンドです。以下にある # は、Unix コマンド ラインでコマンドを実行することを意味し、mysql> と表示されることは、現在 MySQL サーバーにログインしており、mysql コマンドが mysql クライアントで実行されていることを意味します。
MySQL にログインする場合は、-h を使用してホスト名を指定する必要があります。

# [mysql dir]/bin/mysql -h hostname -u root -p
ログイン後にコピー

データベースを作成します。

mysql> create database [databasename];
ログイン後にコピー

すべてのデータベースをリストします。

mysql> show databases;
ログイン後にコピー

データベースに切り替えます。

mysql> use [db name];
ログイン後にコピー

データベースのすべてのテーブルを表示します。

mysql> show tables;
ログイン後にコピー

データテーブルのフィールド形式を表示します。

mysql> describe [table name];
ログイン後にコピー

データベースを削除します。

mysql> drop database [database name];
ログイン後にコピー

データテーブルを削除します。

mysql> drop table [table name];
ログイン後にコピー

データテーブルのすべてのデータを表示します。

mysql> SELECT * FROM [table name];
ログイン後にコピー

指定されたデータテーブルの列情報を返します。

mysql> show columns from [table name];
ログイン後にコピー

値「何でも」を使用してフィルタリングし、選択した特定の行を表示します。

mysql> SELECT * FROM [table name] WHERE [field name] = "whatever";
ログイン後にコピー

名前「Bob」と電話番号「3444444」を含むすべてのレコードを表示します。

mysql> SELECT * FROM [table name] WHERE name = "Bob" AND phone_number = '3444444';
ログイン後にコピー

名前「Bob」と電話番号「3444444」を含まないすべてのレコードを表示し、phone_number フィールドで並べ替えます。

mysql> SELECT * FROM [table name] WHERE name != "Bob" AND phone_number = '3444444' order by phone_number;
ログイン後にコピー

名前が文字「bob」で始まり、電話番号が「3444444」であるすべてのレコードを表示します。

mysql> SELECT * FROM [table name] WHERE name like "Bob%" AND phone_number = '3444444';
ログイン後にコピー

名前が「bob」で始まり、電話番号が「3444444」の1件目から5件目までを表示します。

mysql> SELECT * FROM [table name] WHERE name like "Bob%" AND phone_number = '3444444' limit 1,5;
ログイン後にコピー

正規表現を使用してレコードを検索します。大文字と小文字の区別を強制するには、「正規表現バイナリ」を使用します。このコマンドは、a で始まるレコードを検索します。

mysql> SELECT * FROM [table name] WHERE rec RLIKE "^a";
ログイン後にコピー

異なる一意のレコードを返します。

mysql> SELECT DISTINCT [column name] FROM [table name];
ログイン後にコピー

選択したレコードを昇順または降順で表示します。

mysql> SELECT [col1],[col2] FROM [table name] ORDER BY [col2] DESC;
ログイン後にコピー

行数を返します。

mysql> SELECT COUNT(*) FROM [table name];
ログイン後にコピー

指定された列の値の合計をカウントします。

mysql> SELECT SUM(*) FROM [table name];
ログイン後にコピー

テーブルに参加します。

mysql> select lookup.illustrationid, lookup.personid,person.birthday from lookup left join person on lookup.personid=person.personid=statement to join birthday in person table with primary illustration id;
ログイン後にコピー

新しいユーザーを作成します。 rootとしてログインします。 mysql データベースに切り替え、ユーザーを作成し、権限を更新します。

# mysql -u root -p
mysql> use mysql;
mysql> INSERT INTO user (Host,User,Password) VALUES('%','username',PASSWORD('password'));
mysql> flush privileges;
ログイン後にコピー

UNIXコマンドラインからユーザーパスワードを変更します。

# [mysql dir]/bin/mysqladmin -u username -h hostname.blah.org -p password 'new-password'
ログイン後にコピー

mysqlコマンドラインからユーザーパスワードを変更します。 root としてログインし、パスワードを設定し、権限を更新します。

# /etc/init.d/mysql stop
# mysqld_safe --skip-grant-tables &
# mysql -u root
mysql> use mysql;
mysql> update user set password=PASSWORD("newrootpassword") where User='root';
mysql> flush privileges;
mysql> quit
# /etc/init.d/mysql stop
# /etc/init.d/mysql start
ログイン後にコピー

root パスワードが空の場合は、root パスワードを設定します。

# mysqladmin -u root password newpassword
ログイン後にコピー

root パスワードを更新します。

# mysqladmin -u root -p oldpassword newpassword
ログイン後にコピー

ユーザー「bob」に、パスワード「passwd」を使用して localhost からサーバーに接続することを許可します。 root としてログインし、mysql データベースを切り替えます。権限を設定し、権限を更新します。

# mysql -u root -p
mysql> use mysql;
mysql> grant usage on *.* to bob@localhost identified by 'passwd';
mysql> flush privileges;
ログイン後にコピー

データベースデータベースの権限を設定します。 root としてログインし、mysql データベースに切り替え、権限を付与し、権限を更新します。

# mysql -u root -p
mysql> use mysql;
mysql> INSERT INTO db (Host,Db,User,Select_priv,Insert_priv,Update_priv,Delete_priv,Create_priv,Drop_priv) VALUES ('%','databasename','username','Y','Y','Y','Y','Y','N');
mysql> flush privileges;
ログイン後にコピー

または

mysql> grant all privileges on databasename.* to username@localhost;
mysql> flush privileges;
ログイン後にコピー

既存のテーブルのデータを更新します。

mysql> UPDATE [table name] SET Select_priv = 'Y',Insert_priv = 'Y',Update_priv = 'Y' where [field name] = 'user';
ログイン後にコピー

[フィールド名] = '任意' であるテーブル内の行を削除します。

mysql> DELETE from [table name] where [field name] = 'whatever';
ログイン後にコピー

データベースの権限/特権を更新します。

mysql> flush privileges;
ログイン後にコピー

列を削除します。

mysql> alter table [table name] drop column [column name];
ログイン後にコピー

データベースに列を追加します。

mysql> alter table [table name] add column [new column name] varchar (20);
ログイン後にコピー

列名を変更します。

mysql> alter table [table name] change [old column name] [new column name] varchar (50);
ログイン後にコピー

独自の列を追加します。

mysql> alter table [table name] add unique ([column name]);
ログイン後にコピー

列の値を大きく設定してください。

mysql> alter table [table name] modify [column name] VARCHAR(3);
ログイン後にコピー

一意の列を削除します。

mysql> alter table [table name] drop index [colmn name];
ログイン後にコピー

CSV ファイルをテーブルにインポートします。

mysql> LOAD DATA INFILE '/tmp/filename.csv' replace INTO TABLE [table name] FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n' (field1,field2,field3);
ログイン後にコピー

すべてのデータベースを SQL ファイルにエクスポートします。

# [mysql dir]/bin/mysqldump -u root -ppassword --opt >/tmp/alldatabases.sql
ログイン後にコピー

データベースをエクスポートします。

# [mysql dir]/bin/mysqldump -u username -ppassword --databases databasename >/tmp/databasename.sql
ログイン後にコピー

データベースからテーブルをエクスポートします。

# [mysql dir]/bin/mysqldump -c -u username -ppassword databasename tablename > /tmp/databasename.tablename.sql
ログイン後にコピー

SQLファイルからデータベース(データテーブル)を復元します。

# [mysql dir]/bin/mysql -u username -ppassword databasename < /tmp/databasename.sql
ログイン後にコピー

データテーブルの作成例1。

mysql> CREATE TABLE [table name] (firstname VARCHAR(20), middleinitial VARCHAR(3), lastname VARCHAR(35),suffix VARCHAR(3),officeid VARCHAR(10),userid VARCHAR(15),username VARCHAR(8),email VARCHAR(35),phone VARCHAR(25), groups VARCHAR(15),datestamp DATE,timestamp time,pgpemail VARCHAR(255));
ログイン後にコピー

データテーブル作成例2。

りー


関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のおすすめ
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート