MySQL(4)运算符 | 关联查询详解

2023-05-16

一、MySQL 的运算符

(1)算术运算符:+ - * /(除也可以写成 div) %(取模可以写成 mod)
(2)比较运算符:= > >= < <= !=(不等于还可以写成<>) <=>(安全等于)
(3)逻辑运算符:&&(逻辑与也可以写成 and) ||(逻辑或也可以写成 or) not(逻辑非)
(4)范围:表达式 between … and … (也可以写成 表达式>=… and 表达式 <=…)
表达式 not between … and …(也可以写成 表达式<… || 表达式 >…)
(5)集合:in (值,值,值…) not in(值,值,值…)
(6)模糊查询:LIKE NOT LIKE,通配符:%表示 0-n 个字符,_下划线代表一个字符
(7)位运算符:&(按位与) |(按位或)^(按位异或)~(按位取反)>>(右移)<<(左移)
(8)NULL 值判断,is null 或 is not null,如果使用 null=null,null<>null,null=0,null<>0,null=false 等都不对。
不过 xxx is null 可以使用 xxx <=> null ,xxx is not null 可以写成 not xxx <=> null
结论:所有的运算符遇到 NULL 结果都是 NULL,除了<=>

1 、算术运算符

+,-,*,/(div),%(mod)

#筛选出 eid 是偶数的员工
SELECT * FROM t_employee WHERE eid % 2 = 0;
SELECT * FROM t_employee WHERE eid MOD 2 = 0;

#查看每天的基本工资值,每个月按 22 天算
SELECT eid,basic_salary/12 AS "日薪" FROM t_salary;

#div 也表示除,但是只保留整数部分
SELECT eid,basic_salary DIV 12 AS "日薪" FROM t_salary;

#关于+,在 Java 中,+的左右两边如果有字符串,那么表示字符串的拼接,但是在 MySQL 中+只表示数值相加,
#如果遇到非数值类型,先尝试转成数值,如果转失败,就按 0 计算
SELECT eid+ename FROM t_employee;
SELECT eid+birthday FROM t_employee;

#MySQL 中字符串拼接要使用字符串函数实现
SELECT CONCAT(eid,":",ename) AS result FROM t_employee;

2 、比较运算符

=>, <>=, <=!=(不等于<>)<=>(安全等于)

#查询 basic_salary!=10000
SELECT eid,basic_salary FROM t_salary WHERE basic_salary != 10000;
SELECT eid,basic_salary FROM t_salary WHERE basic_salary <> 10000;
#查询 basic_salary=10000,注意在 Java 中比较是==
SELECT eid,basic_salary FROM t_salary WHERE basic_salary = 10000;
#查询 commission_pct 等于 0.40
SELECT eid,commission_pct FROM t_salary WHERE commission_pct = 0.40;
SELECT eid,commission_pct FROM t_salary WHERE commission_pct <=> 0.40;
#查询 commission_pct 等于 NULL
SELECT eid,commission_pct FROM t_salary WHERE commission_pct IS NULL;
SELECT eid,commission_pct FROM t_salary WHERE commission_pct <=> NULL;
#查询 commission_pct 不等于 NULL
SELECT eid,commission_pct FROM t_salary WHERE commission_pct IS NOT NULL;
SELECT eid,commission_pct FROM t_salary WHERE NOT commission_pct <=> NULL;

3 、逻辑运算符

&&,或||,非!AND,或 OR ,非 NOT,异或 XOR

#查询性别男,并且在 90 以前出生的员工
SELECT * FROM t_employee WHERE gender='男' AND birthday<'1990-01-01';

#查询职位编号 job_id 是 1 或 2 的员工
SELECT * FROM t_employee WHERE job_id =1 OR job_id = 2;

#查询基本薪资是在 9000-12000 之间的员工编号和基本薪资
SELECT eid,basic_salary FROM t_salary WHERE basic_salary >=9000 AND basic_salary<=12000;

