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

一、数据库基础

数据库

一、数据库基础

1、一些概念

  • 数据库:数据库(DataBase ,简称DB),就是信息的集合。数据库是由数据库管理系统管理的数据的集合;
  • 数据库管理系统:简称DBMS 。是一种操纵和管理数据库的大型软件,通常用于建立、使用和维护数据库;
  • 数据库系统:DBS。通常由软件、数据库和数据管理员(DBA)组成;
  • 数据库管理员:DBA。负责全面管理和控制数据库系统。

  • 元组:是关系数据库中的基本概念,关系是一张表,表中的每行(即数据库中的每条记录)就是一个元组,每列就是一个属性。
  • 码:能唯一标识实体的属性,对应表中的列
  • 候选码:若关系中的某一属性或属性组的值能唯一的标识一个元组 ,则称该属性组为候选码。例如,学生实体中,“学号”能唯一的区分学生实体,同时“班级”和“姓名”组合也可以唯一的区分学生实体,所以{学号}、{班级,姓名}都是候选码
  • 主码:也叫主键。主码是从候选码中选出来,一个实体只能有一个主码,但可以有多个候选码。主码是最小的候选码,是根据业务需求来选取的 ,是数据库设计者认为最适合唯一标识表的属性或属性组合
  • 外码:也叫外键。如果一个关系中的一个属性是另一个关系的主键 ,则这个属性为外键。一个表只能有一个主键,可以有多个外键
  • 主属性:候选码中出现过的属性称为主属性
  • 非主属性:不包含在任何一个候选码中的属性称为非主属性

2、ER图

  • 提供了表示实体类型、属性和联系的方法
    • 实体:通常是现实世界的业务对象。用矩形框表示
    • 属性:某个实体拥有的属性。可以理解为字段。用椭圆形表示
    • 联系:实体与实体之间的的关系。可以通过数字表示实体之间的数量对照关系(1:1 、1:N 、M:N)

在这里插入图片描述

3、数据库范式

  • 1NF:属性(对应表中的字段)不可再分,也就是这个字段只能是一个值,不能再分为其他字段。是所有关系型数据库的最基本要求 。强调的是列的原子性,即数据库表的每一列都是不可分割的原子数据项

  • 2NF:1NF的基础上,消除了非主属性对于码的部分函数依赖:添加主键,非主属性依赖主键

将表拆分出来,每个表设单独的主键,非主属性依赖主键。要求所有实体的属性完全依赖于主关键字

  • 3NF:在2NF的基础之上,消除了非主属性对于码的传递函数依赖:消除传递函数依赖

传递函数依赖:在关系模式R(U)中,设 X、Y、Z是U的不同的属性子集,如果X确定Y、Y确定Z,则称Z传递函数依赖于X。传递函数会导致数据冗余和异常。任何非主属性不依赖于其他非主属性

4、为什么不推荐使用外键与级联?

在阿里巴巴开发手册中这样说到:

【强制】不得使用外键与级联,一切外键概念必须在应用层解决。

说明: 以学生和成绩的关系为例,学生表中的 student_id 是主键,那么成绩表中的 student_id 则为外键。如果更新学生表中的 student_id,同时触发成绩表中的student_id 更新,即为级联更新 。外键与级联更新适用于单机低并发,不适合分布式、高并发集群 ; 级联更新是强阻塞,存在数据库更新风暴的风 险; 外键影响数据库的插入速

为什么不使用外键?

  • 增加了复杂性:每次做修改操作(删除、更新)都必须考虑外键约束,会导致开发的时候很痛苦,测试数据极为不方便;外键的主从关系是固定的,假如需求有变化,数据库中的这个字段如果不需要和其他表有关联的话就会增加很多麻烦
  • 增加了额外工作:数据库需要增加维护外键的工作,当我们设计外键字段的修改操作,要出发相关操作去检查,保证数据的一致性和正确性
  • 对分库分表不友好:分库分表下外键是无法生效的

5、drop、delete与truncate区别?

1)用法不同

  • drop:drop table 表名 ,直接将表都删除掉,在删除表的时候使用
  • truncate:truncate table 表名 ,只删除表中的数据,再插入数据时自增长id又从1开始,在清空表中数据时使用
  • delete:delete from 表名 where 列名 = 值 ,删除某一行的数据,如果不加where子句和truncate table 表名 作用相同

2)属于不同数据库语言

  • truncate 和drop属于DDL(数据定义语言)语句,操作立即生效,原数据不放到rollback segment中,不能回滚。而delete是DML(数据库操作语言)语句,会放到rollback segment中,事务提交后才生效

3)执行速度不同

一般来说 drop>truncate >delete

6、数据库设计通常分为?

  • 需求分析:分析用户的需求,包括数据、功能和性能需求
  • 概念结构设计:主要采用E-R模型进行设计,包括画E-R图
  • 逻辑结构设计:通过将E-R图转换成表,实现从E-R模型到关系模型的转换
  • 物理结构设计:主要是为所设计的数据库选择合适的存储结构和存储路径
  • 数据库实施:包括编程、测试和试运行
  • 数据库的运行和维护:系统的运行与数据库的日常维护

二、NoSQL基础

1、NoSQL是什么?

Not Only SQL 。泛指非关系型数据库,主要针对的是键值、文档以及图形类型数据存储 。并且,NoSQL数据库天生支持分布式,数据冗余和数据分片等特性,旨在提供可扩展的高可用高性能数据存储解决方案

NoSQL数据库代表:HBase、Cassandra、MongoDB、Redis

