函数

用法

函数最常用的地方就是查询语句处

select 函数(字段) from 表名;
select 字段列表 from 表名 group by 分组字段 having 函数(字段);

字符串函数(字符串要用引号包裹!)

Concat

Concat(s1,s2,....,sn);

用途:将多个字符串拼接成一个

Lower和Upper

Lower(x)
Upper(x)

用途:Lower将x字符串全部转化为小写,Upper将字符串全部转化为大写

Lpad和Rpad

Lpad(str,n,pad)
Rpad(str,n,pad)

用途:Lpad是左填充,Rpad是右填充,将str字符串左/右边填充pad字符串知道他们之为n

原本字符串+填充字符串=n时停止

Trim

trim(x)

用途:将字符串x的首尾处空格去掉

Substring

substring(str,star_index,len)

用途:从star_index处截取字符串str,截取len个字符(下标从1开始)

日期函数(日期要用引号包裹!)

获取当前时间

Curdate()			->返回日期,年-月-日
Curtime() ->返回日期,时-分-秒
Now() ->返回日期,年-月-日-时-分-秒

截取当前时间其中一部分

Year(date)			->返回date日期中的年
Month(date) ->返回date日期中的月
day(date) ->返回date日期中的日

修改时间的

Date_add(date,interval 数值 值类型)

用法

select date_add(now(),interval 70 hour);在当前日期之后增加70小数后是什么时候

值类型有:year,month,day,hour,minute,second

Datediff(day1,day2)			->返回day2与day1之间相差多久

数值函数

对值取整

ceil(x)				->对x向上取整
floor(x) ->对x向下取整

其他

mod(x,y)			->返回x处于y的余数
rand() ->返回0到1之间的小数(精度很长!比如说0.5151915616)
round(x,y) ->求x四舍五入之后的值,保留y位小数

流程控制函数(就if判断这种)

if判断

if(value,t,f)	-->如果value的逻辑值是true就返回t值,如果为false就返回f值

ifnull判断

ifnull(value_1,value_2)		如果value_1不为null就返回value_1要不然就返回value_2

value可以为表达式/值,等形式

case 表达式 when 值 形式的判断

语法

case 表达式 when 值a then 返回值1 when 值b then 返回值2 .....else 抄底返回值 end;

解释:如果表达式=值a,就返回值1,如果表达式=值b,就返回值2,如果都不等于就返回抄底返回值

这个就和编程语言中的switch大致一致!

case when 值 形式的判断

语法

case when 条件表达式a then 返回值1 when 条件表达式b then 返回值2 else 抄底返回值 end;

解释:如果条件表达式a成立即为true就返回值1,如果条件表达式b成立就返回值2,都不成立就返回抄底返回值

这个就和编程语言中的if大致一致

约束条件

描述

约束就是限定表数据的规则

目的:保证数据库中的数据的正确性,有效性,完整性

在建表/修表的时候添加约束条件

约束是作用于表中字段上的

多个约束用空格分割

分类

约束 描述 关键字
非空约束 限制字段数据不能为null not null
唯一约束 保证字段数据是唯一不重复的 unique
主键约束 主键是一行数据的唯一标识,要求非空且唯一 primary key
默认约束 保存数据的时候如果没给字段值就给出默认值 default
检查约束 保证数据满足条件 check
外键约束 用于俩张表之间建立连接 foreign key

主键约束一般搭配自动增长auto_imporment一起使用

用法

Create table 表名(
字段名1 类型 约束条件,
....
字段名n 类型 约束条件,
);

check用法举例

age int check(age>5 && age<10)

default用法举例

age int default 1

修改字段约束

Alter table 表名 add 字段 类型 约束;
Alter table 表名 change 旧字段 新字段 类型 约束

外键

具有外键的表叫子表,外键关联的表叫父表

语法

创建外键

alter table 子表 add foreign(子表关联字段) references 父表(父表的关联字段);
alter table 子表 add constraint 外键名 foreign key(子表字段) referencnes 父表(父表关联字段名);

在创建表的时候创建外键

foreign key(子表关联字段) references 父表(父表关联字段);

如果在创建外键的时候没有设置外键名字那么mysql会默认给一个外键名

查看外键名

show create table 表名;

删除外键

alter table 子表名 drop foreign key 自定义的外键名;

默认删除/更新外键数据行为

Alter table 子表名 add constraint 外键名 foreign key(外键名) references 父表(关联字段) on update 关键字 on delete 关键字;

行为关键字

行为 描述
No action 当在父表中删除/更新记录的时候,首先检查该记录是否存在外键,如果存在就不允许删除/更新
restrict 与no action一致
cascade 当在父表中删除/更新记录的时候,首先检查该记录是否存在外键,如果存在,就也删除/更新子表中的记录
set null 当在父表中删除/更新记录的时候,首先检查该记录是否存在外键,如果存在,如果有就设置子表外键值为null(注意子表约束是否运行为null)
set default 父表有变更的时候,子表将外键值设为一个默认值(innodb引擎中不支持)