#查询基本薪资不在 9000-12000 之间的员工编号和基本薪资
SELECT eid,basic_salary FROM t_salary WHERE NOT (basic_salary >=9000 AND basic_salary<=12000);
SELECT eid,basic_salary FROM t_salary WHERE basic_salary <9000 OR basic_salary>12000;

4 、范围和集合

between ... and ...not between ... and ...
in(集合)not in(...)

#查询基本薪资是在 9000-12000 之间的员工编号和基本薪资
SELECT eid,basic_salary FROM t_salary WHERE basic_salary BETWEEN 9000 AND 12000;

#查询 eid 是 1,3,5 的基本工资
SELECT eid,basic_salary FROM t_salary WHERE eid IN (1,3,5);

5 、模糊查询

like 和 通配符 一起使用
like _ 匹配单个字符
like % 匹配任意个字符

#查询名字中有'冰'字的员工信息
SELECT * FROM t_employee WHERE ename LIKE '%冰%';

#查询姓李的员工信息
SELECT * FROM t_employee WHERE ename LIKE '李%';

#查询姓李,名字就一个字的员工信息
SELECT * FROM t_employee WHERE ename LIKE '李_';

#查询李冰冰的信息
SELECT * FROM t_employee WHERE ename LIKE '李冰冰';
通常情况,可以使用 FIND_IN_SET()函数或 LIKE 操作符搜索 SET 值:
	mysql> SELECT * FROM tbl_name WHERE FIND_IN_SET('value',set_col)>0;
	mysql> SELECT * FROM tbl_name WHERE set_col LIKE '%value%';1 个语句找出 SET_col 包含 value set 成员的行。第 2 个类似,但有所不同:它在其它地方找出 set_col 包含 value的行,甚至是在另一个 SET 成员的子字符串中。
	
	下面的语句也是合法的:
	mysql> SELECT * FROM tbl_name WHERE set_col & 1;
	mysql> SELECT * FROM tbl_name WHERE set_col = 'val1,val2';1 个语句寻找包含第 1set 成员的值。第 2 个语句寻找一个确切匹配的值。应注意第 2 类的比较。将 set值与'val1,val2'比较返回的结果与同'val2,val1'比较返回的结果不同。指定值时的顺序应与在列定义中所列的顺序相同。
	
如果想要为 SET 列确定所有可能的值,使用 SHOW COLUMNS FROM tbl_name LIKE set_col 并解析输出中第 2 列的 SET定义。

有什么实际应用呢?
	比如我们设定用户的权限控制,一个用户可能会有多种权限,我们使用所有权限创建一个 SET 类型的字段,我们不需要用一系列 int 来定义各种权限了,直接使用一个 SET 字段即可:
/*
用户权限 permission 表
*/
create table user_permission(
	id int UNSIGNED not null auto_increment,
	user_id int not null ,
	permission set('阅读','评论','发帖') not null,
	primary key(id),
	unique (user_id)
);
desc user_permission;
insert into user_permission values (0,1,'阅读'),(0,2,'阅读'),(0,3,'阅读,评论');
insert into user_permission values (0,4,'阅读,评论,发帖');
select *,permission+0 from user_permission;
select permission from user_permission where user_id=1;
select * from user_permission where permission & 10;
SELECT * FROM user_permission WHERE FIND_IN_SET('评论',permission)>0;

6 、NULL 值判断与计算处理

NULL 值判断与处理

#查询奖金百分比不为空的员工编号
SELECT eid,commission_pct FROM t_salary WHERE commission_pct IS NOT NULL;

#查询奖金百分比为空的员工编号
SELECT eid,commission_pct FROM t_salary WHERE commission_pct IS NULL;

关于 null 值计算
所有运算符遇到 null 都是 null

