1.常用数据类型

1)整数:int, bit

2)小数:decimal       #decimal(5,2)表示共有五位数,保留两位小数

3)字符串:varchar, char  

4)日期时间:date, time, datetime

5)枚举类型(enum)

2.约束

1)主键primary key:物理上存储的顺序

2)非空not null:此字段不能为空

3)唯一unique:此字段不允许重复

4)默认default:当不填写此值时会使用默认值,如果填写则已填写为准

5)外键foreign key:对关系字段进行约束,当为关系字段填写值时,会到关联的表中查询此值是否存在,如果存在则填写成功,如果不存在则填写失败并抛出异常

数值类型
类型 字节大小 有符号范围 无符号范围
TINYINT 1 -127~127 0~255
SMALLINT 2 -32768~32767 0~65535
MEDIUMINT 3 -8388608~8388607 0~16777215
INT/INTEGER 4 -2147483648~2147483647 0~4294967265
BIGINT 8 -9223372036854775808~-9223372036854775807 0~18446744073709551615
字符串
类型 字节大小 示例
CHAR 0-255 char(3)不管输入几个字节都会占3个字节
VARCHAR 0-255 varchar(3)输入比三小的字节会占用实际字节大小
TEXT 0-65535 大文本
日期时间类型
DATE 4 ‘2020-01-01’
TIME 3 ’12:05:34’
DATETIME 8 ‘2020-01-01  12:05:34’
YEAR 1 ‘2019’
TIMESTAMP 4 ‘1970-01-01  00:00:01’UTC~‘2038-01-01  00:00:01’UTC

3.sql语句alter

显示当前时间

select now();

创建classes表(id, name)

create table zzzz(

id int primary key not null auto_increment,

name varchar(20),

age int

);

查看表结构

desc zzzz

1)创建students表(id, name, age, high, gender, cls_id)

create table students (

id int unsigned not null auto_increment primary key,

name varchar(20),

age tinyint unsigned default 0,

high decimal(5,2),

gender enum('男', '女', '中性', '保密') default '保密',

cls_id int unsigned

);

创建classes表(id, name)

create table classes(

id int unsigned not null auto_increment primary key,

name varchar(20)

);

2)修改表属性

修改表-添加字段

alter table 表名 add 列名 类型;

alter table students add birthday datetime;

修改表-修改字段:不重命名版

alter table 表名 modify 列名 类型及约束;

alter table students modify birthday date;

修改表-修改字段:重命名版

alter table 表名 change 原名 新名 类型及约束;

alter table students change birthday birth date;

3)修改表-删除字段

alter table 表名 drop 列名;

alter table students drop birthday;

4) 删除表

drop table 表名;

drop table students;

4.sql语句增加insert

1)全列插入

insert into 表名 values(..)    主键字段 可以用0 null default 来站位

向students表里插入 一个学生信息

insert into students values (0,'小明',19,188.999,'男', 1);

2)部分插入

insert into students(id, name, age) values (0,'绿帽子',19);

部分插入(多条记录)

insert into students(id, name, age) values (0,'绿帽子',19),(0,'小跳蚤',21);

5.sql语句修改update

update 表名 set 列1=值1, 列2=值2... where 条件;

update students set age=100 where id=1;

update students set age=100,cls_id=77 where id=1;

6.sql语句删除delete与truncate

1)物理删除

delete from 表名 where 条件

delete from students where cls_id=88;

2)逻辑删除

用一条字段来表示 这条信息是否已经不能在使用了

给students表添加一个is_delete字段 bit 类型

alter table students add is_delete bit default 0;

update students set is_delete=1 where id=6;

3)truncate

清空表,连同id字段自增重置为1,重新插入的数据id默认会从1开始,用truncate删除的数据无法恢复

truncate students

7.sql语句查看select

查询基本使用(条件,排序,聚合函数,分组,分页)

1)查询所有列

select * from 表名

select * from students;

一定条件查询(where)

select * from where id=5;

查询制定列

select id,name from students;