MYSQL-->函数与约束条件的更多相关文章

  1. Mysql - 函数

    Mysql提供的函数是在是太多了, 很多我都见过, 别说用了. 园子里面, 有人弄了一个比较全的. MYSQL函数 我这里会将他写的完全拷贝下来, 中间会插入一些自己项目中使用过的心得 一.数学函数 ...

  2. mysql连接查询,封装mysql函数

    连接查询 交叉连接语法: select  * | 字段列表 from 表1  cross join 表2 内连接: select *|字段列表 from 左表 inner join 右表 on 左表. ...

  3. MySQL 函数大全

    mysql函数大全 对于针对字符串位置的操作,第一个位置被标记为1. ASCII(str) 返回字符串str的最左面字符的ASCII代码值.如果str是空字符串,返回0.如果str是NULL,返回NU ...

  4. MySQL函数不能创建的解决方法

    MySQL函数不能创建,是一个很麻烦的问题,下面就为您提供了一个解决此问题的方法,如果您也遇到过类似的问题,不妨一看. http://database.51cto.com/art/201010/229 ...

  5. Mysql函数:Last_insert_id()语法讲解

    Mysql函数可以实现许多我们需要的功能,下面介绍的Mysql函数Last_insert_id()就是其中之一,希望对您学习Mysql函数能有所帮助. 自动返回最后一个INSERT或 UPDATE 查 ...

  6. linux下mysql函数的详细案列

    MYSQL * STDCALL mysql_real_connect(MYSQL *mysql, const char *host, const char *user, const char *pas ...

  7. MySQL函数讲解(MySQL函数大全)

    讲mysql函数之前先给大家展示一下利用mysql函数的一个例子: SELECT i.item_id, i.item_name, i.cid, i.last_update_time, u.url, u ...

  8. mysql函数全解析

    本文摘自:http://www.cnblogs.com/cocos/archive/2011/05/06/2039469.html mysql函数大全 对于针对字符串位置的操作,第一个位置被标记为1. ...

  9. MySQL函数笔记

    MySQL函数笔记 日期函数 SELECT t1.xcjyrq, t1.* FROM view_sbxx t1 WHERE t1.syzt ; SELECT t1.xcjyrq, t1.* FROM ...

  10. 【转】mysql函数

    MySQL函数 MySQL数据库提供了很多函数包括: 数学函数: 字符串函数: 日期和时间函数: 条件判断函数: 系统信息函数: 加密函数: 格式化函数: 一.数学函数 数学函数主要用于处理数字,包括 ...

随机推荐

  1. Nginx搭建简易文件服务器

    Nginx搭建简易文件服务器 1.安装nginx,此处略过 2.修改nginx配置文件 详细如下 # 此处为部分文件是否有权限,使用root,则不会出现403权限问题 user root; worke ...

  2. 解决 Vue 部署在域名子路由 问题

    我们先看下官方说明 默认情况下,Vue CLI 会假设你的应用是被部署在一个域名的根路径上,例如 https://www.my-app.com/ .如果应用被部署在一个子路径上,你就需要用这个选项指定 ...

  3. 分享一款免费OPC UA服务器

    OPC UA基于OPC基金会提供的新一代技术,提供安全,可靠和独立于厂商的,实现原始数据和预处理的信息从制造层级到生产计划或ERP层级的传输.通过OPC UA,所有需要的信息在任何时间,任何地点对每个 ...

  4. Git 09 IDEA撤销提交

    参考源 https://www.bilibili.com/video/BV1FE411P7B3?spm_id_from=333.999.0.0 版本 本文章基于 Git 2.35.1.2 如果提交了不 ...

  5. DOM及DOM相关操作

    DOM 概述: DOM 全称(document object model)文档对象模型(文档指定为对应html文档),对应的DOM就是操作HTML文档的(增删改查) DOM结构 document 文档 ...

  6. pre 预格式化文本标签

    预格式化指的是保留文本在源代码中的格式,页面中显示的和源代码中的效果完全一致.例如,原封不动地保留文本中的空白.空格.制表符等. 除非使用<pre/>标签包裹的文本,否则,浏览器不显示和源 ...

  7. 【JDBC】学习路径2-编写第一个JDBC程序

    第一章:导入jar包 在未安装MySQL数据库的请务必安装,安装教程:[MySQL]从入门到掌握2-下载安装 connector/J下载地址:https://dev.mysql.com/downloa ...

  8. 「学习笔记」斜率优化dp

    目录 算法 例题 任务安排 题意 思路 代码 [SDOI2012]任务安排 题意 思路 代码 任务安排 再改 题意 思路 练习题 [HNOI2008]玩具装箱 思路 代码 [APIO2010]特别行动 ...

  9. Typora的破解

    Typora是什么? Typora是一款支持实时预览的Markdown文本编辑器.支持即时渲染技术,这也是与其他Markdown编辑器最显著的区别.即时渲染使得你写Markdown就想是写Word文档 ...

  10. Linux之博客系统的搭建

    博客系统 三种配置:php+nginx+mysql 搭建步骤 改主机名 hostnamectl set-hostname lnmp 传入LNMP压缩包于root下(略) 配置网络(略)及yum源 先检 ...