#计算实际的薪资: basic_salary + salary * 奖金百分比
#函数:IFNULL(表达式,用什么值代替)
SELECT eid,basic_salary + performance_salary *(1+ commission_pct) FROM t_salary;#错误的
SELECT eid,basic_salary + performance_salary *(1+ IFNULL(commission_pct,0)) FROM t_salary;

<=>安全等于

#查询奖金百分比为空的员工编号
SELECT eid,commission_pct FROM t_salary WHERE commission_pct <=> NULL;

7 、位运算符

>> << & | ~ ^(异或)

SELECT 2^3,2&3,2|3,2>>3,2<<3,~3;

二、关联查询

在这里插入图片描述
作用:从 2 张或多张表中,取出有关联的数据。

关联查询一共有几种情况:

  • 内连接:INNER JOIN 、CROSS JOIN
  • 外连接:左外连接(LEFT OUTER JOIN)、右外连接(RIGHT OUTER JOIN)、全外连接(FULL OUTER JOIN)
  • 自连接:当 table1 和 table2 本质上是同一张表,只是用取别名的方式虚拟成两张表以代表不同的意义。

说明:
(1)连接 n 个表,至少需要 n-1 个连接条件。 例如:连接三个表,至少需要两个连接条件。
(2)当两个关联查询的表如果有字段名字相同,并且要查询中涉及该关联字段,那么需要使用表名前缀加以区分
(3)当如果表名比较长时,可以给表取别名,简化 SQL 语句

在这里插入图片描述

1、笛卡尔积

定义:将两(或多)个表的所有行进行组合,连接后的行数为两(或多)个表的乘积数。
在 MySQL 中如下情况会出现笛卡尔积,主要是因为缺少关联条件或者关联条件不准确。

注:外连接必须写关联条件,否则报语法错误。

#查询员工姓名和所在部门名称
SELECT ename,dname FROM t_employee,t_department;
SELECT ename,dname FROM t_employee INNER JOIN t_department;
SELECT ename,dname FROM t_employee CROSS JOIN t_department;
SELECT ename,dname FROM t_employee JOIN t_department;

2、关联条件

表连接的约束条件可以有三种方式:WHERE, ON, USING。

  • WHERE:适用于所有关联查询
  • ON:只能和 JOIN 一起使用,只能写关联条件。虽然关联条件可以并到 WHERE 中和其他条件一起写,但分开写可读性更好。
  • USING:只能和 JOIN 一起使用,而且要求 两个关联字段在关联表中名称一致,而且只能表示关联字段值相等。
#把关联条件写在 where 后面
SELECT ename,dname FROM t_employee,t_department WHERE t_employee.dept_id=t_department.did;

#把关联条件写在 on 后面,只能和 JOIN 一起使用
SELECT ename,dname FROM t_employee INNER JOIN t_department ON t_employee.dept_id=t_department.did;
SELECT ename,dname FROM t_employee CROSS JOIN t_department ON t_employee.dept_id=t_department.did;
SELECT ename,dname FROM t_employee JOIN t_department ON t_employee.dept_id=t_department.did;

把关联字段写在 using()中,只能和 JOIN 一起使用,而且两个表中的关联字段必须名称相同,而且只能表示=

#查询员工姓名与基本工资
SELECT ename,basic_salary FROM t_employee INNER JOIN t_salary USING(eid);

n 张表关联,需要 n-1 个关联条件

#查询员工姓名,基本工资,部门名称
SELECT ename,basic_salary,dname FROM t_employee,t_department,t_salary
WHERE t_employee.dept_id=t_department.did AND t_employee.eid=t_salary.eid;
SELECT ename,basic_salary,dname FROM t_employee INNER JOIN t_department INNER JOIN t_salary
ON t_employee.dept_id=t_department.did AND t_employee.eid=t_salary.eid;

3、内连接(INNER JOIN)

有两种,显式的和隐式的,返回连接表中符合连接条件和查询条件的数据行。

