目次
制約条件
//図に示すように、各列の意味は次のとおりです: フィールド名 | タイプ | 空 | キー値 | デフォルト値 | 追加設定
# // テーブル db2.t1 を作成します。空、デフォルト値は 0 文字、表示効果は次のようになります。下の図; 年齢フィールドのタイプは小さな整数で、負の数値 (符号なし) は許可されないという制約があり、デフォルト値は 19 に設定されています。ここでのデフォルト値の設定に注意してください。 tinyint タイプ、つまり、デフォルト値の設定は 255 を超えることはできません。性別フィールドのタイプは列挙型、列挙型はラジオ選択、制約は空にすることが許されず、デフォルト値は m に設定されます。
修改表结构
语法结构
添加新字段
修改字段类型
修改字段名
删除字段
修改表名
ホームページ データベース mysql チュートリアル MySQLのナレッジポイントのテーブル構造を詳しくまとめて説明する

MySQLのナレッジポイントのテーブル構造を詳しくまとめて説明する

Mar 04, 2022 pm 05:12 PM
mysql

この記事では、mysql に関する関連知識を提供し、主にテーブル構造を含む制約やテーブル構造の変更に関連する問題について紹介します。

MySQLのナレッジポイントのテーブル構造を詳しくまとめて説明する

推奨学習: mysql チュートリアル

制約条件

  • 役割とは制限の? ##

    mysql> desc db1.t9;
    ログイン後にコピー

//図に示すように、各列の意味は次のとおりです: フィールド名 | タイプ | 空 | キー値 | デフォルト値 | 追加設定

mysql> insert into t9 values (null,null,null);
ログイン後にコピー
    //上の図に示すように、制約条件は空 (NULL) にすることができるため、ここで値を割り当てるときに空にすることができます。null は大文字と小文字が区別されません
  • mysql> select * from  db1.t9;
    ログイン後にコピー

  • mysql> insert into db1.t9(name,sex) values("lucy","girl");
    mysql> select * from db1.t9;
    ログイン後にコピー
//t9 テーブルの制約 この条件では、3 番目のフィールドのデフォルト値は NULL です。これは、3 番目のフィールドに値が割り当てられていない場合、デフォルト値が入力されることを意味します。テーブル、つまり、次の図に示すように、デフォルトで NULL

## が入力されます。 '' '' Sは空の設定を許可されています(デフォルト設定)

not null is null(empt)

Key#

# EXTRA // 追加設定

# // テーブル db2.t1 を作成します。空、デフォルト値は 0 文字、表示効果は次のようになります。下の図; 年齢フィールドのタイプは小さな整数で、負の数値 (符号なし) は許可されないという制約があり、デフォルト値は 19 に設定されています。ここでのデフォルト値の設定に注意してください。 tinyint タイプ、つまり、デフォルト値の設定は 255 を超えることはできません。性別フィールドのタイプは列挙型、列挙型はラジオ選択、制約は空にすることが許されず、デフォルト値は m に設定されます。

    mysql> ; desc db2.t1;
  • mysql> create database db2;
    mysql> create table db2.t1(
        -> name char(10) not null default "",
        -> age tinyint unsigned default 19,
        -> sex enum("m","w") not null default "m"
        -> );
    ログイン後にコピー
  • //名前フィールドにのみ値を割り当て、残りのフィールドにはデフォルト値が割り当てられます

    mysql> insert into db2.t1(name) values("bob");
    ログイン後にコピー

  • mysql> select * from db2.t1;
    ログイン後にコピー

    ##
    mysql> insert into db2.t1 values("lucy","21","w");     //给字段赋值,就不会以默认值赋值了
    mysql> select * from db2.t1;
    ログイン後にコピー
  • ##概要

  • 制約

タイプ

Null (nullが許可されるかどうか)

#デフォルトでは null が許可されます

##null 以外の空は許可されません##一意のインデックス 一意の #全文インデックス fulltext#定義されている場合はデフォルトです (フィールド タイプに一致するため)

キー (キー値)

#通常のインデックス インデックス


## 主キー 主キー

外部キー外部キー


デフォルト (デフォルト値: フィールドに値を割り当てず、デフォルト値の割り当てを使用します)
デフォルトは次のとおりです。定義されていない場合は null


追加 (追加の設定: デフォルトでは追加の設定はありません)

修改表结构

语法结构

  • 用法

mysql> alter table 库名.表名 执行动作;

  • 执行动作

add 添加字段

modify 修改字段类型

change 修改字段名

drop 删除字段

rename 修改表名

添加新字段

  • 用法

—— 新字段默认添加在字段末尾