2、SQL和NoSQL的区别

  • SQL数据库是结构化存储,具有固定行和列的表格;NoSQL数据库是非结构化存储,文档:JSON文档,键值:键值对,宽列:包含行和动态列的表 ,图:节点和边
  • SQL数据库提供ACID属性;NoSQL通常不支持ACID事务,为了可扩展、高性能进行了权衡,少部分支持比如MongoDB。
  • SQL数据库性能决定于磁盘子系统,要获得最佳性能,通常需要优化查询、索引和表结构;NoSQL性能通常由底层硬件集群大小、网络延迟以及调用应用程序来决定

2、NoSQL数据库有什么优势

  • 灵活性:NoSQL数据库通常提供灵活的架构,以实现更快速、更多的迭代开发 。灵活的数据模型使NoSQL数据库成为半结构化和非结构化数据的理想之选
  • 可扩展性:NoSQL数据库通常被设计为通过使用分布式硬件集群来横向扩展,而不是通过添加昂贵和强大的服务器来纵向扩展
  • 高性能:NoSQL数据库针对特定的数据模型和访问模型进行了优化 ,这与尝试使用关系数据库完成完成类似功能相比可实现更高的性能
  • 强大的功能:NoSQL数据库提供功能强大的API和数据类型 ,专门针对其各自的数据模型而构建

3、NoSQL数据库有哪些类型?

  • 键值:键值数据库是一种比较简单的数据库,其中每个项目都包含键和值。应用可以完全控制value字段中存储的内容,没有任何限制。代表的键值数据库:Redis和DynanoDB

  • 文档:文档数据库中的数据被存储在类似于JSON对象的文档中,非常清晰直观。每个文档包含成对的字段和值,这些值通常可以是各种类型。代表的文档数据库:MongoDB

  • 图形:轻松构建和运行与高度连接的数据集一起使用的应用程序。图形数据库的典型使用案例包括社交网络、推荐引擎、欺诈检测和知识图形。代表的图形数据库:Neo4j、Giraph

  • 宽列:宽列存储数据库非常适合需要存储大量的数据,代表的宽列数据库有 Cassandra、HBase

三、字符集

1、什么是字符集

字符集就是乙烯类字符的集合。字符集的种类较多,每个字符集可以表示的字符范围通常不同,比如说有些字符集是无法表示汉字的

计算机只能存储二进制的数据,对于英文、汉字、表情等字符需要转换为对应的二进制数据。我们将字符对应二进制数据的过程称为“字符编码”,反之二进制数据解析成字符的过程称为“字符解码”

2、常见的字符集

ASCII , GB2321 , GBK , UTF-8

Unicode&UTF-8

不同的字符集可以表示的字符范围以及编码规则存在差异,这就导致了使用错误的编码方式查看一个包含字符的文件就会产生乱码现象 。乱码的本质就是:编码和解码时用了不同或者不兼容的字符集。为了解决这个问题,Unicode诞生了。

Unicode字符集中包含了世界上几乎所有已知的字符,不过Unicode字符集并没有规定如何存储这些字符(使用二进制数据表示这些字符),于是就有了UTF-8 ,。

UTF-8使用1到4个字节为每个字符编码,可以根据不同的符号自动选择编码的长短。UTF-8是目前使用最广的一种字符编码。

3、MySQL字符编码集中有两套UTF-8编码实现:

  • utf8
  • utf8mb4

utf8mb4是UTF-8的完整实现 ,可以用来存储emoji符号。因此如果你需要存储emoji类型的数据或者一些比较复杂的文字、繁体字到MySQL数据库的话,数据库的编码一定要指定为utf8mb4而不是utf8,否则存储的时候就会报错了。

四、SQL语言基础

1、SQL语法要点

  • SQL语句不区分大小写
  • SQL语句以;结尾
  • 处理SQL语句时,所有空格都被忽略

2、SQL分类

  • DDL:数据定义语言。对数据库内部对象 进行创建、删除、修改的操作语言。更多的被数据库管理员使用

是SQL语言集中负责数据结构定义与数据库对象定义的语言

DDL的核心指令是 CREATE、ALTER、DROP

  • DML:数据库操纵语言,对数据库中表记录的操作。包括表记录的插入、更新、删除和查询,是开发人员日常使用最频繁的操作。只对表内部数据的操作,不涉及表结构等

主要功能是访问数据,其语法都是以读写数据库 为主

DML的核心指令是 INSERT、UPDATE、DELETE、SELECT

  • TCL:事务控制语言,用于管理数据库中的事务 。核心指令是:COMMIT、ROLLBACK

  • DCL:数据控制语言,是一种可对数据访问权进行控制的指令,DCL以控制用户的访问权限为主 ,可利用DCL控制的权限有:CONNECT、SELECT、INSERT、UPDATE、DELETE、EXECUTE、USAGE、REFERENCES

3、DML数据库操纵语言

DML语言的主要功能就是读写数据库实现增删改查

插入数据

字段名和值一一对应。可以插入一行也可以同时插入多行

-- INSERT INTO 表名([字段名1,字段名2,字段名3])values(`值1`,`值2`,`值3`) 插入一行
--INSERT INTO 表名(`字段名1`)values(`值1`),(`值2`),(`值3`)  插入多行
--插入一行
INSERT INTO student(name,pwd)VALUES('张三','123456');
--插入多行
INSERT INTO student(name,pwd)VALUES('张三','123456'),('张三','123456');
-- 插入完整行,可以忽略字段名
INSERT INTO student VALUES('张三','123456','aaaa');

更新数据

update user 
set username = 'root',password='root'
where username='root';

删除数据

delete from user
where username='root';

清空表中的数据

truncate table user;

查询

-- 查询单列
select prod_name from department;
--查询多列
select prod_name,prod_id from department;
--查询所有列
select * from department;--查询不同的值  用于返回唯一不同的值,作用于所有列,所有列的值都相同才算相同
select distinct ven_id from products;-- 限制查询结果,分页
select * from mytable limit 5 ; -- 返回前五行
select * from mytable limit 0,5;-- 返回前五行,第1~5行
select * from mytable limit 2,3; -- 从第三行开始,返回三条数据,第3~5行