格式:

  • 隐式:SELECT [cols_list] from 表 1,表 2 where [condition]
  • 显式:SELECT [cols_list] from 表 1 INNER JOIN 表 2 ON [关联条件] where [其他筛选条件]
    SELECT [cols_list] from 表 1 CROSS JOIN 表 2 ON [关联条件] where [其他筛选条件]
    SELECT [cols_list] from 表 1 JOIN 表 2 ON [关联条件] where [其他筛选条件]
    在这里插入图片描述
#查询员工姓名和所在部门名称
SELECT ename,dname FROM t_employee,t_department WHERE t_employee.dept_id=t_department.did;
SELECT ename,dname FROM t_employee INNER JOIN t_department ON t_employee.dept_id=t_department.did;
SELECT ename,dname FROM t_employee CROSS JOIN t_department ON t_employee.dept_id=t_department.did;
SELECT ename,dname FROM t_employee JOIN t_department ON t_employee.dept_id=t_department.did;

#查询员工姓名,基本工资,部门名称
SELECT ename,basic_salary,dname FROM t_employee,t_department,t_salary
WHERE t_employee.dept_id=t_department.did AND t_employee.eid=t_salary.eid;
SELECT ename,basic_salary,dname FROM t_employee INNER JOIN t_department INNER JOIN t_salary
ON t_employee.dept_id=t_department.did AND t_employee.eid=t_salary.eid;

4、外连接(OUTER JOIN)

外连接分为:

  • 左外连接(LEFT OUTER JOIN),简称左连接(LEFT JOIN)。
  • 右外连接(RIGHT OUTER JOIN),简称右连接(RIGHT JOIN)。
  • 全外连接(FULL OUTER JOIN),简称全连接(FULL JOIN)。

左连接(LEFT JOIN)

在这里插入图片描述

右外连接(RIGHT JOIN)

在这里插入图片描述

外连接(FULL JOIN)

mysql 不支持 FULL JOIN,但是可以用 left join union right join 代替。

在这里插入图片描述

5、自连接

当 table1 和 table2 本质上是同一张表,只是用取别名的方式虚拟成两张表以代表不同的意义。然后两个表再进行内连接,外连接等查询。

#查询员工姓名以及领导姓名,仅显示有领导的员工
SELECT emp.ename,mgr.ename
FROM t_employee AS emp, t_employee AS mgr
WHERE emp.mid = mgr.eid;

#查询员工姓名以及领导姓名,仅显示有领导的员工
SELECT emp.ename,mgr.ename
FROM t_employee AS emp INNER JOIN t_employee AS mgr
ON emp.mid = mgr.eid;

#查询所有员工姓名及其领导姓名
SELECT emp.ename,mgr.ename
FROM t_employee AS emp LEFT JOIN t_employee AS mgr
ON emp.mid = mgr.eid;

如果有收获!!! 希望老铁们来个三连,点赞、收藏、转发
创作不易,别忘点个赞,可以让更多的人看到这篇文章,顺便鼓励我写出更好的博客
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

