一.表的结构的增删改
添加数据类型
alter table 表名 add 字段 数据类型; #如果字段存在则会报错 Duplicate column name '字段'
#修改数据类型
alter table 表名 modify 字段 数据类型; #如果出现Truncated incorrect INTEGER value: '小明'的报错则是因为字段与数据类型不符
#更改字段名甚至数据类型。
alter table 表名 change 老字段 新字段 新数据类型; #数据类型可改可不改,注意数据类型的更改要符合本身规则。
#删除字段
alter table 表名 drop 字段;

查看表结构(字符,数据类型,约束)

MariaDB [mysql]> desc s;
+--------+-------------------------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------------------------------+------+-----+---------+----------------+
| id | int() unsigned | NO | PRI | NULL | auto_increment |
| name | varchar() | YES | | NULL | |
| age | tinyint() unsigned | YES | | | |
| high | decimal(,) | YES | | NULL | |
| gender | enum('男','女','中性','保密') | NO | | 保密 | |
| cls_id | int() unsigned | YES | | NULL |

插入字段的内容 (insert into 表 values (赋值))

insert into s values(,'酱爆',,192.555,‘男’,)   
#格局字段顺序赋予value值,id赋值0但是因为设置了auto_increment的主键,会自动增加为1;
# 甚至可以赋值为default或者null,因为默认自增,综上来说,设置了主键自增的字段,添加数据的时候可以用0,null,default来做占位符。
# 另外往gender的字段内添加数据,可以根据索引来插入。即1为男,2为女..
#不管数据插入是否成功,自增都会生效

查看表内数据

select * from  表名;
MariaDB [mysql]> select * from s;
+----+--------+------+--------+--------+--------+
| id | name | age | high | gender | cls_id |
+----+--------+------+--------+--------+--------+
| | 酱爆 | | 192.56 | 男 | |
| | 酱爆 | | 192.56 | 男 | |
+----+--------+------+--------+--------+--------+

几个报错分析:

1.MariaDB [mysql]> insert into s values(null,'酱爆',,192.455,null,);
ERROR (): Column 'gender' cannot be null #此报错是因为设置gender的null约束为NO,如果不设置的话,就将null默认为一个
字符串插入。另外往gender的字段内添加数据,可以根据索引来插入。即1为男,2为女...
.Invalid default value for 'gender'   #此报错是因为前方null字段设置为空,而默认值设置不为空冲突
.column 'gender' has duplicate dvalue'?' in ENUMigned #编码格式改为utf8
Column count doesn't match value count at row 1 #添加的数据个数与字段个数不匹配
3. Field 'id' doesn't have a default value #这是因为id的约束设置为非空值,并且没有默认值和主键自增

部分插入

insert into s (name,age) values('酱爆',)
-> ;
Query OK, row affected (0.002 sec)
# 然后查看
MariaDB [mysql]> select * from s; #*代表所有
+----+--------+------+--------+--------+--------+
| id | name | age | high | gender | cls_id |
+----+--------+------+--------+--------+--------+
| | 酱爆 | | 192.56 | 男 | |
| | 酱爆 | | 192.56 | 男 | |
| | 酱爆 | | 192.46 | 女 | |
| | 酱爆 | | NULL | 保密 | NULL |
+----+--------+------+--------+--------+--------+
这里有两个需要注意的地方:
)id自增和gender为保密,这是因为设置了主键自增和设置了默认值为‘保密’
)high和cls_id为null,因为插入时没有赋值,会默认为null,但是这是建立在null的约束为YES的前提下,不然会报错。
)如果在id的字段内插入值,不能重复
4)插入的汉字数据变成 ?,这是因为数据库字符集格式没改,试着改为utf8.
5)如果没有改变字符集是无法将汉字当作默认值设置表结构的。 插入指定字段(列)的多行信息
insert into 表名 (字段,字段) values(赋值,赋值),(赋值,赋值)
insert into baba (name,age) values('酱爆',),(’熊大‘,);
| | 酱爆 | | NULL | 保密 | NULL |
| | 熊大 | | NULL | 保密 | NULL |

修改字段内数据(限定范围多用where)

update s set name='zz' where name='酱爆';
+----+--------+------+--------+--------+--------+
| id | name | age | high | gender | cls_id |
+----+--------+------+--------+--------+--------+
| | zz | | 192.56 | 男 | |
| | zz | | 192.56 | 男 | |
| | zz | | 192.46 | 女 | |
| | zz | | NULL | 保密 | NULL |
| | zz | | NULL | 保密 | NULL |
| | 熊大 | | NULL | 保密 | NULL |
| | zz | | NULL | 保密 | NULL |
| | 熊大 | | NULL | 保密 | NULL |

修改多个字段的内容(update 表 set ...)

