当前位置: 首页 > news >正文

汉力建设网站网站换了域名做跳转

汉力建设网站,网站换了域名做跳转,中国风网站模板,学会wordpress后万能文章目录 Mysql基础一、数据模型1.1 关系型数据库与非关系型数据库1.2 Mysql 数据模型 二、SQL2.1 SQL 通用语法2.2 SQL分类2.3 DDL2.3.1 数据库操作2.3.2 表操作 — 创建 查询2.3.3 表操作— 修改删除2.3.4 数据类型2.3.4.1 数值类型2.3.4.2 字符串类型2.3.4.3 日期… 文章目录 Mysql基础一、数据模型1.1 关系型数据库与非关系型数据库1.2 Mysql 数据模型 二、SQL2.1 SQL 通用语法2.2 SQL分类2.3 DDL2.3.1 数据库操作2.3.2 表操作 — 创建 查询2.3.3 表操作— 修改删除2.3.4 数据类型2.3.4.1 数值类型2.3.4.2 字符串类型2.3.4.3 日期时间类型2.3.4.4 总结案例 2.4 DML2.4.1 插入数据2.4.2 更新数据2.4.3 删除数据 2.5 DQL2.5.1 数据准备2.5.2 基本语法2.5.3 基础查询2.5.4 条件查询2.5.4 聚合函数2.5.5 分组查询2.5.6 排序查询2.5.7 分页查询2.5.8 执行顺序 2.6 DCL2.6.1 管理用户2.6.2 权限控制 三、函数3.1 字符串函数3.2 数值函数3.3 日期函数3.4 流程函数 四、约束4.1 分类4.2 约束演示4.3 外键约束4.3.1 准备数据4.3.2 语法4.3.3 删除/更新行为 Mysql基础 一、数据模型 1.1 关系型数据库与非关系型数据库 关系型数据库 RDBMS 概念建立在关系模型基础上由多张表相互连接的二维表组成的数据库。 ​ Mysql数据库就是一个关系型数据库 ​ 二维表 ​ 使用表存储数据格式统一便于维护 ​ 使用SQL语言操作标准统一使用方便 非关系型数据库 ​ 不通过表结构存储数据的数据库。 ​ 比如Redis就是一个非关系型数据库 1.2 Mysql 数据模型 ​ 安装完MySQL之后我们的计算机就成为Mysql数据库服务器我们就可以通过客户端连接Mysql数据库管理系统DBMS然后可以使用SQL语句通过数据库管理系统来创建数据库也可以通过数据库管理系统在指定的数据库中创建表 名称全称简称数据库存储数据的仓库数据是有组织的进行存储DataBaseDB数据库管理系统操纵和管理数据库的大型软件DataBase Management System (DBMS)SQL操作关系型数据库的编程语言定义了一套操作Structured Query Language (SQL) 二、SQL 2.1 SQL 通用语法 SQL语句可以单行或多行书写以分号结尾 SQL语句可以使用空格/缩进来增强语句可读性 MySQL数据库的SQL语句不区分大小写关键字建议使用大写 单行注释 --注释内容 或者 #注释内容 多行注释 /注释内容/ 2.2 SQL分类 分类全称说明DDLData Definition Language数据定义语言用来定义数据库对象(数据库表字段)DMLData Manipulation Language数据操作语言用来对数据库表中的数据进行增删改DQLData Query Language数据查询语言用来查询数据库中表的记录DCLData Control Language数据控制语言用来创建数据库用户、控制数据库的 2.3 DDL ​ 概念Data Definition Language数据定义语言用来**定义数据库对象(数据库表字段) **。 2.3.1 数据库操作 查询所有数据库 show databases ;查询当前数据库 select database() ;创建数据库 create database [ if not exists ] 数据库名 [ default charset 字符集 ] [ collate 排序 规则 ] ;​ 数据库的字符集不建议设置为UTF-8因为UTF-8的汉字存储长度是三个字节但是数据库中有一些特殊字符是占用四个字节的所以 推荐使用utf8mb4因为支持四个字节 删除 DROP DATABASE [if exists] 数据库名;使用 USE 数据库名;2.3.2 表操作 — 创建 查询 查询当前数据库所有表 show tables;查看指定表结构 desc 表名 ;​ 可以查看到指定表的字段字段的类型、是否可以为NULL是否存在默认值等信息 查询指定表的建表语句 show create table 表名 ;​ 通过这条指令主要是用来查看建表语句的而有部分参数我们在创建表的时候并未指定也会查询到因为这部分是数据库的默认值如存储引擎、字符集等。 CREATE TABLE dept ( id int unsigned NOT NULL AUTO_INCREMENT COMMENT ‘主键\r\nID’, name varchar(10) NOT NULL COMMENT ‘部门名称’, create_time datetime NOT NULL COMMENT ‘创建时间’, update_time datetime NOT NULL COMMENT ‘修改时间’, PRIMARY KEY (id), UNIQUE KEY name (name) ) ENGINEInnoDB AUTO_INCREMENT6 DEFAULT CHARSETutf8mb4 COLLATEutf8mb4_0900_ai_ci COMMENT‘部门表’ 创建表 CREATE TABLE 表名( 字段1 字段1类型 [ COMMENT 字段1注释 ], 字段2 字段2类型 [COMMENT 字段2注释 ], 字段3 字段3类型 [COMMENT 字段3注释 ], ...... 字段n 字段n类型 [COMMENT 字段n注释 ] ) [ COMMENT 表注释 ] ;最后一个字段后面没有逗号 create table if not exists tb_user(id int COMMENT 编号,name varchar(50) COMMENT 姓名,age int COMMENT 年龄,gender varchar(1) COMMENT 性别) comment 用户表;2.3.3 表操作— 修改删除 添加字段 ALTER TABLE 表名 ADD 字段名 类型 (长度) [ COMMENT 注释 ] [ 约束 ];为emp表增加一个新的字段”昵称”为nickname类型为varchar(20) ALTER TABLE emp ADD nickname varchar(20) COMMENT 昵称;修改数据类型 ALTER TABLE 表名 MODIFY 字段名 新数据类型 (长度);修改字段名和类型 ALTER TABLE 表名 CHANGE 旧字段名 新字段名 类型 (长度) [ COMMENT 注释 ] [ 约束 ];ALTER TABLE emp CHANGE nickname username varchar(30) COMMENT 昵称;删除字段 ALTER TABLE 表名 DROP 字段名;将emp表的字段username删除 ALTER TABLE emp DROP username;修改表名 ALTER TABLE 表名 RENAME TO 新表名;删除表 DROP TABLE [ IF EXISTS ] 表名;在删除表的时候表中的全部数据也都会被删除。 删除指定表并重新创建该表 TRUNCATE TABLE 表名;truncate: 截断、截取 在删除表的时候表中的全部数据也都会被删除。 2.3.4 数据类型 三类数值类型、字符串类型、日期时间类型。 2.3.4.1 数值类型 TINYINT 类似Java语言的byte占位1个字节 SMALLINT 类似Java语言当中的short占位2个字节 INT/INTEGER 类似Java语言中int占用4个字节 BIGINT 类似Java语言当中的long占用8个字节 前五种是整形后三种是浮点型 FLOAT 类似Java语言中的float占用4个字节 DOUBLE 类似Java语言中的double类型占用8个字节 类型大小有符号(SIGNED)范围无符号(UNSIGNED)范围描述TINYINT1 byte(-128127)(0255)小整数值SMALLINT2 bytes(-3276832767)(065535)大整数值MEDIUMINT3bytes(-83886088388607)(016777215)大整数值INT/INTEGER4bytes(-21474836482147483647)(04294967295)大整数值BIGINT8bytes(-263263-1)(02^64-1)极大整数值FLOAT4bytes(-3.402823466 E383.402823466351 E38)0 和 (1.175494351 E-383.402823466 E38)单精度浮点数DOUBLE8bytes(-1.7976931348623157E3081.7976931348623157E308)0 和(2.2250738585072014E-3081.7976931348623157E308)双精度浮点数值DECIMAL依赖于M(精度)和D(标度)的值依赖于M(精度)和D(标度)的值小数值(精确定点数) 什么是精度和标度 如123.45 精度就是整个长度5标度就是小数点后位数2 score double(4,1)是什么含义 score字段的精度是4100.0只有一位小数 怎么使用无符号范围 age tinyint unsigned 表示age字段的范围是(0255) 2.3.4.2 字符串类型 类型大小描述CHAR0-255 bytes定长字符串(需要指定长度)VARCHAR0-65535 bytes变长字符串(需要指定长度)TINYBLOB0-255 bytes不超过255个字符的二进制数据TINYTEXT0-255 bytes短文本字符串BLOB0-65 535 bytes二进制形式的长文本数据TEXT0-65 535 bytes长文本数据MEDIUMBLOB0-16 777 215 bytes二进制形式的中等长度文本数据MEDIUMTEXT0-16 777 215 bytes中等长度文本数据LONGBLOB0-4 294 967 295 bytes二进制形式的极大文本数据LONGTEXT0-4 294 967 295 bytes极大文本数据 char 与 varchar 的区别 ​ char 与 varchar 都可以描述字符串char是定长字符串指定长度多长就占用多少个字符和字段值的长度无关 。而varchar是变长字符串指定的长度为最大占用长度 。**相对来说char的性能会更高些。**因为varchar在存储的时候会根据内容计算存储空间大小所以性能低一些 用户名 username ------ 长度不定, 最长不会超过50 ​ username varchar(50) 性别 gender --------- 存储值, 不是男,就是女 ​ gender char(1) 手机号 phone -------- 固定长度为11 ​ phone char(11) 2.3.4.3 日期时间类型 DATE、TIME、DATETIME使用的会多一些 类型大小范围格式描述DATE31000-01-01 至 9999-12-31YYYY-MM-DD日期值TIME3-838:59:59 至 838:59:59HH:MM:SS时间值或持续时间YEAR11901 至 2155YYYY年份值DATETIME81000-01-01 00:00:00 至9999-12-31 23:59:59YYYY-MM-DD HH:MM:SS混合日期和时间值TIMESTAMP41970-01-01 00:00:01 至2038-01-19 03:14:07YYYY-MM-DD HH:MM:SS混合日期和时间值时间戳 2.3.4.4 总结案例 设计一张员工信息表要求如下 编号纯数字 员工工号 (字符串类型长度不超过10位) 员工姓名字符串类型长度不超过10位 性别男/女存储一个汉字 年龄正常人年龄不可能存储负数 身份证号二代身份证号均为18位身份证中有X这样的字符 入职时间取值年月日即可 create table emp( id int comment 编号, workno varchar(10) comment 工号, name varchar(10) comment 姓名, gender char(1) comment 性别, age tinyint unsigned comment 年龄, idcard char(18) comment 身份证号, entrydate date comment 入职时间 ) comment 员工表;2.4 DML ​ DML英文全称是Data Manipulation Language(数据操作语言)用来对数据库中表的数据记录进行增、删、改操作。 添加数据INSERT修改数据UPDATE删除数据DELETE 2.4.1 插入数据 指定字段添加数据 INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...); 1比如 insert into employee(id,workno,name,gender,age,idcard,entrydate) values(1,1,Itcast,男,10,123456789012345678,2000-01-01);给全部字段添加数据 INSERT INTO 表名 VALUES (值1, 值2, ...);但是数据的字段一定要进行对应 insert into employee values(2,2,张无忌,男,18,123456789012345670,2005-01-01);批量添加数据 INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...), (值1, 值2, ...), (值1, 值2, ...) ;或者 INSERT INTO 表名 VALUES (值1, 值2, ...), (值1, 值2, ...), (值1, 值2, ...) ;案例 insert into employee values(3,3,韦一笑,男,38,123456789012345670,2005-01-01),(4,4,赵敏,女,18,123456789012345670,2005-01-01);注意事项 插入数据时指定的字段顺序需要与值的顺序是一一对应的。字符串和日期型数据应该包含在引号中。插入的数据大小应该在字段的规定范围内。 2.4.2 更新数据 语法 UPDATE 表名 SET 字段名1 值1 , 字段名2 值2 , .... [ WHERE 条件 ] ;案例 修改id为1的数据将name修改为itheima update employee set name itheima where id 1;修改id为1的数据, 将name修改为小昭, gender修改为 女 update employee set name 小昭 , gender 女 where id 1;将所有的员工入职日期修改为 2008-01-01 update employee set entrydate 2008-01-01;注意 ​ 修改语句的条件可以有也可以没有如果没有条件则会修改整张表的所有数据。 2.4.3 删除数据 语法 DELETE FROM 表名 [ WHERE 条件 ] ;删除gender为女的员工 delete from employee where gender 女;删除所有员工 delete from employee;注意事项 DELETE 语句的条件可以有也可以没有如果没有条件则会删除整张表的所有数据。DELETE 语句不能删除某一个字段的值(可以使用UPDATE将该字段值置为NULL即可)当进行删除全部数据操作时datagrip会提示我们询问是否确认删除我们直接点击Execute即可。 2.5 DQL ​ DQL英文全称是Data Query Language(数据查询语言)数据查询语言用来查询数据库中表的记录。 2.5.1 数据准备 drop table if exists employee;create table emp(id int comment 编号,workno varchar(10) comment 工号,name varchar(10) comment 姓名,gender char(1) comment 性别,age tinyint unsigned comment 年龄,idcard char(18) comment 身份证号,workaddress varchar(50) comment 工作地址,entrydate date comment 入职时间 )comment 员工表;INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (1, 00001, 柳岩666, 女, 20, 123456789012345678, 北京, 2000-01-01);INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (2, 00002, 张无忌, 男, 18, 123456789012345670, 北京, 2005-09-01);INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (3, 00003, 韦一笑, 男, 38, 123456789712345670, 上海, 2005-08-01);INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (4, 00004, 赵敏, 女, 18, 123456757123845670, 北京, 2009-12-01);INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (5, 00005, 小昭, 女, 16, 123456769012345678, 上海, 2007-07-01);INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (6, 00006, 杨逍, 男, 28, 12345678931234567X, 北京, 2006-01-01);INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (7, 00007, 范瑶, 男, 40, 123456789212345670, 北京, 2005-05-01);INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (8, 00008, 黛绮丝, 女, 38, 123456157123645670, 天津, 2015-05-01);INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (9, 00009, 范凉凉, 女, 45, 123156789012345678, 北京, 2010-04-01);INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (10, 00010, 陈友谅, 男, 53, 123456789012345670, 上海, 2011-01-01);INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (11, 00011, 张士诚, 男, 55, 123567897123465670, 江苏, 2015-05-01);INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (12, 00012, 常遇春, 男, 32, 123446757152345670, 北京, 2004-02-01);INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (13, 00013, 张三丰, 男, 88, 123656789012345678, 江苏, 2020-11-01);INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (14, 00014, 灭绝, 女, 65, 123456719012345670, 西安, 2019-05-01);INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (15, 00015, 胡青牛, 男, 70, 12345674971234567X, 西安, 2018-04-01);INSERT INTO emp (id, workno, name, gender, age, idcard, workaddress, entrydate) VALUES (16, 00016, 周芷若, 女, 18, null, 北京, 2012-06-01);2.5.2 基本语法 SELECT字段列表 FROM表名列表 WHERE条件列表 GROUP BY分组字段列表 HAVING分组后条件列表 ORDER BY排序字段列表 LIMIT分页参数基本查询不带任何条件条件查询WHERE聚合函数count、max、min、avg、sum分组查询group by排序查询order by分页查询limit 2.5.3 基础查询 查询多个字段 SELECT 字段1, 字段2, 字段3 ... FROM 表名 ;SELECT * FROM 表名 ;注意 * 号代表查询所有字段在实际开发中尽量少用不直观、影响效率。 案例 select id,workno,name,gender,age,idcard,workaddress,entrydate from emp;字段设置别名 SELECT 字段1 [ AS 别名1 ] , 字段2 [ AS 别名2 ] ... FROM 表名;SELECT 字段1 [ 别名1 ] , 字段2 [ 别名2 ] ... FROM 表名;案例 select workaddress as 工作地址 from emp;select workaddress 工作地址 from emp;去除重复记录 SELECT DISTINCT 字段列表 FROM 表名;select distinct workaddress 工作地址 from emp;2.5.4 条件查询 语法 SELECT 字段列表 FROM 表名 WHERE 条件列表 ;常见比较运算符条件 比较运算符功能大于大于等于小于小于等于等于 或 !不等于BETWEEN … AND …在某个范围之内(含最小、最大值)IN(…)在in之后的列表中的值多选一LIKE 占位符模糊匹配(_匹配单个字符, %匹配任意个字符)IS NULL是NULL 常见逻辑运算符 逻辑运算符功能AND 或 并且 (多个条件同时成立)OR 或 ||或者 (多个条件任意一个成立)NOT 或 !非 , 不是 案例 查询年龄等于18 或 20 或 40 的员工信息 select * from emp where age 18 or age 20 or age 40;select * from emp where age in(18,20,40);查询姓名为两个字的员工信息 select * from emp where name like __;查询身份证号最后一位是X的员工信息 select * from emp where idcard like %X;select * from emp where idcard like _________________X;2.5.4 聚合函数 将一列数据作为一个整体进行纵向计算 语法 SELECT 聚合函数(字段列表) FROM 表名 ;NULL值是不参与所有聚合函数运算!!! 常见的聚合函数 函数功能count统计数量max最大值min最小值avg平均值sum求和 案例 统计该企业员工数量 -- 统计的是总记录数,null也统计 select count(*) from emp; -- 统计的是idcard字段不为null的记录数 select count(idcard) from emp; 下面等同于select count(*) from emp; select count(1) from emp; ​ count(1)“是SQL查询语句中的一种写法用于对一张表进行计数。它的作用是统计表中所有的行数可以用来查询表中数据的总量。与其等价的写法是count(*)”它也可以用来计数。不同的数据库系统在使用count函数时可能存在些许差异但通常都支持这两种写法。 2.5.5 分组查询 语法 SELECT 字段列表 FROM 表名 [ WHERE 条件 ] GROUP BY 分组字段名 [HAVING 分组后过滤条件 ];where与having区别? 执行时机不同where是分组之前进行过滤不满足where条件不参与分组而having是分组之后对结果进行过滤。 判断条件不同where不能对聚合函数进行判断而having可以。 注意事项 分组之后查询的字段一般为聚合函数和分组字段查询其他字段无任何意义。 执行顺序: where 聚合函数 having 。 支持多字段分组, 具体语法为 : group by columnA,columnB 案例 根据性别分组 , 统计男性员工 和 女性员工的数量 select gender, count(*) from emp group by gender ;根据性别分组 , 统计男性员工 和 女性员工的平均年龄 select gender, avg(age) from emp group by gender ;查询年龄小于45的员工 , 并根据工作地址分组 , 获取员工数量大于等于3的工作地址 select workaddress, count(*) address_count from emp where age 45 group by workaddress having address_count 3;统计各个工作地址上班的男性及女性员工的数量 select workaddress, gender, count(*) 数量 from emp group by gender , workaddress;2.5.6 排序查询 排序在日常开发中是非常常见的一个操作有升序排序也有降序排序。 语法 SELECT 字段列表 FROM 表名 ORDER BY 字段1 排序方式1 , 字段2 排序方式2 ;排序方式 ASC : 升序(默认值)从小到大DESC: 降序从大到小 注意事项 如果是升序, 可以不指定排序方式ASC ; 如果是多字段排序当第一个字段值相同时才会根据第二个字段进行排序 ; 案例 根据年龄对公司的员工进行升序排序 select * from emp order by age asc;select * from emp order by age;根据年龄对公司的员工进行升序排序 , 年龄相同 , 再按照入职时间进行降序排序 select * from emp order by age asc , entrydate desc;2.5.7 分页查询 分页操作在业务系统开发时也是非常常见的一个功能我们在网站中看到的各种各样的分页条后台都需要借助于数据库的分页操作。 ​ 语法 SELECT 字段列表 FROM 表名 LIMIT 起始索引, 查询记录数 ;注意事项: 起始索引从0开始起始索引 查询页码 - 1* 每页显示记录数。 分页查询是数据库的方言不同的数据库有不同的实现MySQL中是LIMIT。 如果查询的是第一页数据起始索引可以省略直接简写为 limit 10。 案例 查询第1页员工数据, 每页展示10条记录 select * from emp limit 0,10; select * from emp limit 10;查询第2页员工数据, 每页展示10条记录 -------- (页码-1)*页展示记录数 select * from emp limit 10,10;2.5.8 执行顺序 2.6 DCL ​ DCL英文全称是Data Control Language(数据控制语言)用来管理数据库用户、控制数据库的访问权限。 2.6.1 管理用户 查询用户 select * from mysql.user;或者 use mysql;select * from user;​ 其中 Host代表当前用户访问的主机, 如果为localhost, 仅代表只能够在当前本机访问是不可以远程访问的。 User代表的是访问该数据库的用户名。 ​ 在MySQL中需要通过Host和User来唯一标识一个用户。 创建用户 CREATE USER 用户名主机名 IDENTIFIED BY 密码;​ 仅仅是创建了用户并没有权限访问其他数据库 创建用户itcast, 只能够在当前主机localhost访问, 密码123456 create user itcastlocalhost identified by 123456; 创建用户heima, 可以在任意主机访问该数据库, 密码123456 create user heima% identified by 123456;修改用户密码 ALTER USER 用户名主机名 IDENTIFIED WITH mysql_native_password BY 新密码 ;修改用户heima的访问密码为1234 alter user heima% identified with mysql_native_password by 1234;删除用户 DROP USER 用户名主机名 ;删除 itcastlocalhost 用户 drop user itcastlocalhost;注意事项 在MySQL中需要通过用户名主机名的方式来唯一标识一个户。主机名可以使用 % 通配。这类SQL开发人员操作的比较少主要是DBA Database Administrator 数据库管理员使用。 2.6.2 权限控制 权限官方文档MySQL :: MySQL 8.0 Reference Manual :: 6.2.2 Privileges Provided by MySQL 常用权限 权限说明ALL, ALL PRIVILEGES所有权限SELECT查询数据INSERT插入数据UPDATE修改数据DELETE删除数据ALTERALTERDROP删除数据库/表/视图CREATE创建数据库/表 查询权限 SHOW GRANTS FOR 用户名主机名 ;show grants for heima%;授予权限 GRANT 权限列表 ON 数据库名.表名 TO 用户名主机名;授予 ‘heima’‘%’ 用户itcast数据库所有表的所有操作权限 grant all on itcast.* to heima%;撤销权限 REVOKE 权限列表 ON 数据库名.表名 FROM 用户名主机名;revoke all on itcast.* from heima%;注意事项 多个权限之间使用逗号分隔 授权时 数据库名和表名可以使用 * 进行通配代表所有。 三、函数 函数 是指一段可以直接被另一段程序调用的程序或代码 四类 字符串函数、数值函数、日期函数、流程函数 3.1 字符串函数 函数功能CONCAT(S1,S2,…Sn)字符串拼接将S1S2… Sn拼接成一个字符串LOWER(str)将字符串str全部转为小写UPPER(str)将字符串str全部转为大写LPAD(str,n,pad)左填充用字符串pad对str的左边进行填充达到n个字符串长度RPAD(str,n,pad)右填充用字符串pad对str的右边进行填充达到n个字符串长度TRIM(str)去掉字符串头部和尾部的空格SUBSTRING(str,start,len)返回从字符串str从start位置起的len个长度的字符串 concat 字符串拼接 select concat(hello,Mysql)结果helloMysql lower全部转小写 SELECT LOWER(Hello)结果hello upper : 全部转大写 SELECT UPPER(Hello)结果HELLO lpad : 左填充 SELECT LPAD(Hello,10,Mysql)结果MysqlHello rpad : 右填充 SELECT rpad(Hello,10,Mysql)结果HelloMysql trim : 去除头尾空格 select trim( Hello MySQL );结果Hello MySQL substring : 截取子字符串 select substring(Hello MySQL,1,5);结果:Hello 案例 由于业务需求变更企业员工的工号统一为5位数目前不足五位数的全部在前面补0. update emp set workno lpad(workno, 5, 0);3.2 数值函数 函数功能CEIL(x)向上取整FLOOR(x)向下取整MOD(x,y)返回x/y的模RAND()返回0~1内的随机数ROUND(x,y)求参数x的四舍五入的值保留y位小数 案例 通过数据库的函数生成一个六位数的随机验证码。 SELECT lpad(floor(rand()*1000000) ,6,0)select lpad(round(rand()*1000000 , 0), 6, 0);3.3 日期函数 函数功能CURDATE()返回当前日期CURTIME()返回当前时间NOW()返回当前日期和时间YEAR(date)获取指定date的年份MONTH(date)获取指定date的月份DAY(date)获取指定date的日期DATE_ADD(date, INTERVAL exprtype)返回一个日期/时间值加上一个时间间隔expr后的时间值DATEDIFF(date1,date2)返回起始时间date1 和 结束时间date2之间的天date1-date2 date_add增加指定的时间间隔 select date_add(now(), INTERVAL 70 YEAR );select date_add(now(), INTERVAL 70 MONTH );select date_add(now(), INTERVAL 70 DAY );datediff获取两个日期相差的天数 -- -61 select datediff(2021-10-01, 2021-12-01);案例 ​ 查询所有员工的入职天数并根据入职天数倒序排序。 ELECT name , datediff(now(),entrydate) as date from emp ORDER BY date DESCselect name, datediff(curdate(), entrydate) as entrydays from emp order by entrydays desc;3.4 流程函数 可以在SQL语句中实现条件筛选从而提高语句的效率。 函数功能IF(value , t , f)如果value为true则返回t否则返回fIFNULL(value1 , value2)如果value1不为空返回value1否则返回value2CASE WHEN [ val1 ] THEN [res1] … ELSE [ default ] END如果val1为true返回res1… 否则返回default默认值CASE [ expr ] WHEN [ val1 ] THEN [res1] … ELSE [ default ] END如果expr的值等于val1返回res1… 否则返回default默认值 case when then else end 需求: ​ 查询emp表的员工姓名和工作地址 (北京/上海 ---- 一线城市 , 其他 ---- 二线城市) selectname,( case workaddress when 北京 then 一线城市 when 上海 then 一线城市 else 二线城市 end ) as 工作地址from emp;四、约束 4.1 分类 概念约束是作用于表中字段上的规则用于限制存储在表中的数据。 目的保证数据库中数据的正确、有效性和完整性。 约束描述关键字非空约束限制该字段的数据不能为nullNOT NULL唯一约束保证该字段的所有数据都是唯一、不重复的UNIQUE主键约束主键是一行数据的唯一标识要求非空且唯一PRIMARY KEY默认约束保存数据时如果未指定该字段的值则采用默认值DEFAULT检查约束(8.0.16版本之后)保证字段值满足某一个条件CHECK外键约束用来让两张表的数据之间建立连接保证数据的一致性和完整性FOREIGN KEY 注意 约束是作用于表中字段上的可以在创建表/修改表的时候添加约束。4.2 约束演示 create table tb_user(id int PRIMARY KEY AUTO_INCREMENT COMMENT ID唯一标识,name varchar(10) NOT NULL UNIQUE COMMENT 姓名,age int CHECK (0age age120) COMMENT 年龄,status char(1) DEFAULT(1) COMMENT 状态,gender char(1) COMMENT 状态);4.3 外键约束 外键用来让两张表的数据之间建立连接从而保证数据的一致性和完整性。 4.3.1 准备数据 create table dept(id int auto_increment comment ID primary key,name varchar(50) not null comment 部门名称)comment 部门表;INSERT INTO dept (id, name) VALUES (1, 研发部), (2, 市场部),(3, 财务部), (4,销售部), (5, 总经办);create table emp(id int auto_increment comment ID primary key,name varchar(50) not null comment 姓名,age int comment 年龄,job varchar(20) comment 职位,salary int comment 薪资,entrydate date comment 入职时间,managerid int comment 直属领导ID,dept_id int comment 部门ID )comment 员工表;INSERT INTO emp (id, name, age, job,salary, entrydate, managerid, dept_id) VALUES (1, 金庸, 66, 总裁,20000, 2000-01-01, null,5),(2, 张无忌, 20,项目经理,12500, 2005-12-05, 1,1), (3, 杨逍, 33, 开发, 8400,2000-11-03, 2,1),(4, 韦一笑, 48, 开发,11000, 2002-02-05, 2,1), (5, 常遇春, 43, 开发,10500, 2004-09-07, 3,1),(6, 小昭, 19, 程序员鼓励师,6600, 2004-10-12, 2,1);4.3.2 语法 添加外键 CREATE TABLE 表名( 字段名 数据类型,...[CONSTRAINT] [外键名称] FOREIGN KEY (外键字段名) REFERENCES 主表 (主表列名) );ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名) REFERENCES 主表 (主表列名) ;删除外键 ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;4.3.3 删除/更新行为 ​ 添加了外键之后再删除父表数据时产生的约束行为我们就称为删除/更新行为。具体的删除/更新行为有以下几种 行为说明NO ACTION当在父表中删除/更新对应记录时首先检查该记录是否有对应外键如果有则不允许删除/更新。 (与 RESTRICT 一致) 默认行为RESTRICT当在父表中删除/更新对应记录时首先检查该记录是否有对应外键如果有则不允许删除/更新。 (与 NO ACTION 一致) 默认行为CASCADE当在父表中删除/更新对应记录时首先检查该记录是否有对应外键如果有则也删除/更新外键在子表中的记录。SET NULL当在父表中删除对应记录时首先检查该记录是否有对应外键如果有则设置子表中该外键值为null这就要求该外键允许取null。SET DEFAULT父表有变更时子表将外键列设置成一个默认的值 (Innodb不支持) 具体语法 将行为设置为CASCADE ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段) REFERENCES 主表名 (主表字段名) ON UPDATE CASCADE ON DELETE CASCADE;
文章转载自:
http://www.morning.lmcrc.cn.gov.cn.lmcrc.cn
http://www.morning.rgmls.cn.gov.cn.rgmls.cn
http://www.morning.tmxfn.cn.gov.cn.tmxfn.cn
http://www.morning.easiuse.com.gov.cn.easiuse.com
http://www.morning.lmnbp.cn.gov.cn.lmnbp.cn
http://www.morning.yqpzl.cn.gov.cn.yqpzl.cn
http://www.morning.kpfds.cn.gov.cn.kpfds.cn
http://www.morning.yjxfj.cn.gov.cn.yjxfj.cn
http://www.morning.sgfgz.cn.gov.cn.sgfgz.cn
http://www.morning.hhrpy.cn.gov.cn.hhrpy.cn
http://www.morning.shxmr.cn.gov.cn.shxmr.cn
http://www.morning.sacxbs.cn.gov.cn.sacxbs.cn
http://www.morning.mbhdl.cn.gov.cn.mbhdl.cn
http://www.morning.jxrpn.cn.gov.cn.jxrpn.cn
http://www.morning.bscsp.cn.gov.cn.bscsp.cn
http://www.morning.cltrx.cn.gov.cn.cltrx.cn
http://www.morning.ngzkt.cn.gov.cn.ngzkt.cn
http://www.morning.fwnyz.cn.gov.cn.fwnyz.cn
http://www.morning.gqfbh.cn.gov.cn.gqfbh.cn
http://www.morning.jpfpc.cn.gov.cn.jpfpc.cn
http://www.morning.skdrp.cn.gov.cn.skdrp.cn
http://www.morning.qgtbx.cn.gov.cn.qgtbx.cn
http://www.morning.rykgh.cn.gov.cn.rykgh.cn
http://www.morning.mcbqq.cn.gov.cn.mcbqq.cn
http://www.morning.yrjkz.cn.gov.cn.yrjkz.cn
http://www.morning.gcfrt.cn.gov.cn.gcfrt.cn
http://www.morning.yzygj.cn.gov.cn.yzygj.cn
http://www.morning.wnhsw.cn.gov.cn.wnhsw.cn
http://www.morning.mkyny.cn.gov.cn.mkyny.cn
http://www.morning.hgcz.cn.gov.cn.hgcz.cn
http://www.morning.nclps.cn.gov.cn.nclps.cn
http://www.morning.gtdf.cn.gov.cn.gtdf.cn
http://www.morning.thbkc.cn.gov.cn.thbkc.cn
http://www.morning.tnfyj.cn.gov.cn.tnfyj.cn
http://www.morning.sskkf.cn.gov.cn.sskkf.cn
http://www.morning.krlsz.cn.gov.cn.krlsz.cn
http://www.morning.tdqhs.cn.gov.cn.tdqhs.cn
http://www.morning.xprzq.cn.gov.cn.xprzq.cn
http://www.morning.tgczj.cn.gov.cn.tgczj.cn
http://www.morning.plqsz.cn.gov.cn.plqsz.cn
http://www.morning.bfkrf.cn.gov.cn.bfkrf.cn
http://www.morning.ptqpd.cn.gov.cn.ptqpd.cn
http://www.morning.qkqgj.cn.gov.cn.qkqgj.cn
http://www.morning.eronghe.com.gov.cn.eronghe.com
http://www.morning.nlkm.cn.gov.cn.nlkm.cn
http://www.morning.hbhnh.cn.gov.cn.hbhnh.cn
http://www.morning.jmwrj.cn.gov.cn.jmwrj.cn
http://www.morning.lgkbn.cn.gov.cn.lgkbn.cn
http://www.morning.xbxks.cn.gov.cn.xbxks.cn
http://www.morning.khdw.cn.gov.cn.khdw.cn
http://www.morning.zbjfq.cn.gov.cn.zbjfq.cn
http://www.morning.syrzl.cn.gov.cn.syrzl.cn
http://www.morning.jpfpc.cn.gov.cn.jpfpc.cn
http://www.morning.rgnp.cn.gov.cn.rgnp.cn
http://www.morning.rnwt.cn.gov.cn.rnwt.cn
http://www.morning.mmqng.cn.gov.cn.mmqng.cn
http://www.morning.srgwr.cn.gov.cn.srgwr.cn
http://www.morning.llllcc.com.gov.cn.llllcc.com
http://www.morning.dfqmy.cn.gov.cn.dfqmy.cn
http://www.morning.gqtzb.cn.gov.cn.gqtzb.cn
http://www.morning.rnds.cn.gov.cn.rnds.cn
http://www.morning.mxmzl.cn.gov.cn.mxmzl.cn
http://www.morning.cplym.cn.gov.cn.cplym.cn
http://www.morning.jpjpb.cn.gov.cn.jpjpb.cn
http://www.morning.nyhtf.cn.gov.cn.nyhtf.cn
http://www.morning.kynf.cn.gov.cn.kynf.cn
http://www.morning.qtyfb.cn.gov.cn.qtyfb.cn
http://www.morning.flncd.cn.gov.cn.flncd.cn
http://www.morning.gqwbl.cn.gov.cn.gqwbl.cn
http://www.morning.yrnyz.cn.gov.cn.yrnyz.cn
http://www.morning.txgjx.cn.gov.cn.txgjx.cn
http://www.morning.tsxg.cn.gov.cn.tsxg.cn
http://www.morning.dlgjdg.cn.gov.cn.dlgjdg.cn
http://www.morning.yfmlj.cn.gov.cn.yfmlj.cn
http://www.morning.tndhm.cn.gov.cn.tndhm.cn
http://www.morning.cwgpl.cn.gov.cn.cwgpl.cn
http://www.morning.etsaf.com.gov.cn.etsaf.com
http://www.morning.fthcn.cn.gov.cn.fthcn.cn
http://www.morning.qnftc.cn.gov.cn.qnftc.cn
http://www.morning.mzmqg.cn.gov.cn.mzmqg.cn
http://www.tj-hxxt.cn/news/273515.html