mysql> alter table 库名.表名 add 字段名 类型(宽度) 约束条件;

add 字段名 类型 [约束条件] after 字段名;

add 字段名 类型 [约束条件] first;

  • 不指定位置添加字段

mysql> alter table db2.t1 add email varchar(50);     //不指定添加字段的位置,默认就在末尾
mysql> desc db2.t1;
ログイン後にコピー

  • 在某一字段后面添加字段

mysql> alter table db2.t1 add hobby set("eat","drink","play","happy") not null default "eat,drink" after age;    //指定添加位置在字段age之后,条件设置不允许为空,并设置默认值为eat,drink
mysql> desc db2.t1;
ログイン後にコピー

mysql> select * from db2.t1;     //查看表内容,发现hobby字段自动添加了默认值
ログイン後にコピー

  • 将字段添加到最前面

mysql> alter table db2.t1 add class char(7) default "B180601" first;     //将字段class添加到最前面
mysql> desc db2.t1;
ログイン後にコピー

mysql> select * from db2.t1; //class字段自动添加默认值

修改字段类型

  • 基本用法

—— 修改的字段类型不能与已存储的数据冲突

mysql> alter table 库名.表名 modify 字段名 类型(宽度) 约束条件;

modify 字段名 类型 [约束条件] after 字段名;

modify 字段名 类型 [约束条件] first;

注:

如果表中这个字段类型下面的字段已经有值了,那么修改的类型与约束不能与字段里面已经存储的数据发生冲突,如果发生冲突则不允许修改。比如,有一个字段name,里面存储了一个数据为bob,那么把字段的类型(宽度)改成char(1),则会修改失败,因为bob的宽度为3,如果将字段的类型(宽度)改为char(1),则源数据bob就存不下了,由于已存储的数据优先,所以就不能进行修改;

修改字段的类型时要注意,不修改的部分要原样进行抄写,如果不修改的部分不原样抄写,那就相当于对其进行还原即使用默认配置。比如有一个字段name,他的类型是char(10),约束条件是不允许为空,默认值是"",现在要将其类型宽度改为char(20),其余没修改的部分没有在命令中进行原样抄写,那么输出结果该字段的约束条件会变为默认情况,即允许为空,默认值为NULL。改变字段位置的时候也一样。

mysql> desc db2.t1;

  • 将字段age的位置修改到字段class的后面

mysql> alter table db2.t1 modify age tinyint unsigned default 19 after class; //除了对字段age的位置进行了修改,其余不修改的地方如:类型(宽度)、约束条件进行原样抄写

mysql> desc db2.t1;

  • 将字段name的类型变为varchar(15)

mysql> alter table db2.t1 modify name varchar(15) not null default "";
mysql> desc db2.t1;
ログイン後にコピー

修改字段名

  • 基本用法

—— 也可以用来修改字段类型

mysql> alter table 库名.表名 change 源字段名 新字段名 类型(宽度) 约束条件;

注:也可以用来修改类型和约束条件,只需要写上新的类型和新的约束条件即可

mysql> desc db2.t1;

  • 将字段名email修改为mail

mysql> alter table db2.t1 change email mail varchar(50);

mysql> desc db2.t1;

  • 将字段名mail修改为email,并修改约束条件

mysql> alter table db2.t1 change mail email varchar(50) not null default "njw@163.com";     //出现错误,因为源数据中,mail字段中的值为NULL,如果将约束条件修改为not null,那么就与源数据发生冲突,所以修改失败
ERROR 1138 (22004): Invalid use of NULL value
mysql> alter table db2.t1 change mail email varchar(50) default "njw@163.com";
mysql> desc db2.t1;
ログイン後にコピー

删除字段

  • 基本用法

mysql> alter table 库名.表名 drop 字段名;

mysql> alter table db2.t1 drop email;    //删除库db2中表t1的字段email
mysql> desc db2.t1;    //没有字段email,已被删除
ログイン後にコピー

mysql> select * from db2.t1;    //字段email及其数据已被删除

修改表名

  • 基本用法

mysql> alter table 库名.表名 rename 新表名;

                                                          库名.新表名;

mysql> use db2;

mysql> show tables;

mysql> alter table db2.t1 rename stuinfo;     //将表名修改为stuinfo

mysql> show tables;

mysql> select * from stuinfo;

推荐学习:mysql视频教程

以上がMySQLのナレッジポイントのテーブル構造を詳しくまとめて説明するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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)

phpmyadminを開く方法 phpmyadminを開く方法 Apr 10, 2025 pm 10:51 PM

次の手順でphpmyadminを開くことができます。1。ウェブサイトコントロールパネルにログインします。 2。phpmyadminアイコンを見つけてクリックします。 3。MySQL資格情報を入力します。 4.「ログイン」をクリックします。

