mariadb(二)增删改
一.表的结构的增删改
添加数据类型
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,)
mariadb(二)增删改的更多相关文章
- MyBatis学习系列二——增删改查
目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring 数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改, ...
- ThinkPHP 数据库操作(二) : 增删改查
基本使用 可以直接使用数据库运行原生SQL操作了,支持 query (查询操作)和 execute (写入操作)方法,并且支持参数绑定. Db::query('select * from think_ ...
- mybatis入门(二):增删改查
mybatis的原理: 1.mybatis是一个持久层框架,是apache下的顶级项目 mybatis托管到googlecode下,目前托管到了github下面 2.mybatis可以将向prepar ...
- <MySQL>入门二 增删改 DML
-- DML语言 /* 数据操作的语言 插入:insert 修改:update 删除:delete */ 1.插入 -- 插入语句 /* 语法:insert into 表名(列名...) values ...
- mariadb数据库增删改查
1.常用数据类型 1)整数:int, bit 2)小数:decimal #decimal(5,2)表示共有五位数,保留两位小数 3)字符串:varchar, char 4)日期时间:date, ...
- mybatis入门二-----增删改查
一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: <?xml version="1.0&quo ...
- mariadb数据库(2)增删改与 单表查询
一.数据类型 MariaDB数据类型可以分为数字,日期和时间以及字符串值. 使用数据类型的原则:够用就行, 尽量使用范围小的,而不用大的 常用的数据类型 整数:int, bit 小数:decimal ...
- mysql基础之mariadb对表中数据的增删改查
复习: 查看表:show tables; 创建表:create table 表名(字符类型); 删除表:drop table 表名; 对表的结构进行增删改查: 查看表结构:desc 表名; 修改表-添 ...
- 日历插件FullCalendar应用:(二)数据增删改
接上一篇 日历插件FullCalendar应用:(一)数据展现. 这一篇主要讲使用fullcalendar插件如何做数据的增删改,用到了art.dialog web对话框组件,上一篇用到的webFor ...
随机推荐
- windows10配置Docker容器独立IP地址互相通信
Docker官方推荐我们通过端口映射的方式把Docker容器的服务提供给宿主机或者局域网其他容器使用.一般过程是: 1.Docker进程通过监听宿主机的某个端口,将该端口的数据包发送给Docker容器 ...
- linux自动化运维工具Ansible saltstack Puppet、Chef、Fabric之间的对比
发现分布式是一个发展的趋势,无论是大型网站的负载均衡架构还是大数据框架部署,以及云存储计算系统搭建都离不开多台服务器的连续部署和环境搭建. 当我们的基础架构是分散式或者基于云的,并且我们经常需要处理在 ...
- MyBatis基础面试题
转自:http://www.cnblogs.com/huajiezh/p/6415322.html 1.Mybatis基础: #{...} 和 ${...} 的区别MyBatis将 #{…} 解释为J ...
- [随笔重写] Python3 的深拷贝与浅拷贝
1. Python3 关于深浅拷贝的官方文档 文档地址:Python3.7.2 源码地址:lib/copy.py 2. 先说结论 深拷贝与浅拷贝是对复合对象而言的 深拷贝会构造一个新的复合对象,然后递 ...
- Kotlin学习(2)函数
函数声明: fun plus(a:Int,b:String):Boolean{ //fun 函数名(参数名:参数类型,参数名:参数类型):返回值类型 println(a) return true // ...
- 关于Python程序的运行方面,有什么手段能提升性能?
1.使用多进程,充分利用机器的多核性能 2.对于性能影响较大的部分代码,可以使用C或C++编写 3.对于IO阻塞造成的性能影响,可以使用IO多路复用来解决 4.尽量使用Python的内建函数 5.尽量 ...
- 使用OFBIZ的理由和不使用OFBIZ的理由
1 使用OFBIZ的理由 1.1 什么是OFBIZ OFBIZ是由Sourceforge维护的一个最著名的开源项目之一,提供创建基于最新J2EE/XML规范和技术标准,构建大型企业级.跨平台.跨数据库 ...
- MVC调用函数function.php
<?php //控制器的调用函数C function C($name, $method){ require_once('/libs/controller/'.$name.'Controller. ...
- C#控制文本框(TextBox)只能输入正数,负数,小数
由于项目需要,需要写一个TextBox文本框,此文本框需要满足:只能输入正数,负数和小数.比如:3,0.3,-4,-0.4等等. 在网上找了许多正则表达式都不好用,由于本人又对正则表达式 ...
- C# ASP.NET发送电子邮件System.Net.Mail
1.补充知识 (1)POP3和SMTP服务器是什么? 简单点来说:POP3 用于接收电子邮件 ,SMTP 用于发送电子邮件. (1)POP3具体指什么? POP3(Post Office Protoc ...