相关文章:

  • 流量统计网站推广法注册工作室和公司的区别
  • 新公司做网站有效果吗wordpress recent posts
  • 网站开发设计师岗位职责网站建设对我有什么好处
  • 常州网站建设方案策划宿州哪家做网站好
  • 著名的网站建设公司架设网站是自己架设服务器还是租服务器
  • 网站没收录了怎么办做网站大概价格
  • 快速建站服务器自己做的网站加载慢
  • 福州网站建设加推广宁波免费网站建站模板
  • 慈溪想做网站的公司北京做养生SPA的网站建设
  • 如何查看网站开发商商城网站怎么做推广
  • 流行用什么做网站网站目标人群
  • 网站备案法律法规深圳凌 网站开发
  • 学网站维护汕头企业网站建设设计
  • 网站做外链好嘛免费网络短剧网站
  • 网站开发和前端开发卢松松wordpress
  • 绥化网站建设做产品网站营销推广
  • 国内免费域名注册网站10岁一12岁的创意手工
  • 网站建设客网站哪里有网站开发公司
  • 模板展示网站源码网站的管理和维护
  • 河源网站开发wordpress 速度优化
  • 汽车网站代码沧州网站建设哪家专业
  • 手机如何创建简易网站磁盘阵列做网站
  • 创建个人网站制作流程步骤动易医院网站管理系统
  • 青岛出版集团网站标准百度网站建设
  • 国内网站建设流程wordpress破解汉化版
  • 厦门市建设保障性住房局网站租车网站建设方案
  • 商城类网站建设方案免费百度seo引流
  • 湖南旅游网站开发平台设计思路
  • 网站设计 重庆做微电影模板下载网站
  • 站长工具源码做网站加一个定位功能要多少钱