MySQL:世界で最も人気のあるデータベースの紹介 MySQL:世界で最も人気のあるデータベースの紹介 Apr 12, 2025 am 12:18 AM

MySQLはオープンソースのリレーショナルデータベース管理システムであり、主にデータを迅速かつ確実に保存および取得するために使用されます。その実用的な原則には、クライアントリクエスト、クエリ解像度、クエリの実行、返品結果が含まれます。使用法の例には、テーブルの作成、データの挿入とクエリ、および参加操作などの高度な機能が含まれます。一般的なエラーには、SQL構文、データ型、およびアクセス許可、および最適化の提案には、インデックスの使用、最適化されたクエリ、およびテーブルの分割が含まれます。

単一のスレッドレディスの使用方法 単一のスレッドレディスの使用方法 Apr 10, 2025 pm 07:12 PM

Redisは、単一のスレッドアーキテクチャを使用して、高性能、シンプルさ、一貫性を提供します。 I/Oマルチプレックス、イベントループ、ノンブロッキングI/O、共有メモリを使用して同時性を向上させますが、並行性の制限、単一の障害、および書き込み集約型のワークロードには適していません。

MySQLの場所:データベースとプログラミング MySQLの場所:データベースとプログラミング Apr 13, 2025 am 12:18 AM

データベースとプログラミングにおけるMySQLの位置は非常に重要です。これは、さまざまなアプリケーションシナリオで広く使用されているオープンソースのリレーショナルデータベース管理システムです。 1)MySQLは、効率的なデータストレージ、組織、および検索機能を提供し、Web、モバイル、およびエンタープライズレベルのシステムをサポートします。 2)クライアントサーバーアーキテクチャを使用し、複数のストレージエンジンとインデックスの最適化をサポートします。 3)基本的な使用には、テーブルの作成とデータの挿入が含まれ、高度な使用法にはマルチテーブル結合と複雑なクエリが含まれます。 4)SQL構文エラーやパフォーマンスの問題などのよくある質問は、説明コマンドとスロークエリログを介してデバッグできます。 5)パフォーマンス最適化方法には、インデックスの合理的な使用、最適化されたクエリ、およびキャッシュの使用が含まれます。ベストプラクティスには、トランザクションと準備された星の使用が含まれます

なぜMySQLを使用するのですか?利点と利点 なぜMySQLを使用するのですか?利点と利点 Apr 12, 2025 am 12:17 AM

MySQLは、そのパフォーマンス、信頼性、使いやすさ、コミュニティサポートに選択されています。 1.MYSQLは、複数のデータ型と高度なクエリ操作をサポートし、効率的なデータストレージおよび検索機能を提供します。 2.クライアントサーバーアーキテクチャと複数のストレージエンジンを採用して、トランザクションとクエリの最適化をサポートします。 3.使いやすく、さまざまなオペレーティングシステムとプログラミング言語をサポートしています。 4.強力なコミュニティサポートを提供し、豊富なリソースとソリューションを提供します。

Apacheのデータベースに接続する方法 Apacheのデータベースに接続する方法 Apr 13, 2025 pm 01:03 PM

Apacheはデータベースに接続するには、次の手順が必要です。データベースドライバーをインストールします。 web.xmlファイルを構成して、接続プールを作成します。 JDBCデータソースを作成し、接続設定を指定します。 JDBC APIを使用して、接続の取得、ステートメントの作成、バインディングパラメーター、クエリまたは更新の実行、結果の処理など、Javaコードのデータベースにアクセスします。

DockerによるMySQLを開始する方法 DockerによるMySQLを開始する方法 Apr 15, 2025 pm 12:09 PM

DockerでMySQLを起動するプロセスは、次の手順で構成されています。MySQLイメージをプルしてコンテナを作成および起動し、ルートユーザーパスワードを設定し、ポート検証接続をマップしてデータベースを作成し、ユーザーはすべての権限をデータベースに付与します。

Centosはmysqlをインストールします Centosはmysqlをインストールします Apr 14, 2025 pm 08:09 PM

CentOSにMySQLをインストールするには、次の手順が含まれます。適切なMySQL Yumソースの追加。 yumを実行して、mysql-serverコマンドをインストールして、mysqlサーバーをインストールします。ルートユーザーパスワードの設定など、MySQL_SECURE_INSTALLATIONコマンドを使用して、セキュリティ設定を作成します。必要に応じてMySQL構成ファイルをカスタマイズします。 MySQLパラメーターを調整し、パフォーマンスのためにデータベースを最適化します。

See all articles