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;
## が入力されます。 '' '' Sは空の設定を許可されています(デフォルト設定)
not null is null(empt)
# // テーブル db2.t1 を作成します。空、デフォルト値は 0 文字、表示効果は次のようになります。下の図; 年齢フィールドのタイプは小さな整数で、負の数値 (符号なし) は許可されないという制約があり、デフォルト値は 19 に設定されています。ここでのデフォルト値の設定に注意してください。 tinyint タイプ、つまり、デフォルト値の設定は 255 を超えることはできません。性別フィールドのタイプは列挙型、列挙型はラジオ選択、制約は空にすることが許されず、デフォルト値は m に設定されます。
- mysql> ; desc db2.t1;
- //名前フィールドにのみ値を割り当て、残りのフィールドにはデフォルト値が割り当てられます
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;
ログイン後にコピー ##概要
- 制約
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" -> );
タイプ
キー (キー値) | #通常のインデックス インデックス |
##一意のインデックス 一意の | |
## 主キー 主キー | |
外部キー外部キー | |
| デフォルト (デフォルト値: フィールドに値を割り当てず、デフォルト値の割り当てを使用します) |
デフォルトは次のとおりです。定義されていない場合は 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;
mysql> alter table db2.t1 modify age tinyint unsigned default 19 after class; //除了对字段age的位置进行了修改,其余不修改的地方如:类型(宽度)、约束条件进行原样抄写 mysql> desc db2.t1;
mysql> alter table db2.t1 modify name varchar(15) not null default ""; mysql> desc db2.t1; ログイン後にコピー 修改字段名
—— 也可以用来修改字段类型 mysql> alter table 库名.表名 change 源字段名 新字段名 类型(宽度) 约束条件; 注:也可以用来修改类型和约束条件,只需要写上新的类型和新的约束条件即可 mysql> desc db2.t1;
mysql> alter table db2.t1 change email mail varchar(50); mysql> desc db2.t1;
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リアルなヌード写真を作成する AI 搭載アプリ ![]() AI Clothes Remover写真から衣服を削除するオンライン AI ツール。 ![]() Undress AI Tool脱衣画像を無料で ![]() Clothoff.ioAI衣類リムーバー ![]() Video Face Swap完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。 ![]() 人気の記事
アサシンのクリードシャドウズ:シーシェルリドルソリューション
3週間前
By DDD
Windows11 KB5054979の新しいものと更新の問題を修正する方法
2週間前
By DDD
Atomfallのクレーンコントロールキーカードを見つける場所
3週間前
By DDD
<🎜>:Dead Rails-すべての課題を完了する方法
4週間前
By DDD
Atomfall Guide:アイテムの場所、クエストガイド、およびヒント
4週間前
By DDD
![]() ホットツール![]() メモ帳++7.3.1使いやすく無料のコードエディター ![]() SublimeText3 中国語版中国語版、とても使いやすい ![]() ゼンドスタジオ 13.0.1強力な PHP 統合開発環境 ![]() ドリームウィーバー CS6ビジュアル Web 開発ツール ![]() SublimeText3 Mac版神レベルのコード編集ソフト(SublimeText3) ![]() ホットトピック
Gmailメールのログイン入り口はどこですか?
![]() ![]()
CakePHP チュートリアル
![]() ![]()
C# チュートリアル
![]() ![]()
Steamのアカウント名の形式は何ですか
![]() ![]() ![]() 次の手順でphpmyadminを開くことができます。1。ウェブサイトコントロールパネルにログインします。 2。phpmyadminアイコンを見つけてクリックします。 3。MySQL資格情報を入力します。 4.「ログイン」をクリックします。 ![]() MySQLはオープンソースのリレーショナルデータベース管理システムであり、主にデータを迅速かつ確実に保存および取得するために使用されます。その実用的な原則には、クライアントリクエスト、クエリ解像度、クエリの実行、返品結果が含まれます。使用法の例には、テーブルの作成、データの挿入とクエリ、および参加操作などの高度な機能が含まれます。一般的なエラーには、SQL構文、データ型、およびアクセス許可、および最適化の提案には、インデックスの使用、最適化されたクエリ、およびテーブルの分割が含まれます。 ![]() Redisは、単一のスレッドアーキテクチャを使用して、高性能、シンプルさ、一貫性を提供します。 I/Oマルチプレックス、イベントループ、ノンブロッキングI/O、共有メモリを使用して同時性を向上させますが、並行性の制限、単一の障害、および書き込み集約型のワークロードには適していません。 ![]() データベースとプログラミングにおけるMySQLの位置は非常に重要です。これは、さまざまなアプリケーションシナリオで広く使用されているオープンソースのリレーショナルデータベース管理システムです。 1)MySQLは、効率的なデータストレージ、組織、および検索機能を提供し、Web、モバイル、およびエンタープライズレベルのシステムをサポートします。 2)クライアントサーバーアーキテクチャを使用し、複数のストレージエンジンとインデックスの最適化をサポートします。 3)基本的な使用には、テーブルの作成とデータの挿入が含まれ、高度な使用法にはマルチテーブル結合と複雑なクエリが含まれます。 4)SQL構文エラーやパフォーマンスの問題などのよくある質問は、説明コマンドとスロークエリログを介してデバッグできます。 5)パフォーマンス最適化方法には、インデックスの合理的な使用、最適化されたクエリ、およびキャッシュの使用が含まれます。ベストプラクティスには、トランザクションと準備された星の使用が含まれます ![]() MySQLは、そのパフォーマンス、信頼性、使いやすさ、コミュニティサポートに選択されています。 1.MYSQLは、複数のデータ型と高度なクエリ操作をサポートし、効率的なデータストレージおよび検索機能を提供します。 2.クライアントサーバーアーキテクチャと複数のストレージエンジンを採用して、トランザクションとクエリの最適化をサポートします。 3.使いやすく、さまざまなオペレーティングシステムとプログラミング言語をサポートしています。 4.強力なコミュニティサポートを提供し、豊富なリソースとソリューションを提供します。 ![]() Apacheはデータベースに接続するには、次の手順が必要です。データベースドライバーをインストールします。 web.xmlファイルを構成して、接続プールを作成します。 JDBCデータソースを作成し、接続設定を指定します。 JDBC APIを使用して、接続の取得、ステートメントの作成、バインディングパラメーター、クエリまたは更新の実行、結果の処理など、Javaコードのデータベースにアクセスします。 ![]() DockerでMySQLを起動するプロセスは、次の手順で構成されています。MySQLイメージをプルしてコンテナを作成および起動し、ルートユーザーパスワードを設定し、ポート検証接続をマップしてデータベースを作成し、ユーザーはすべての権限をデータベースに付与します。 ![]() CentOSにMySQLをインストールするには、次の手順が含まれます。適切なMySQL Yumソースの追加。 yumを実行して、mysql-serverコマンドをインストールして、mysqlサーバーをインストールします。ルートユーザーパスワードの設定など、MySQL_SECURE_INSTALLATIONコマンドを使用して、セキュリティ設定を作成します。必要に応じてMySQL構成ファイルをカスタマイズします。 MySQLパラメーターを調整し、パフォーマンスのためにデータベースを最適化します。 ![]() |