排序

order by 用于对结果集按照一个列或者多个列进行排序。默认按照升序(ASC)对记录进行排序,如果需要按照降序对记录进行排序,可以使用desc关键字

-- 默认是升序。可以对多个列进行排列如下,不同列可以有不同的排序规则。按照先排序的列进行排序,相等再按后面的列的排序规则
select * from products
order by prod_price DESC,prod_name ASC -- 先按成绩降序,如果成绩一样,按名字排序

分组

-- 查询不同课程的  平均分、最高分、最低分
-- 分组为不同的课程SELECT `subjectname`,AVG(`studentresult`)AS 平均分,MAX(`studentresult`) AS 最高分 ,MIN(`studentresult`) AS 最低分
FROM result r
GROUP BY r.subjectno   -- 通过什么字段来分组
HAVING 平均分 >80    -- having:过滤条件

having和where:

  • where:过滤指定的行,后面不能加聚合函数(分组函数),where在group by 前面
  • having:过滤分组,一般都是和group by 连用 ,不能单独使用。having 在group by 之后

子查询

内部查询在其父查询之前执行,以便可以将内部查询的结果传递给外部查询。

-- 查询数据库结构的所有考试结果(学号,科目编号,成绩),降序排列
SELECT `studentno`,`subjectno`,`studentresult`
FROM `result`
WHERE subjectno =(
SELECT subjectno FROM `subject`
WHERE subjectname = '数据库结构'
)
ORDER BY studentresult DESC-- 分数不小于80分的学生的学号和姓名
SELECT `studentno`,`studentname`
FROM `student`
WHERE `studentno`=ANY (
SELECT `studentno`FROM `result`
WHERE `studentresult`>80
)
ORDER BY `studentno`DESC-- 子查询的子查询
SELECT cust_name, cust_contact
FROM customers
WHERE cust_id IN (SELECT cust_idFROM ordersWHERE order_num IN (SELECT order_numFROM orderitemsWHERE prod_id = 'RGAN01'));

IN 和 BETWEEN

  • IN操作符在WHERE子句中使用,作用是在指定的几个特定值中任选一个值
  • Between 操作符在WHERE子句中使用,作用是选区介于某个范围内的值
-- IN
SELECT *
FROM products
WHERE vend_id IN ('DLL01', 'BRS01');-- BETWEEN ,between一般和and连用,在某个区间范围内
SELECT *
FROM products
WHERE prod_price BETWEEN 3 AND 5;

模糊查询

LIKE操作符在WHERE子句中使用,作用是确定字符串是够匹配模式

只有字段是文本值时才使用LIKE

LIKE支持两个通配符匹配选项:% 和 _

不要滥用通配符,通配符位于开头处匹配会非常慢

% 表示任何字符出现任意次数

_表示任何字符出现一次

-- 从商品中查找名称为%bean bag%的商品id、商品名、商品价格
SELECT prod_id, prod_name, prod_price
FROM products
WHERE prod_name LIKE '%bean bag%';

联表查询

join

-- 从table1中查找table1.common_column1 = table2.common_column2的table1的cplumn1和table2的column2
select table1.column1, table2.column2...
from table1
join table2
on table1.common_column1 = table2.common_column2;

连接表时需要在每个表中选择一个字段,并对这些字段的值进行比较,值相同的两条记录将合并为一条。连接表的本质就是将不同表的记录合并起来,形成一张新表。当然,这张新表只是临时的,它仅存在于本次查询期间

当两个表中有同名的字段时,为了帮助数据库引擎区分是哪个表的字段,在书写同名字段名时需要加上表名,当然,如果书写的字段名在两个表中是唯一的,则不用写表名;

如果两张表的关联字段名相同,也可以使用USING子句来代替ON

-- join....on
select c.cust_name, o.order_num
from Customers c
inner join Orders o
on c.cust_id = o.cust_id
order by c.cust_name;-- 如果两张表的关联字段名相同,也可以使用USING子句:join....using()
select c.cust_name, o.order_num
from Customers c
inner join Orders o
using(cust_id)
order by c.cust_name;
  • inner join: (默认连接方式)只有当两个表都存在满足条件的记录时才会返回行。

    满足s.studentno=r.studentno这个条件的行,才返回

  • left join:返回左表中的所有行,即使右表中没有满足条件的行也是如此。

先把左表的行全部抄下来,然后看右表有没有匹配条件的行 ,有的话就把字段合并,没有就不合并。

  • right join:从右表中返回所有的值,即使左表中没有匹配(右表全集) 返回右表全集加交集

先把右表的行全部抄下来,然后看左表有没有匹配条件的行 ,有的话就把字段合并,没有就不合并。

-- inner join  
SELECT studentname,s.studentno,subjectno,studentresult 
FROM student AS s INNER JOIN result AS r
ON s.studentno=r.studentno-- right join
SELECT studentname,s.studentno,subjectno,studentresult 
FROM student AS s RIGHT JOIN result AS r
ON s.studentno=r.studentno-- left join
SELECT studentname,s.studentno,subjectno,studentresult 
FROM student AS s LEFT JOIN result AS r
ON s.studentno=r.studentno

组合

union运算符将两个或更多查询的结果组合起来,并生成一个结果集 ,其中包含来自union中参与查询的提取行。

基本规则:

  • 所有查询的列数和列顺序必须相同
  • 每个查询中涉及表的列的数据类型必须相同或兼容
  • 通常返回的列名取自第一个查询