使用as给字段起别名

select id,name as '姓名', age, high, gender from students;

通过表名字段查询

select students.name from students;

给表起别名查询

select s.id,s.name,s.age from students as s;

消除重复行

distinct

select distinct age from students;

2)条件查询

查询年纪大于18岁的信息

select * from students where age > 18;

18岁到28岁之间(and)

select * from students where age >= 18 and age =< 28;    允许使用&&

select * from students where age between 18 and 28

在18岁以上或者身高180以上的人(or)

select * from students where age > 18 or high > 180;    允许使用||

3)模糊查询like

% 替代1个或者多个甚至是没有

查询姓名中有‘小’的所有名字

select * from students where name like '%小%';

查询两个字人的名字

select * from students where name like '__';    两个下划线

查询至少有2个字的名字

select * from students where name like '%__%';

4)范围查询

in (1,3,8)表示在一个非连续的范围内

查询年纪为18和34的人

select * from students where age in (18, 34);

查询 年龄在17岁到34岁之间的信息

select * from students where age between 17 and 34;

查询 年纪不在18到34岁的信息

select * from students where age not between 17 and 34;

5)空判断

判断is null

查询身高为空的人的信息

select * from students where high is null;

6)排序order by

asc从小到大排列,即升序

desc从大到小排序,即降序

order by支持多字段

查询年纪在18到34岁之间的男性,按照年纪从小到大

select * from students where gender=1 and age between 18 and 34 order by age;

查询年纪在18到34岁之间的女性,身高从高到矮

select * from students where gender=2 and age between 18 and 34 order by high desc;

查询年纪在18到34岁的男性,身高从高到矮排序,如果身高相同的情况下按照年纪从小到大排序,如果年龄也相等那么按照id从小到大排序;

select * from students where age between 18 and 34 and gender=1 order by high desc,age,id;

8.聚合函数

1)总数count

查询男性有多少人

select count(*) from students where gender=1;

2)最大值max

查询最大的年纪

select max(age) from students;

查询女性的最高身高

select max(high) from students where gender=2;

3)最小值 min

select min(high) from students;

4)求和sum

计算所有人的年龄总和

select sum(age) from students;

5)平均值avg

计算平均年纪 sum(age)/count(*)

select sum(age)/count(*) from students;

select avg(age),2 from students;

保留2位小数

select round(avg(age),2) from students;

6)分组group by

按照性别分组,查询所有的性别

select gender from students group by gender;

计算每组性别的人数

select gender, count(*) from students group by gender;

查询男性组中的姓名 group_concat

select gender,group_concat(name) from students where gender=1 group by gender;    group_concat()按照拼接后的字符串显示

7)having

查询每个性别平均年纪超过30岁的性别,以及姓名 having avg(age) > 30

select gender, group_concat(name) from students group by gender having avg(age) > 30;

查询每种性别中的人数多于4个的组的信息

select gender,group_concat(name) from students group by gender having count(*)>4;

8)分页limit

显示5页

select * from students limit 5;

分页显示,每页显示2条数据

select * from students limit 0, 2;

按照身高从高到矮排序,查找出所有女性,并且分页显示,每页显示2条数据

select * from students where gender=2 order by high desc limit 0,2;

