この記事では、mysql に関する関連知識を提供し、主にテーブル構造を含む制約やテーブル構造の変更に関連する問題について紹介します。
推奨学習: mysql チュートリアル
役割とは制限の? ##
mysql> desc db1.t9;
mysql> insert into t9 values (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)
Key# # EXTRA // 追加設定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 以外の空は許可されません
キー (キー値) | #通常のインデックス インデックス |
##一意のインデックス 一意の | |
## 主キー 主キー | |
外部キー外部キー | |
| デフォルト (デフォルト値: フィールドに値を割り当てず、デフォルト値の割り当てを使用します) |
デフォルトは次のとおりです。定義されていない場合は 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 サイトの他の関連記事を参照してください。
関連ラベル:
ソース:csdn.net
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
最新の問題
結果セットから最小値のみを表示する方法 (MYSQL)
次のステートメントがあります: selectDATE(recieved_on)asDay,round(count(*)/24)AS'average'frommessagewhere...
から 2024-04-06 21:44:19
0
1
603
MySQL でグループ化してカウントするにはどうすればよいですか?
友人に送信され、削除されていないメッセージの合計数を抽出するクエリを作成しようとしています。これはテーブル構造のスクリーンショットです。 達成したい出力は次のとおりです。 idme...
から 2024-04-06 18:30:17
0
1
353
MySQL は複数のテーブルからデータを取得します
次の列を含む eg_design テーブル、および次の列を含む eg_domains テーブル、および次の列を含む eg_fonts テーブルがあります。 $domain_id に...
から 2024-04-06 18:42:44
0
2
479
関連トピック
詳細>
|