-- 如果允许重复的值,请使用 UNION ALL。SELECT column_name(s) FROM table1
UNION ALL
SELECT column_name(s) FROM table2;

函数

  • 文本处理

LEFT() / RIGHT() :左边或者右边的字符

LOWER() / UPPER() :转换为小写或者大写

LTRIM() / RTRIM() : 去除左边或者右边的空格

LENGTH() : 长度,以字节为单位

SOUNDEX() : 转换为语音值

  • 汇总

AVG() : 返回某列的平均值

COUNT() : 返回某列的行数

MAX() : 返回某列的最大值

MIN() : 返回某列的最小值

SUM():返回某列值之和

使用DISTINCT(唯一)可以让汇总函数值汇总不同的值

SELECT AVG(DISTINCT col1) AS avg_col
FROM mytable

汇总col1字段中不同的值的和

4、DDL数据定义语言

DDL的主要功能是定义数据库对象(如:数据库、数据表、视图、索引等)

  • 对于数据库
create database test;
drop database test;
use test;
  • 对于数据表
-- 普通创建
CREATE TABLE user (id int(10) unsigned NOT NULL COMMENT 'Id',username varchar(64) NOT NULL DEFAULT 'default' COMMENT '用户名',password varchar(64) NOT NULL DEFAULT 'default' COMMENT '密码',email varchar(64) NOT NULL DEFAULT 'default' COMMENT '邮箱'
) COMMENT='用户表';-- 根据已有的表创建新表
create table vip_user as select * from user;-- 删除数据表
drop table user;-- 添加列
alter table user add age int (3);-- 删除列
alter table user drop column age;-- 添加主键
alter table user add primary key (id);-- 删除主键
alter table user drop primary key;
  • 视图

定义:

视图是基于SQL语句的结果集的可视化的表

视图是虚拟的表,本身不包含数据,也就不能对其进行索引操作。对视图的操作和对普通标的操作一样

作用:

简化复杂的SQL操作,比如复杂的联结;

只使用实际表的一部分数据;

通过只给用户访问视图的权限,保证数据的安全性;

更改数据格式和表示

创建视图

CREATE VIEW top_10_user_view AS
SELECT id, username
FROM user
WHERE id < 10;

删除视图

DROP VIEW top_10_user_view;
  • 索引

索引是一种用于快速查询和检索数据的数据结构,其本质可以看成是一种排序好的数据结构。索引的作用就相当于书的目录

优点:

使用索引可以大大加快数据的检索速度(大大减少检索的数据量),这也是创建索引的最主要的原因

通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性

缺点:

创建索引和维护索引需要耗费许多时间,但对表中的数据进行增删改的时候,如果有数据有索引,那么索引也需要动态的修改,会降低SQL执行效率

索引需要物理文件存储,也会耗费一定空间

创建索引:在数据库中执行一个操作,在表中建立索引

CREATE INDEX user_index
ON user(id);

添加索引:在已存在的表中增加新的索引

ALTER table user ADD INDEX user_index(id);

创建唯一索引

CREATE UNIQUE INDEX user_index
ON user (id);

删除索引

ALTER TABLE user
DROP INDEX user_index;
  • 约束

SQL约束用于规定表中的数据规则,如果存在违反约束的数据行为,行为会被约束终止。

约束可以在创建表时规定(通过 CREATE TABLE语句),或者在表创建之后规定(通过 ALTER TABLE语句)

约束类型:

NOT NULL :指示某列不能存储NULL值

UNIQUE:保证某列的某行必须由唯一的值

PRIMARY KEY:确保某列有唯一标识,主键

CHECK:保证列中的值符合指定的条件

DEFAULT:规定没有给列赋值时的默认值

创建表时使用约束条件:

CREATE TABLE Users (Id INT(10) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '自增Id',Username VARCHAR(64) NOT NULL UNIQUE DEFAULT 'default' COMMENT '用户名',Password VARCHAR(64) NOT NULL DEFAULT 'default' COMMENT '密码',Email VARCHAR(64) NOT NULL DEFAULT 'default' COMMENT '邮箱地址',Enabled TINYINT(4) DEFAULT NULL COMMENT '是否有效',PRIMARY KEY (Id)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COMMENT='用户表';

5、TCL事务处理

TCL的主要功能是管理数据库中的事务

  • 不能回退select语句,回退select语句也没意义;也不能回退create和drop语句
  • MySQL默认是隐式提交,每执行一条语句就把这条语句当成一个事务然后进行提交。
  • 当出现 START TRANSACTION 语句时,会关闭隐式提交;当 COMMIT 或 ROLLBACK 语句执行后,事务会自动关闭,重新恢复隐式提交。
  • 通过 set autocommit = 0 可以取消自动提交,直到set autocommit=1 才会提交。autocommit标记是针对每个连接而不是针对服务器
-- 开始事务
START TRANSACTION;-- 插入操作 A
INSERT INTO `user`
VALUES (1, 'root1', 'root1', 'xxxx@163.com');-- 创建保留点 updateA
SAVEPOINT updateA;-- 插入操作 B
INSERT INTO `user`
VALUES (2, 'root2', 'root2', 'xxxx@163.com');-- 回滚到保留点 updateA
ROLLBACK TO updateA;-- 提交事务,只有操作 A 生效.回滚到了保留点A,所以后面B的插入操作不会被执行
COMMIT;

6、权限控制 DCL

DCL的主要功能是控制用户的访问权限

要授予用户账户权限,可以用GRANT命令;要撤销用户的权限,可以用REVOKE命令。

GRANT privilege,[privilege],.. ON privilege_level
TO user [IDENTIFIED BY password]
[REQUIRE tsl_option]
[WITH [GRANT_OPTION | resource_option]];
  • 在GRANT关键字后指定一个或多个权限,如果授予用户多个权限,则每个权限由逗号分隔
  • ON privilege_level 确定权限应用级别。MySQL支持global(* .*) , database,table和列级别
  • user 是要授予权限的用户

使用示例:

-- 创建账户
CREATE USER myuser IDENTIFIED BY 'mypassword';-- 修改账户名
UPDATE user SET user='newuser' WHERE user='myuser';
FLUSH PRIVILEGES;-- 删除账户
DROP USER myuser;-- 查看权限
SHOW GRANTS FOR myuser;-- 授予权限
GRANT SELECT, INSERT ON *.* TO myuser;-- 删除权限
REVOKE SELECT, INSERT ON *.* FROM myuser;-- 更改密码
SET PASSWORD FOR myuser = 'mypass';

7、存储过程

  • 存储过程可以看成是对一系列SQL操作的批处理。存储过程可以由触发器,其他存储过程以及Java等应用程序调用

  • 使用存储过程的好处

代码封装:保证了一定的安全性;

代码复用;

由于是预先编译,因此具有很高的性能

  • 创建存储过程:

命令行中创建存储过程需要自定义分隔符

包含in 、out 、 inout 三种参数

给变量赋值都需要用select into 语句

每次只能给一个变量赋值,不支持集合的操作

  • 阿里巴巴Java开发手册中强制禁止使用存储过程。因为存储过程难以调试和扩展,更没有移植性。
-- 创建存储过程
DROP PROCEDURE IF EXISTS `proc_adder`;
DELIMITER ;;
CREATE DEFINER=`root`@`localhost` PROCEDURE `proc_adder`(IN a int, IN b int, OUT sum int)
BEGINDECLARE c int;if a is null then set a = 0;end if;if b is null then set b = 0;end if;set sum  = a + b;
END
;;
DELIMITER ;-- 使用存储过程
set @b=5;
call proc_adder(2,@b,@s);
select @s as sum;

8、触发器

触发器是一种与表操作有关的数据库对象,当触发器所在表上出现指定事件时,将调用该对象,即表的操作事件触发表上的触发器的执行

使用触发器的优点

SQL触发器提供了另一种检查数据完整性的方法;

SQL触发器可以捕获数据库层中业务逻辑中的错误;

SQL触发器提供了另一种执行计划任务的方法。通过使用SQL触发器,不必等待运行计划任务,因为在对表中的数据进行更改之前或之后会自动调用触发器;

SQL触发器对于审计表中数据的更改非常有用

使用触发器的缺点

SQL触发器只能提供扩展验证,并且不能替换所有验证。必须在应用程序层中完成一些简单的验证;

从客户端应用程序调用和执行SQL触发器是不可见的,因此很难弄清楚数据库层中发生了什么

SQL触发器可能会增加数据库服务器的开销

创建触发器

CREATE TRIGGER trigger_name
trigger_time
trigger_event
ON table_name
FOR EACH ROW
BEGINtrigger_statements
END;

当触发器的触发条件满足时,将会执行BEGIN和END之间的触发器执行动作

查看触发器

SHOW TRIGGERS;

删除触发器

DROP TRIGGER IF EXISTS trigger_insert_user;

相关文章:

一、数据库基础

数据库 一、数据库基础 1、一些概念 数据库&#xff1a;数据库&#xff08;DataBase &#xff0c;简称DB&#xff09;&#xff0c;就是信息的集合。数据库是由数据库管理系统管理的数据的集合&#xff1b;数据库管理系统&#xff1a;简称DBMS 。是一种操纵和管理数据库的大型…...

Harmony OS教程学习笔记

基础知识 1.如何修改程序启动的第一个页面&#xff1f; 不想使用创建的默认的页面&#xff0c;这时需要修改启动页面&#xff0c;修改的地方在EntryAbility文件中的onWindowStageCreate方法中。 onWindowStageCreate(windowStage: window.WindowStage) {// Main window is cr…...

605. 种花问题

链接 假设有一个很长的花坛&#xff0c;一部分地块种植了花&#xff0c;另一部分却没有。可是&#xff0c;花不能种植在相邻的地块上&#xff0c;它们会争夺水源&#xff0c;两者都会死去。给你一个整数数组 flowerbed 表示花坛&#xff0c;由若干 0 和 1 组成&#xff0c;其中…...

Elasticsearch 常见的简单查询

查看es中有哪些索引 请求方式&#xff1a;GET 请求地址&#xff1a;http://localhost:9200 /_cat/indices?v 参数&#xff1a;无 结果&#xff1a; 查看索引全部数据 请求方式&#xff1a;GET 请求地址&#xff1a;http://localhost:9200/index-2023-08/_search 参数&a…...

C#使用xamarin进行跨平台开发

使用 Xamarin 进行跨平台开发可以使用 C# 和 .NET 平台来开发移动应用程序&#xff0c;同时将代码在多个主要移动操作系统上运行&#xff0c;包括 Android 和 iOS。以下是在 C# 中使用 Xamarin 进行跨平台开发的一般步骤&#xff1a; 安装 Xamarin&#xff1a; 在开始之前&…...

xargs 的用法 在1个文件夹中批量删除文件,这些删除的文件名是另一个文件夹中的文件名。

xargs 的用法 在1个文件夹中批量删除文件&#xff0c;这些删除的文件名是另一个文件夹中的文件名。 1、问题背景 应用场景 1、问题背景 应用场景 在二进制部署docker时&#xff0c;会把docker的所有可执行文件复制到/usr/bin下。 如果说复制过去后&#xff0c;想要反悔&#x…...

集简云本周新增/更新:新增2大功能,集成2款应用,更新4款应用,新增近20个动作

本周更新概要 新增功能 新增功能&#xff1a;Claude2 新增功能&#xff1a;语聚AI对话助手对话背景设定 应用新增 新增应用&#xff1a;领星ERP 新增应用&#xff1a;slack(自建) 应用更新 更新应用&#xff1a;企业微信(代开发) 更新应用&#xff1a;阿里云效2020(新版…...

MySQL存储过程怎么写?看完这篇秒懂

今天测试一个数据展示模块&#xff0c;依赖于数据部推送数据&#xff0c;但是他们没有人员配合&#xff0c;为了赶工&#xff0c;于是自己徒手造数据&#xff0c;有些页面&#xff0c;要查看翻页和权限等相关的功能&#xff0c;手动造是不可能的&#xff0c;因为我懒....哈哈哈…...

STM32电源名词解释

STM32电源架构 常用名词 VCC Ccircuit 表示电路&#xff0c;即接入电路的电压。 VDD Ddevice 表示器件&#xff0c; 即器件内部的工作电压。 VSS Sseries 表示公共连接&#xff0c;通常指电路公共接地端电压。 VDDA Aanalog 表示模拟&#xff0c;是模拟电路部分的电源。主要为…...

《操作系统真象还原》学习笔记:第七章 中断

由于 CPU 获知了计算机中发生的某些事&#xff0c;CPU 暂停正在执行的程序&#xff0c;转而去执行处理该事件的程序&#xff0c;当这段程序执行完毕后&#xff0c;CPU 继续执行刚才的程序。整个过程称为中断处理&#xff0c;也称为中断。 把中断按事件来源分类&#xff0c;来自…...

【学习笔记之vue】These dependencies were not found:

These dependencies were not found:方案一 全部安装一遍 我们先浅试一个axios >> npm install axios 安装完报错就没有axios了&#xff0c;验证咱们的想法没有问题&#xff0c;实行&#xff01; ok...

【数据结构】实现栈和队列

目录 一、栈1.栈的概念及结构&#xff08;1&#xff09;栈的概念&#xff08;2&#xff09;栈的结构 2.栈的实现&#xff08;1&#xff09;类型和函数的声明&#xff08;2&#xff09;初始化栈&#xff08;3&#xff09;销毁&#xff08;4&#xff09;入栈&#xff08;5&#x…...

APT60DQ20BG-ASEMI新能源功率器件APT60DQ20BG

编辑&#xff1a;ll APT60DQ20BG-ASEMI新能源功率器件APT60DQ20BG 型号&#xff1a;APT60DQ20BG 品牌&#xff1a;ASEMI 封装&#xff1a;TO-3P 恢复时间&#xff1a;&#xff1e;50ns 正向电流&#xff1a;60A 反向耐压&#xff1a;200V 芯片个数&#xff1a;2 引脚数…...

[Android Framework] 系统 ANR 问题排查实践小结

文章目录 背景卡顿的定义:卡顿分类:卡顿原因汇总ANR 出现的原理应用层导致ANR系统导致ANR日志抓取traces.txt 是如何生成的分析思路与验证相关日志分析data/anr/traces.txt其他分析思路如何分析生成的 trace.html 文件呢?最后解决参考:背景 本文记录了工作中遇到的Andorid …...

【Unity】Text文本组件的一些操作

Unity的Text组件的几种常见的操作方法 Text组件是Unity中用于在UI界面上显示文本的组件。它包含了一些常见的属性和方法&#xff0c;可以用来控制文本的内容、外观和交互。以下是一些常见的Text组件的操作&#xff1a; 设置文本内容&#xff1a;通过直接在Unity编辑器中的Text…...

如何通过tomcat下载映射下载文件

1.1找到tomcat服务器中server.xml文件 !--doBase是静态资源路径位置&#xff0c; path作用相当于设置的key, doBase作用相当于value --> <Context path"/download" docBase"E:\testBackData"></Context>1.2 找到tomcat服务器中web.xml文…...

Redis的8种数据结构和应用场景介绍,面试题答案

面试原题&#xff1a;你用过Redis哪些数据结构&#xff1f;&#xff08;网易一面 2023&#xff09;(面试题来自牛客网) 参考答案 后面有 详细答案解析&#xff0c;帮助更快记忆~ 参考答案共652字符&#xff0c;阅读约需1分8秒&#xff1b;全文共8694字符&#xff0c;阅读约需…...

Log4Qt日志框架(1)- 引入到QT中

Log4Qt日志框架&#xff08;1&#xff09;- 引入到QT中 1 下载源码2 简介3 加入到自己的项目中3.1 使用库文件3.2 引入源文件 4 说明 1 下载源码 github&#xff1a;https://github.com/MEONMedical/Log4Qt 官方(版本较老)&#xff1a;https://sourceforge.net/projects/log4q…...

【算法刷题之哈希表篇(1)】

目录 1.哈希表基础理论2.leetcode-242. 有效的字母异位词&#xff08;1&#xff09;方法一&#xff1a;排序&#xff08;2&#xff09;方法二&#xff1a;哈希表 3.leetcode-349. 两个数组的交集&#xff08;1&#xff09;方法一&#xff1a;哈希表&#xff08;2&#xff09;方…...

uni-app 打包生成签名Sha1

Android平台打包发布apk应用&#xff0c;需要使用数字证书&#xff08;.keystore文件&#xff09;进行签名&#xff0c;用于表明开发者身份。 可以使用JRE环境中的keytool命令生成。以下是windows平台生成证书的方法&#xff1a; 安装JRE环境&#xff08;推荐使用JRE8环境&am…...

【Django】Django创建一个文件下载服务

当使用Django创建一个下载服务时&#xff0c;您可以设置一个视图来处理文件下载请求&#xff0c;并根据您的需求提供文件下载链接。以下是一个简单的示例&#xff0c;演示如何在Django中实现基本的文件下载服务&#xff1a; 创建Django项目和应用&#xff1a; 首先&#xff0c…...

Navicat for Mysql 显示 emoji 表情符号乱码问题 — 其它乱码情况都可参考

系统环境&#xff1a; 操作系统&#xff1a;MAC OS 10.11.6 MySQL&#xff1a;Server version: 5.6.21 MySQL Community Server (GPL) Navicat for MySQL: version 9.3.1 - standard 1、问题发现 在客户端执行用户注册&#xff0c;用户名包括 emoji 表情符号&#xff0c;注册完…...

《数字图像处理-OpenCV/Python》连载(2)目录

《数字图像处理-OpenCV/Python》连载&#xff08;2&#xff09;目录 本书京东优惠购书链接&#xff1a;https://item.jd.com/14098452.html 本书CSDN独家连载专栏&#xff1a;https://blog.csdn.net/youcans/category_12418787.html 第一部分 OpenCV-Python的基本操作 第1章 …...

Go学习-Day4

文章目录 Go学习-Day4函数值传递&#xff0c;引用传递常用的函数 异常处理数组Slice切片 Go学习-Day4 个人博客&#xff1a;CSDN博客 函数 值传递&#xff0c;引用传递 值传递直接拷贝值&#xff0c;一般是基本数据类型&#xff0c;数组&#xff0c;结构体也是引用传递传递…...

将el-dialog封装成函数调用

1、 使用Vue实例化方法 // MyDialog.js import Vue from vue export const openFormDialog function ({ props {}, events {} }) {const vm new Vue({data () {return {form: {}}},render () {return (<el-dialogvisible{true}{...{ props }}{...{ on: events }}onClos…...

Windows10批处理命令行设置环境变量笔记,无需重新安装python与chrome

近期&#xff0c;工作中经常安装、部署python生产、开发环境&#xff0c;比较麻烦&#xff0c;也没有心情去优化。突然&#xff0c;我的电脑崩溃了&#xff0c;在重新安装电脑的过程中&#xff0c;保留了原来的安装软件&#xff08;有的没有放在系统盘中&#xff09;&#xff0…...

统计学补充概念07-比较树

概念 在层次聚类中&#xff0c;聚类结果可以以树状结构表示&#xff0c;通常称为树状图&#xff08;Dendrogram&#xff09;。树状图展示了数据点如何被合并或分裂以形成聚类的层次结构。通过观察树状图&#xff0c;可以更直观地理解数据点之间的相似性和关系。 在比较树状图…...

设计原则 --《设计模式之美》总结篇

本文是阅读《设计模式之美》的总结和心得&#xff0c;跳过了书中对面试和工作用处不大或不多的知识点&#xff0c;总结总共分为三章&#xff0c;分别是面对对象编程范式、设计原则和设计模式。 设计模式是代码设计时的一些经验总结。相比于设计模式&#xff0c;设计原则更抽象。…...

Day16-蜗牛影城后端开发

蜗牛影城后端开发 一 多表关联查询 电影集合movie的type(类别)字段关联到电影类别movieType表的_id(主键) 二 蜗牛影城后端开发 1 数据的导入导出 2 用户模块 UserModel.js //导入mongoose,并解构出Schema(类)和model(对象) const {Schema,model} =...

axios / fetch 实现 stream 流式请求

axios 是一个支持node端和浏览器端的易用、简洁且高效的http库。本文主要介绍 axios 如何实现 stream 流式请求&#xff0c;注意这里需要区分 node 环境和浏览器环境。 一、node端 代码演示&#xff1a; const axios require(axios);axios({method: get,url: http://tiven.c…...

Pytorch学习:torchvison.transforms常用包(ToTensor、Resize、Compose和RandomCrop)

torchvision.transforms常用包 1. torchvision.transforms.ToTensor2. torchvision.transforms.Resize3. torchvision.transforms.Compose4. torchvision.transforms.Normalize5. torchvision.transforms.RandomCrop 1. torchvision.transforms.ToTensor 将PIL Image或ndarray…...

算法通关村十二关 | 字符串转换

1. 转换小写字母 LeetCode709&#xff1a;给你一个字符串s&#xff0c;将该字符串中的大写字母转换成相同的小写字母&#xff0c;返回新的字符串。 每个字母都是有确定的ASCII的&#xff0c;可以根据码表操作子字符串&#xff0c;常见的ASCII范围是&#xff1a; a-z: 97-122, …...

前端进阶Html+css09----BFC模型

1.什么是BFC模型 全称是&#xff1a;Block formatting context&#xff08;块级格式化上下文&#xff09;&#xff0c;是一个独立的布局环境&#xff0c;不受外界的影响。 2.FC,BFC,IFC 元素在标准流里都属于一个FC&#xff08;Formatting Context&#xff09;。 块级元素的布…...

重排链表(C语言)

题目&#xff1a; 示例&#xff1a; 思路&#xff1a; 这题我们将使用栈解决这个问题&#xff0c;利用栈先进后出的特点&#xff0c;从链表的中间位置进行入栈&#xff0c;寻找链表的中间位置参考&#xff1a;删除链表的中间节点&#xff0c;之后从头开始进行连接。 本题使用…...

el-table动态合并单元格

el-table使用这个方法合并单元格&#xff0c;:span-method“hbcell” <el-table size"small" :data"table.data" border empty-text"暂无数据" :cell-style"cellStyle" :header-cell-style"tableHeaderColor":span-meth…...

html元素

文章目录 html基本结构属性语义化为什么要语义化 示例head中属性样式一些概念块级元素与行级元素空白折叠 html编程没有css的html显示逻辑 html基本结构 html基本单元就是元素&#xff0c;每个元素有标记和属性&#xff0c;如&#xff1a; <a href"...">www&…...

push github

一、生成密钥 打开git bash执行下面指令&#xff0c;Enter下一步Enter下一步..生成ssh key 密钥&#xff1b; ssh-keygen -t rsa 二、 复制公共密钥到git hub 登录github&#xff0c;在选项setting >> SSH and GPG key >> add new ssh添加刚才的公钥地址即可 验证…...

iFluor 594 Styramide是一种荧光染料,常用于生物分子标记和成像

试剂 | 基础知识概述&#xff08;部分&#xff09;: 中文名称&#xff1a;Alexa Fluor 594酪Styramide 分子量&#xff1a;1341.71 胺的优异替代品 100 Slides 英文名称&#xff1a;iFluor 594 Ex (nm)&#xff1a;588 Em (nm)&#xff1a;604 规格标准&#xff1a;1g&am…...

动态规划入门之01背包变形嗑药

P1802 5 倍经验日 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 嗑药固然可耻&#xff0c;但是能让你快速变强 --鲁迅 手动滑稽&#xff0c;话归正题 动态规划之背包入门01背包模板_爱莉我老婆的博客-CSDN博客 这是01背包的模板&#xff0c;没看的可以去看看。 我们把…...

数据结构——栈和队列OJ题

栈和队列小提升&#xff01; 前言一、用队列实现栈队列接口实现&#xff08;1&#xff09;栈的接口定义&#xff08;2&#xff09;栈的初始化&#xff08;3&#xff09;入栈函数的定义&#xff08;4&#xff09;出栈函数的定义&#xff08;5&#xff09;查找栈顶元素&#xff0…...

同态排序算法

参考文献&#xff1a; [Batcher68] Batcher K E. Sorting networks and their applications[C]//Proceedings of the April 30–May 2, 1968, spring joint computer conference. 1968: 307-314. [SV11] Smart, N.P., Vercauteren, F.: Fully homomorphic SIMD operations. IA…...

“深入探索JVM内部机制:解析Java虚拟机的工作原理“

标题&#xff1a;深入探索JVM内部机制&#xff1a;解析Java虚拟机的工作原理 摘要&#xff1a;本文将介绍Java虚拟机&#xff08;JVM&#xff09;的工作原理&#xff0c;包括类加载、内存管理、垃圾回收和字节码执行等方面。通过深入理解JVM的内部机制&#xff0c;开发人员可以…...

为应用程序接入阿里云CDN优化网站访问速度

文章目录 1.KodCloud云盘系统接入CDN之前的效果2.配置KodCloud云盘接入CDN加速器2.1.添加CDN域名2.2.配置域名信息2.3.CDN推荐配置设置2.4.CDN加速器配置完成 3.配置云解析DNS增加CDN域名的解析4.为CDN加速器配置HTTPS5.验证网站是否接入CDN6.访问应用程序观察请求速度7.观察CD…...

索引设计规范

索引是帮助数据库高效获取数据的数据结构。索引是加速查询的常用技术手段。在设计索引时&#xff0c;要遵循索引设计规范&#xff0c;避免不必要的踩坑。 【推荐】索引存储结构推荐BTREE InnoDB和MyISAM存储引擎表&#xff0c;索引类型必须为BTRER&#xff0c;MEMORY表可以根…...

Appium 2安装与使用java对Android进行自动化测试

文章目录 1、Appium 2.1安装1.1、系统要求1.2、安装Appium2.1服务1.3、安装UiAutomator2驱动1.4、安装Android SDK platform tools1.5、下载OpenJDK 2、Android自动代码例子2.1、安装Android自动化测试元素定位工具Appium Inspector2.2、编写android app自动化测试代码和使用ex…...

小程序运营方式有哪些?如何构建小程序运营框架?

​如今&#xff0c;每个企业基本都做过至少一个小程序&#xff0c;但由于小程序本身不具备流量、也很少有自然流量&#xff0c;因此并不是每个企业都懂如何运营小程序。想了解小程序运营方式方法有哪些&#xff1f; 在正式运营小程序前&#xff0c;了解小程序的功能与企业实际经…...

【golang】for语句和switch语句

使用携带range子句的for语句时需要注意哪些细节&#xff1f; numbers1 : []int{1, 2, 3, 4, 5, 6} for i : range numbers1 {if i 3 {numbers1[i] | i} } fmt.Println(numbers1)这段代码执行后会打印出什么内容&#xff1f; 答案&#xff1a;[1 2 3 7 5 6] 当for语句被执行…...

三、数据库索引

1、索引介绍 索引是一种用于快速查询和检索数据的数据结构&#xff0c;其本质可以看成是一种排序好的数据结构。 常见的索引结构有&#xff1a;B数&#xff0c;B树&#xff0c;Hash和红黑树等。在MySQL中&#xff0c;无论是 InnoDB还是MyISAM&#xff0c;都使用了B树作为索引…...

长时间带什么耳机最舒服,分享长时间佩戴舒服的耳机推荐

时代在进步&#xff0c;科技在不断革新。近年来&#xff0c;一种崭新的耳机——骨传导耳机&#xff0c;如火如荼地进驻耳机市场&#xff0c;引起一阵热潮。不论是平日里的工作出勤还是运动时的挥洒汗水&#xff0c;相比传统耳机&#xff0c;骨传导耳机无疑更加贴合现代生活的需…...

Yolov8小目标检测(1)

💡💡💡本文目标:通过原始基于yolov8的红外弱小目标检测,训练得到初版模型,进行问题点分析; 💡💡💡Yolo小目标检测,独家首发创新(原创),适用于Yolov5、Yolov7、Yolov8等各个Yolo系列,专栏文章提供每一步步骤和源码,带你轻松实现小目标检测涨点 💡💡…...