MySQL命令行中给表添加一个字段(字段名、是否为空、默认值)

MySQL命令行中给表添加一个字段(字段名、是否为空、默认值),第1张

先看一下最简单的例子,在test中,添加一个字段,字段名为birth,类型为date类型。

mysql>

alter

table

test

add

column

birth

date

Query

OK,

0

rows

affected

(0.36

sec)

Records:

0

Duplicates:

0

Warnings:

0

查询一下数据,看看结果:

mysql>

select

*

from

test

+------+--------+----------------------------------+------------+-------+

|

t_id

|

t_name

|

t_password

|

t_birth

|

birth

|

+------+--------+----------------------------------+------------+-------+

|

1

|

name1

|

12345678901234567890123456789012

|

NULL

|

NULL

|

|

2

|

name2

|

12345678901234567890123456789012

|

2013-01-01

|

NULL

|

+------+--------+----------------------------------+------------+-------+

2

rows

in

set

(0.00

sec)

从上面结果可以看出,吵山插入的birth字段,默认值为空。我们再猛棚来试一下,添加枝碰则一个birth1字段,设置它不允许为空。

mysql>

alter

table

test

add

column

birth1

date

not

null

Query

OK,

0

rows

affected

(0.16

sec)

Records:

0

Duplicates:

0

Warnings:

0

居然执行成功了!?意外了!我原来以为,这个语句不会成功的,因为我没有给他指定一个默认值。我们来看看数据:

mysql>

select

*

from

test

+------+--------+----------------------------------+------------+-------+------------+

|

t_id

|

t_name

|

t_password

|

t_birth

|

birth

|

birth1

|

+------+--------+----------------------------------+------------+-------+------------+

|

1

|

name1

|

12345678901234567890123456789012

|

NULL

|

NULL

|

0000-00-00

|

|

2

|

name2

|

12345678901234567890123456789012

|

2013-01-01

|

NULL

|

0000-00-00

|

+------+--------+----------------------------------+------------+-------+------------+

2

rows

in

set

(0.00

sec)

哦,明白了,系统自动将date类型的值,设置了一个默认值:0000-00-00。下面我来直接指定一个默认值看看:

mysql>

alter

table

test

add

column

birth2

date

default

'2013-1-1'

Query

OK,

0

rows

affected

(0.28

sec)

Records:

0

Duplicates:

0

Warnings:

0

mysql>

select

*

from

test

+------+--------+----------------------------------+------------+-------+------------+------------+

|

t_id

|

t_name

|

t_password

|

t_birth

|

birth

|

birth1

|

birth2

|

+------+--------+----------------------------------+------------+-------+------------+------------+

|

1

|

name1

|

12345678901234567890123456789012

|

NULL

|

NULL

|

0000-00-00

|

2013-01-01

|

|

2

|

name2

|

12345678901234567890123456789012

|

2013-01-01

|

NULL

|

0000-00-00

|

2013-01-01

|

+------+--------+----------------------------------+------------+-------+------------+------------+

2

rows

in

set

(0.00

sec)

看到没,将增加的birth2字段,就有一个默认值了,而且这个默认值是我们手工指定的。

关于MySQL中给表添加一个字段,本文就介绍这么多,希望对大家有所帮助,谢谢!

最可能的原因就是插入方法错误。

如有这样一个表,档丛其中字乱蠢陪哗蠢段2允许为空:

字段1   字段2   字段3

那么可以写语句:

insert into 表名( 字段1,字段2,字段3)  values (1,null,1)

如果这样写,就会有错误:

insert into 表名( 字段1,字段2,字段3)  values (1,,1)

所以,如果插入空的时候一定要写上null。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/bake/11984043.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-20
下一篇 2023-05-20

发表评论

登录后才能评论

评论列表(0条)

保存