1 在指定数据库为某一个表增加一列,并为该列指定默认值
描述:
在数据库test中有一张保存接收邮件信息的表Tab_mail_Inbox,现根据应用需要,需要在表中增加一个字段TransType,并且为该字段指定默认值为http。
示例
操作前:
mysql> use test;
Database changed
mysql> desc Tab_mail_Inbox;
+---------------+--------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+---------------+--------------+------+-----+---------+-------+
| RecvAccount | varchar(100) | YES | | NULL | |
| SenderAccount | varchar(100) | YES | | NULL | |
| CCAccount | varchar(100) | YES | | NULL | |
| RecvTime | datetime | NO | MUL | | |
| MailTheme | varchar(100) | YES | | NULL | |
| ContentPath | varchar(100) | YES | | NULL | |
| MailID | varchar(50) | YES | | NULL | |
| SrcIP | varchar(20) | YES | | NULL | |
| SrcPort | varchar(10) | YES | | NULL | |
| DstIP | varchar(20) | YES | | NULL | |
| DstPort | varchar(10) | YES | | NULL | |
| MailContact | varchar(50) | YES | | NULL | |
| Att | varchar(50) | YES | | NULL | |
+---------------+--------------+------+-----+---------+-------+
13 rows in set (0.00 sec)
操作:
mysql> alter table Tab_mail_Inbox add TransType varchar(20);
mysql> alter table Tab_mail_Inbox alter column TransType set default 'http';
操作后:
mysql> desc Tab_mail_Inbox;
+---------------+--------------+------+-----+-------------------+-----------------------------+
| Field | Type | Null | Key | Default | Extra |
+---------------+--------------+------+-----+-------------------+-----------------------------+
| RecvAccount | varchar(300) | YES | | NULL | |
| SenderAccount | varchar(300) | YES | | NULL | |
| CCAccount | varchar(200) | YES | | NULL | |
| RecvTime | timestamp | NO | MUL | CURRENT_TIMESTAMP | on update CURRENT_TIMESTAMP |
| MailTheme | varchar(100) | YES | | NULL | |
| ContentPath | varchar(100) | YES | | NULL | |
| MailID | varchar(50) | YES | | NULL | |
| SrcIP | varchar(20) | YES | | NULL | |
| SrcPort | varchar(10) | YES | | NULL | |
| DstIP | varchar(20) | YES | | NULL | |
| DstPort | varchar(10) | YES | | NULL | |
| MailContact | varchar(50) | YES | | NULL | |
| Att | varchar(50) | YES | | NULL | |
| TransType | varchar(20) | YES | | http | |
+---------------+--------------+------+-----+-------------------+-----------------------------+
14 rows in set (0.00 sec)
注:
我把增加列和设置默认值分成两步来写,似乎有一步完成的方法,不过我不清楚。
2 根据应用需要,把表中多条记录的某一列的值改作其他值
描述:
当前数据库中有一张保存邮件信息的表tab_mail_info,该表中有一个名为TransType的字段,原来用来保存邮件传输方向信息(收为recv ,发为send)。现根据需要,要用TransType字段保存邮件传输使用的协议信息,我们知道方向为recv的使用了POP3协议,方向为send的使用了SMTP协议。
为此需要把tab_mail_info表中所有TransType字段值为recv的记录的TransType字段的值改为pop3,把表中所有TransType字段值为send的记录的TransType字段的值改为smtp。
示例:
mysql> update tab_mail_info set TransType = ' smtp ' where TransType = ' send ';
mysql> update tab_mail_info set TransType = ' pop3 ' where TransType = ' recv ';
注:
我曾经为此事头痛不已,因为我想着要改变的对象正是选择的条件本身,这是矛盾的。我一开始的想法是,先增加一个字段TransType1,他的值和完全和TransType字段一致。然后再以TransType1的值作为选择条件,最后改完了删除TransType1字段。
后来终于想通了,MySQL的运算逻辑其实是先根据选择条件得到一个待操作的对象集合,然后对该集合做相应操作。亦即选择和操作是有严格的先后顺序的,不存在冲突问题。