update s set name='baba' ,age= where id=;
MariaDB [mysql]> select * from s;
+----+--------+------+--------+--------+--------+
| id | name | age | high | gender | cls_id |
+----+--------+------+--------+--------+--------+
| | baba | | 192.56 | 男 | |
| | zz | | 192.56 | 男 | |
| | zz | | 192.46 | 女 | |
| | zz | | NULL | 保密 | NULL |
| | zz | | NULL | 保密 | NULL |
| | 熊大 | | NULL | 保密 | NULL |
| | zz | | NULL | 保密 | NULL |
| | 熊大 | | NULL | 保密 | NULL |
+----+--------+------+--------+--------+--------+

删除数据 (delete from 表  + 限定条件)

delete from s where id =;
#如果不用where限定会删除所有表内的数据,慎用

删除用户:delete from user where user=''

删除后添加数据

insert into s (name,age) values('酱爆',);
#查看字段信息(发现id为8的数据删除后,下条增加的数据id为9,这是因为id自增的属性在起作用,有一定的保护作用)
MariaDB [mysql]> select * from s;
+----+--------+------+--------+--------+--------+
| id | name | age | high | gender | cls_id |
+----+--------+------+--------+--------+--------+
| | baba | | 192.56 | 男 | |
| | zz | | 192.56 | 男 | |
| | zz | | 192.46 | 女 | |
| | zz | | NULL | 保密 | NULL |
| | zz | | NULL | 保密 | NULL |
| | 熊大 | | NULL | 保密 | NULL |
| | zz | | NULL | 保密 | NULL |
| | 酱爆 | | NULL | 保密 | NULL |
+----+--------+------+--------+--------+--------+

查看表内数据:select * from 表名;

查看表结构:desc 表名;

查看表结构信息 :show create table 表名;

逻辑删除

1)增加字段并设置默认值为0

alter table s add is_delete bit() default ;

2)插入新信息

insert into s ('name','age') values('baba',),('mama',);

3)查看(发现is_delete字段内容依然空白,这是因为默认为0的数据太小,不能查看到)

MariaDB [mysql]> select * from s;
+----+--------+------+--------+--------+--------+-----------+
| id | name | age | high | gender | cls_id | is_delete |
+----+--------+------+--------+--------+--------+-----------+
| | baba | | 192.56 | 男 | | |
| | zz | | 192.56 | 男 | | |
| | zz | | 192.46 | 女 | | |
| | zz | | NULL | 保密 | NULL | |
| | zz | | NULL | 保密 | NULL | |
| | 熊大 | | NULL | 保密 | NULL | |
| | zz | | NULL | 保密 | NULL | |
| | 酱爆 | | NULL | 保密 | NULL | |
| | hauhua | | NULL | 保密 | NULL | |
| | baba | | NULL | 保密 | NULL | |
+----+--------+------+--------+--------+--------+-----------+
此操作作用在于给逻辑删除的用户标记,0为正常用户,1为逻辑删除用户。
MariaDB [mysql]> insert into s values(null,'酱爆',,192.455,null,)

最新文章

  1. CentOS6.3 编译安装LAMP(4):编译安装 PHP5.2.17
  2. 剑指offer 复制构造函数
  3. kali 在线教学群 第一次 公开课 小结(1)
  4. go语言编辑器:liteide
  5. Excel 使用CHIINV函数和GAMMA.DIST函数绘制卡方分布
  6. JMeter结果分析
  7. [daily][CentOS][yum] 删除包的同时一同清理掉安装时一起装进来的依赖包
  8. Socket 一对多通信
  9. 1003. Parity(并查集)
  10. javascript 学习笔记之面向对象编程(一):类的实现
  11. 南京Uber优步司机奖励政策(1月25日~1月31日)
  12. 打开新窗口(window.open)
  13. MFC消息机制
  14. Spring事务配置的五种方式和spring里面事务的传播属性和事务隔离级别
  15. Mysql--七种 Join 查询
  16. shell 中的特殊变量
  17. eclipse中javadoc给项目生成api文档
  18. SRD_PreloaderCore
  19. German Collegiate Programming Contest 2018​ A. Attack on Alpha-Zet
  20. ThreadLocal以及内存泄漏

热门文章

  1. Git-第四篇廖雪峰Git教程学习笔记(3)远程仓库,克隆远端库
  2. hdu-1045.fire net(缩点 + 二分匹配)
  3. <每日一题>Day 9:POJ-3281.Dining(拆点 + 多源多汇+ 网络流 )
  4. Git 出现Branch master set up to track remote branch master问题 与忽略文件上传
  5. kali Linux 入门(二)
  6. nginx http正向代理简单配置及systemd 配置
  7. 2018-09-10-weekly
  8. AOP技术介绍--(引言)
  9. thinkphp数据库连接
  10. crt无法修改背景