MySQL(4)运算符 | 关联查询详解 的相关文章

  • HashMap中对红黑树、CAS等知识的补充

    目录 一 红黑树1 概念2 图示3 红黑树的特性 二 解决哈希冲突常见方法1 开放定址法2 链接地址3 再哈希法4 建立公共溢出区 三 CAS1 定义2 操作3 Java中CAS操作4 存在的问题5 实际应用 一 红黑树 1 概念 是一种自
  • 集合框架(1):Collection | Iterator | 增强for

    文章目录 Collection接口一 集合框架的概述Collection接口继承树Collection接口中的方法的使用使用迭代器Iterator遍历Collection集合增强for循环遍历集合 文章链接Java语法https blog
  • 解决tomcat启动闪退问题

    通过自己的实践和查阅资料 xff0c 完美解决一下问题 分享给需要的朋友 遇到问题所在 tomcat启动后 xff0c 黑窗口一闪而过 原因分析 缺少JAVA HOME 或者缺少JRE HOME xff0c 说明你的环境变量不对 xff0c
  • 一维数组 | 二维数组 | 内存解析

    文章目录 一 数组1 数组的理解 xff1a 2 数组相关的概念 3 数组的特点 xff1a 4 数组的分类 xff1a 5 数据结构 xff1a 二 一维数组1 一维数组的声明与初始化2 一维数组元素的引用3 数组的属性 xff1a le
  • Java基本语法

    文章目录 关键字与保留字1 关键字2 保留字 标识符1 标识符2 定义合法标识符规则3 Java中的名称命名规范 变量1 变量的概念2 变量作用3 声明变量4 变量分类5 数据类型6 基本数据类型之间的运算 运算符程序流程控制1 顺序结构2
  • Java小型计算器

    通过对程序的编写 xff0c 可以不同位数实现对加减乘除的计算 xff0c 以及对错误答案给出提示 以满足一些大人给小孩出题的困惑 xff0c 此程序可以自己出题 xff0c 自己检测答案 随时随地想做就做 需求 xff1a 1 实现计算器
  • 杨辉三角 | 回形数 | 复制 | 赋值练习题

    目录 杨辉三角回形数格式方阵的实现使用简单数组拓展 xff1a 修改题目 xff0c 实现array2对array1数组的复制 杨辉三角 使用二维数组打印一个10行杨辉三角 span class token keyword public s
  • 水仙花数 | 平闰年 | 斐波那契数列 | 反转单词

    目录 水仙花1 三位数的水仙花2 四位数的水仙花 平闰年斐波那契数列反转句子中单词顺序 水仙花 1 三位数的水仙花 span class token keyword for span span class token punctuation
  • 图像去雾:AOD-Net

    论文地址 xff1a https arxiv org pdf 1707 06543 pdf 相关代码 xff1a GitHub MayankSingal PyTorch Image Dehazing PyTorch implementati
  • 打印三角形 | 所有素数

    目录 3 100的所有素数找出来5 5正方形直角三角形反直角三角形正等腰三角形 xff08 金字塔 xff09 倒立等腰三角形 4 61 1 1 1 3 43 1 5 1 7 43 1 9 1 11 43 43 1 n 若n为99 3 10
  • 冒泡排序 | 快速排序 | 线性查找 | 二分查找等

    目录 排序算法 xff1a 冒泡排序排序算法 xff1a 快速排序数组的复制 反转 查询 xff08 线性查找 二分查找 xff09 排序算法 xff1a 冒泡排序 span class token keyword public span
  • 多线程(1/2)

    文章目录 一 多线程概述1 概念1 1 程序 进程 线程1 2 单核cpu和多核cpu1 3 并行和并发 2 优点3 何时需要 二 继承Thread类1 多线程创建的方式一 xff1a 继承于Thread类2 线程常用方法3 线程的优先级4
  • 多线程(2/2)

    文章目录 一 程序安全的单例模式之懒汉式1 通过同步代码块解决懒汉式单例设计模式的线程安全问题2 通过同步方法解决懒汉式单例设计模式的线程安全问题 二 死锁问题1 死锁的理解 2 说明 三 Lock锁方式解决线程安全问题四 线程的通信1 涉
  • 集合框架(5):LinkHashMap | TreeMap | Properties | Collections工具类

    文章目录 一 LinkedHashMap底层实现原理二 TreeMap1 自然排序2 定制排序 三 Properties四 Collections 工具类1 工具类中常用的方法2 代码演示 文章链接Java语法https blog csdn
  • 集合框架(2):List | ArrayList | LinkedList | Vector的底层源码

    文章目录 一 list比较ArrayList LinkedList Vector三者的异同 xff1f List接口常用方法List遍历及常用方法总结 ArrayList源码分析LinkedList源码分析Vector源码分析ArrayLi
  • 集合框架(3):set | HashSet | LinkedHashSet | TreeSet的底层源码

    文章目录 一 Set练习题 xff1a 在list内去除重复数据值 二 HashSet三 LinkHashSet四 TreeSet1 自然排序2 定制排序 文章链接Java语法https blog csdn net weixin 45606
  • 单例设计模式

    目录 一 设计模式1 理解2 常用设计模式 23种经典的设计模式 二 单例设计模式1 概念 xff1a 2 如何实现 xff1f 3 饿汉式和懒汉式的区别4 应用场景 xff1a 三 模板方法的设计模式1 解决的问题2 举例3 应用场景 一
  • PageHelper实现分页详细版、整合SSM应用

    在项目开发中我们经常要实现分页技术 xff0c 传统的开发过于繁琐 xff0c 这里我们讲解MyBatis中引进的PageHelper实现分页 简单易懂 xff0c 便于上手 xff01 xff01 xff01 参照官网 完成以下分页技术的
  • 最详细IDEA 的安装、配置与使用

    目录 IDEA 的安装 配置与使用一 IntelliJ IDEA 介绍1 IntelliJ IDEA 介绍2 官网 xff1a 3 IDEA 的下载地址 xff1a 官网 4 官网提供的详细使用文档 xff1a 二 windows 下载安装
  • 对遗传算法(GA)的一些理解

    目录 1 遗传算法的原理 2 遗传算法的主要流程 3 对遗传算法中的选择 编码 交叉及变异的理解 1 遗传算法的原理 基因以染色体为载体在种群间得以传播 xff0c 而基因在相当程度上决定了个体的表现型 性状 xff0c 这个传播过程常常伴