mariadb数据库增删改查的更多相关文章

  1. Yii2.0高级框架数据库增删改查的一些操作(转)

    yii2.0框架是PHP开发的一个比较高效率的框架,集合了作者的大量心血,下面通过用户为例给大家详解yii2.0高级框架数据库增删改查的一些操作 --------------------------- ...

  2. 2. MongoDB基本操作 —— 用Mongo.exe操作数据库增删改查

    一.开篇 传统的关系数据库一般由数据库(database).表(table).记录(record)三个层次概念组成,MongoDB是由数据库(database).集合(collection).文档对象 ...

  3. go——beego的数据库增删改查

    一直都不理解使用go语言的时候,为什么还要自己去装beego,以为使用go便可以解决所有的问题,结果在朋友的点拨下,才意识到: go与beego的关系就好比是nodejs与thinkjs的关系,因此也 ...

  4. (转)SQLite数据库增删改查操作

    原文:http://www.cnblogs.com/linjiqin/archive/2011/05/26/2059182.html SQLite数据库增删改查操作 一.使用嵌入式关系型SQLite数 ...

  5. Yii2.0高级框架数据库增删改查的一些操作

    yii2.0框架是PHP开发的一个比较高效率的框架,集合了作者的大量心血,下面通过用户为例给大家详解yii2.0高级框架数据库增删改查的一些操作 --------------------------- ...

  6. WindowsPhone8 数据库增删改查

    今天第一次在博客园发表文章,如果有的地方写的不对,还请大家指出! 1.这就是一个简单wp8数据库增删改查 1.创建数据表Person [Table] public class Person : INo ...

  7. MVC——数据库增删改查(Razor)——Html语法

    一.显示界面 .Models(模板) private MyDBDataContext _context = new MyDBDataContext(); public List<Info> ...

  8. MVC——数据库增删改查(Razor)

    一.显示信息 .Models(模板) private MyDBDataContext _context = new MyDBDataContext(); //定义一个变量取出所有数据 public L ...

  9. MVC——数据库增删改查(aspx)

    MVC: V(View) :视图→就是页面的模板 C(Control): 控制器→客户主要面对的就是控制器, M(Model):模板→在模板里面主要就是写关于数据库的各种增删改查的方法 它们之间的关系 ...

随机推荐

  1. HashMap,LinkedHashMap,TreeMap的有序性

    HashMap 实际上是一个链表的数组.HashMap 的一个功能缺点是它的无序性,被存入到 HashMap 中的元素,在遍历 HashMap 时,其输出是无序的.如果希望元素保持输入的顺序,可以使用 ...

  2. py实现ftp

    https://www.cnblogs.com/wangziyi0513/p/11077323.html 参考原始代码: 修改了一下: 许多网友问中文路径乱码怎么办,我觉得应该讲中文路径转码后再发送. ...

  3. python3之selenium.webdriver 库练习自动化谷歌浏览器打开百度自动百度关键字

    import os,time,threading from selenium import webdriver from selenium.webdriver.common.keys import K ...

  4. 从Buck-Boost到Flyback

    电源的拓扑有很多种,但是其实我们能够理解一种拓扑,就可以理解其他拓扑结构.因为组成各种拓扑的基本元素是一样的. 对于隔离电源.大家接触最多的电路拓扑应该是 flyback. 但是大家一开始做电源的时候 ...

  5. CentOS 7 各个版本的区别

    CentOS 7 各个版本的区别 2017年07月04日 10:44:37 程诺 阅读数 52029    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.n ...

  6. Confluence 6 文件

    通过将你的文件上传到 Confluence 能够让你在一个统一的地方分享你项目小组的 PDF 文件,Office 文档,图片以及更多的内容. 自动版本,即时预览,权限控制和全文搜索意味着在网络驱动器上 ...

  7. [CF1204E]Natasha,Sasha and the Prefix Sums 题解

    前言 本文中的排列指由n个1, m个-1构成的序列中的一种. 题目这么长不吐槽了,但是这确实是一道好题. 题解 DP题话不多说,直接状态/变量/转移. 状态 我们定义f表示"最大prefix ...

  8. HDU 4738--Caocao's Bridges(重边无向图求桥)

    Caocao's Bridges Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  9. ACM技能表

    看看就好了(滑稽) 数据结构 栈 栈 单调栈 队列 一般队列 优先队列/单调队列 循环队列 双端队列 链表 一般链表 循环链表 双向链表 块状链表 十字链表 邻接表/邻接矩阵 邻接表 邻接多重表 Ha ...

  10. JS框架_(JQuery.js)点赞按钮动画

    百度云盘 传送门 密码: 0ihy 点赞按钮动画效果: (点击一次随机生成一颗小爱心,作为点赞动画~) <!doctype html> <html lang="en&quo ...