随机推荐

  • 最详细IDEA 常用配置、布局说明

    目录 一 创建 Java 工程 xff0c 分析页面布局1 设置显示常见的视图2 工程界面展示3 查看项目配置 二 常用配置 以idea 2019为例 1 设置主题2 设置字体大小 xff08 1 xff09 非代码窗口设置UI样式和字体
  • Springboot整合阿里云短信服务

    文章目录 开通阿里云了解阿里云用户权限操作开通阿里云短信服务添加短信模板添加签名 Springboot整合短信到项目中1 创建一个SpringBoot的项目2 导入依赖3 配置文件4 主启动类5 工具类6 控制器7 业务层8 测试 最好有S
  • 使用JS实现表单验证

    目录 表单页面展示FormCheck jsp CSS样式Register css JavaScript代码FormCheck js 效果图展示 平时我们在注册账号的时候经常看到有提示xxx不得法 xff0c 请重新填写字样 xff0c 本文
  • 对Spring深入的理解 | 概念的总结

    一 Spring的概述 官网 xff1a https spring io projects spring framework overview 官方下载地址 xff1a https docs spring io spring docs 4
  • Spring AOP详解

    1 简述 AOP 概念 AOP xff1a Aspect Oriented Program xff0c 面向 方面 切面的编程 xff1b Filter 过滤器 也是一种 AOP AOP 是一种新的方法论 xff0c 是对传统 OOP Ob
  • Spring IOC详解

    一 IOC的基本概念 1 简述 IOC 概念 IOC Invert Of Control xff0c 控制反转 也成为 DI 依赖注入 其思想是反转资源获取的方向 传统的资源查找方式要求组件向容器发起请求查找资源 作为回应 容器适时的返回资
  • Spring 声明式事务

    文章目录 1 回顾事务2 spring的事务管理3 Spring事务的种类4 基于XML的事务配置1 使用说明2 代码如下 5 基于注解的事务配置1 使用说明2 代码如下 6 基于XML和注解的事务配置代码如下 7 64 Transacti
  • Spring 依赖注入详解

    一 IOC 依赖注入 1 什么是Spring的依赖注入 依赖注入 xff0c 是IOC的一个方面 xff0c 是个通常的概念 xff0c 它有多种解释 这概念是说你不用创建对象 xff0c 而只需要描述它如何被创建 你不在代码里直接组装你的
  • JDBC(1) API详细说明

    目录 一 JDBC概述1 什么是 JDBC2 JDBC API3 JDBC 程序编写步骤 二 用使用 JDBC API1 引入 JDBC 驱动程序1 1 如何获取 JDBC 驱动程序1 2 在Java Project 项目应用中添加数据库驱
  • JDBC(2) 工具类 | PreparedStatement详细说明

    目录 一 JDBC 工具类使用 JDBC API 操作数据库的基本步骤编写工具类 JDBCUtils 二 PreparedStatement1 PreparedStatement 概述2 Statement 的不足3 PreparedSta
  • python: image.paste函数的理解

    目录 image paste函数 举例说明 xff1a image paste函数 python中PIL库中的paste函数的作用为将一张图片覆盖到另一张图片的指定位置去 函数的声明如下 xff1a def paste self im bo
  • JDBC(3)实现通用的增删改查方法

    编写通用的增删改查方法 不明白的可以看代码中注释 xff0c 写的很详细 1 通用的增删改 span class token comment 通用的更新数据库的方法 xff1a insert update delete 语句时 span s
  • JDBC(4)DBCP数据源 | C3P0 数据源

    1 DBCP 数据源 DBCP 是 Apache 软件基金组织下的开源连接池实现 xff0c 该连接池依赖该组织下的另一个开源系统 xff1a Common pool 如需使用该连接池实现 xff0c 应在系统中增加如下两个 jar 文件
  • JDBC(5)DBUtils类详解

    1 DbUtils 类 DbUtils xff1a 提供如关闭连接 装载 JDBC 驱动程序等常规工作的工具类 xff0c 里面的所有方法都是静态的 主要方法如下 xff1a public static void close throws
  • 验证码实现 - html页面版

    前言 图片验证码是我们日常经常用到的 xff0c 本文将介绍如何实现以及其原理 xff0c 并没有过多注重css样式 xff0c 单纯实现验证码功能 如果对滑块验证码感兴趣的可以看这篇文章 xff1a 滑块验证码实现及原理 如果对验证码实现
  • 验证码实现 - 工具类调用版

    前言 图片验证码是我们日常经常用到的 xff0c 本文将介绍如何实现以及其原理 xff0c 以注册页面为例实现功能 如果对滑块验证码感兴趣的可以看这篇文章 xff1a 滑块验证码实现及原理 如果对验证码实现感兴趣的可以看这篇文章 xff1a
  • 滑块验证码实现

    前言 滑块验证码也是生活中常见的 xff0c 本文会介绍如何实现以及原理 如果对验证码实现感兴趣的可以看这篇文章 xff1a 验证码实现 html页面版 如果对验证码实现感兴趣的可以看这篇文章 xff1a 验证码实现 工具类调用版 代码实现
  • MySQL(1)的使用 | SQL

    目录 MySQL 的使用1 启动和停止服务方式一 xff1a 图形化方式方式二 xff1a 命令行 2 客户端登录方式一 xff1a MySQL 自带客户端方式二 xff1a 命令行方式三 xff1a 可视化工具 SQL1 SQL 的语言规
  • MySQL(2)DDL详解

    一 DDL 1 1 操作 Database 注意 xff1a database 不能改名 一些可视化工具可以改名 xff0c 它是建新库 xff0c 把所有表复制到新库 xff0c 再删旧库完成的 1 创建数据库 create databa
  • MySQL(4)运算符 | 关联查询详解

    一 MySQL 的运算符 xff08 1 xff09 算术运算符 xff1a 43 xff08 除也可以写成 div xff08 取模可以写成 mod xff09 xff08 2 xff09 比较运算符 xff1a 61 gt gt 61