常用SQL语句大全

news2024/9/23 17:16:38

 目录

目录

一.SQL概念

二.数据库操作

2.0.连接数据库

2.1创建数据库

2.2使用数据库

2.3切换数据库

2.4删除数据库(慎用!!)

2.5查询数据库

三.表操作

3.0了解数据类型和数据约束

3.1创建表

3.2查询表

3.3修改表

3.4删除表

四.数据操作

4.1插入数据

结果:

 注意事项:

 批量插入数据

 4.2修改数据

4.3删除数据

4.4数据查询

4.4.1准备数据 

4.4.2基本语法 

 4.4.3条件查询

4.4.4聚合函数

4.4.5分组过滤

4.4.6排序

4.4.7分页

五.多表查询

5.0准备数据

5.1了解多表查询

5.2笛卡尔积(交叉查询)

5.3 内连接:隐式内连接、显示内连接

5.4外链接(左外链接,右外链接)

5.5 子查询

5.6代码实现 

 六.sql常用的单词积累



一.SQL概念

当谈到SQL(Structured Query Language)时,它是一种用于管理和操作关系型数据库的标准语言。以下是一些SQL的基本概念:

  1. 数据库(Database):数据库是用于存储和组织数据的集合。它可以包含多个表,索引,视图和其他数据库对象。

  2. 表(Table):表是数据库中数据的结构化表示形式。它由行和列组成,每列定义了特定的数据类型和名称。

  3. 列(Column):列是表中的一个字段,用于存储特定类型的数据。它具有名称和数据类型。

  4. 行(Row):行是表中的一个记录,它包含了一组相关的数据。

  5. 主键(Primary Key):主键是表中的一列或一组列,用于唯一标识表中的每一行。主键必须具有唯一性和非空性。

  6. 外键(Foreign Key):外键是表中的一列,它建立了与其他表的关联关系。外键用于实现表之间的关联和引用完整性。

  7. 查询(Query):查询是通过SQL语句从数据库中获取数据的方式。常见的查询操作包括选择(SELECT)、插入(INSERT)、更新(UPDATE)和删除(DELETE)。

  8. 索引(Index):索引是一种数据结构,用于提高数据库中数据的访问速度。它允许快速搜索和检索数据。

  9. 视图(View):视图是基于一个或多个表的查询结果集。它类似于虚拟表,可以简化复杂查询和数据访问。

  10. 事务(Transaction):事务是数据库操作的单个逻辑单位。它要么完全执行,要么完全回滚,以确保数据的一致性和完整性。

二.数据库操作

2.0.连接数据库

-- 语法
mysql [-h 服务器地址  -P 端口号] -u用户名 -p密码

--实例
mysql -u账号 -p密码

2.1创建数据库

-- create database [IF NOT EXISTS] 数据库名;
create database day035;

2.2使用数据库

-- use 数据库
use day035;

2.3切换数据库

-- 语法
select database();

2.4删除数据库(慎用!!)

-- 语法 drop database 数据库名
drop database day035;

2.5查询数据库

-- 语法
show databases;

三.表操作

3.0了解数据类型和数据约束

数据类型:数据类型定义了一个列或值可以存储的数据的种类。不同的数据类型具有不同的特性和存储要求。常见的 SQL 数据类型包括整数(INTEGER),浮点数(FLOAT),字符串(VARCHAR),日期时间(DATETIME)等。定义正确的数据类型可以提高存储效率,减少存储空间的消耗,并确保数据的合法性和一致性。

大分类类型描述
数值类型int大整数
float浮点数类型
double浮点数类型
字符类型varchar(30)可变长度字符串,如果插入的长度小于定义长度时,插入多长就存多长
char(11)固定长度字符串,如果插入的长度小于定义长度,则可以用空格进行填充
日期类型date日期,格式:yyyy-MM-dd
datetime日期时间,格式:yyyy-MM-dd HH:mm:ss

 数据约束:数据约束用于限制或定义表中数据的规则和限制条件。它们确保数据的完整性和一致性,并防止非法数据的插入或更新。常见的数据约束包括主键约束(PRIMARY KEY),唯一约束(UNIQUE),外键约束(FOREIGN KEY),非空约束(NOT NULL)等。通过定义适当的数据约束,可以确保数据的有效性和正确性,并防止不符合业务规则的数据被插入到表中。

约束描述关键字
主键约束主键是一行数据的唯一标识,要求非空且唯一;一张表只能有一个注解列primary key(auto increment自增)
非空约束限制该字段值不能为nullnot null
唯一约束保证字段的所有数据都是唯一、不重复的unique
默认约束保存数据时,如果未指定该字段值,则采用默认值default
外键约束让两张表的数据建立连接,保证数据的一致性和完整性foreign key

3.1创建表

  •  语法
语法:	
create table 表名(    
        字段名:1  字段类型1(字段长度) comment  "字段1注释 ",
        字段名2  字段类型2(字段长度) comment  "字段2注释 "	
        ....	
        字段名n  字段类型n(字段长度) comment  "字段n注释 "
    ) comment  ”表表名注解“ ;
--其中comment 可以省略不写
  • 需求:创建下列字段的表

    id:标识,数字类型

    name:姓名,字符串类型,长度限制最多30个字符

    gender:性别,字符串类型,长度限制为1个字符

    age:年龄,数值类型

    birthday:生日,日期类型,格式YYYY-mm-dd

  • 代码实现 
create table student1(
    id int comment '标识',
    name varchar(30) comment '姓名',
    gender char(1) comment '性别',
    age int comment '年龄',
    birthday date
);

3.2查询表

查询当前数据库所有表:show tables

查询表结构:desc 表名

查询建表语句:show create table 表名

-- 1. 查看当前库中的所有数据表
show tables;

-- 2. 查看student3表的表结构
desc student3;

-- 3. 查看student3表的建表语句
show create table student3;

3.3修改表

添加字段:alter table 表名 add 字段名 类型(长度)

修改字段类型:alter table 表名 modify 字段名 新数据类型(长度)

修改字段名和字段类型:alter table 表名 change 旧字段名 新字段名 类型 (长度)

删除字段:alter table 表名 drop column 字段名

修改表名: rename table 表名 to 新表名

-- 1. 修改student3表, 添加一列description 变长字符串类型,长度30
alter table student3 add description varchar(30);

-- 2. 修改student3表 description列为定长字符串类型,长度40
alter table student3 modify description char(40);

-- 3. 修改student3表 description列名为descr,变长字符串类型,长度20
alter table student3 change description descr varchar(20);

-- 4. 删除student3表的descr列
alter table student3 drop column descr;

-- 5. 修改student3表的名称为stu
rename table student3 to stu;

3.4删除表

-- 删除stu表
drop table stu;

四.数据操作

4.1插入数据

指定字段添加数据:insert into 表名 (字段名1, 字段名2)  values (值1, 值2)

全部字段添加数据:insert into 表名 values (值1, 值2, ...)

CREATE TABLE DEPT(
	DEPTNO int PRIMARY KEY,##部门编号
	DNAME VARCHAR(14) ,	##部门名称
	LOC VARCHAR(13)  	##部门地址
	) ;
--全部添加
INSERT INTO DEPT VALUES	(10,'ACCOUNTING','NEW YORK');
INSERT INTO DEPT VALUES (20,'RESEARCH','DALLAS');
INSERT INTO DEPT VALUES	(30,'SALES','CHICAGO');
INSERT INTO DEPT VALUES	(10,'ACCOUNTING','NEW YORK');
--选择字段添加
INSERT INTO DEPT(DEPTNO,LOC) VALUES(50,'hr')

INSERT INTO DEPT(LOC) VALUES('测试')
结果:

 注意事项:

1.如果表内有数据约束按照约束字段来添加

    比如 INSERT INTO DEPT(LOC) VALUES('测试') 这段代码因为没用遵循 DEPTNO 的主        键约束(PRIMARY KEY)无法添加    

 2. 如果添加单个数据其他数据会默认插入null  

 3. 插入数据时,指定的字段顺序需要与值的顺序是一一对应的
 4. 字符串和日期型数据应该包含在引号中 

 批量插入数据

批量添加数据(指定字段):insert into 表名 (字段名1, 字段名2) values (值1, 值2), (值1, 值2)

批量添加数据(全部字段):insert into 表名 values (值1, 值2, ...), (值1, 值2, ...)

-- 3. 批量为 为 tb_emp 表的 username , name , gender, create_time, update_time 字段插入数据
insert into tb_emp(username, name, gender, create_time, update_time)
		values ('zhangsan1', '张三1', 1, now(), now())
			  ,('zhangsan2', '张三2', 1, now(), now());

 4.2修改数据

修改数据:update 表名 set 字段名1 = 值1 , 字段名2 = 值2 , .... [ where 条件 ]

-- 1. 将 tb_emp 表的所有员工的入职日期更新为'2010-01-01'
update tb_emp set entrydate = '2010-01-01';

-- 2. 将 tb_emp 表的ID为1员工 姓名name字段更新为'黑马'
update tb_emp set name = '黑马' where id = 1;

-- 3. 将 tb_emp 表的ID为1员工 姓名name字段更新为'传智',入职日期更新为'2022-01-01'
update tb_emp set name = '传智',entrydate = '2022-01-01' where id = 1;

-- 注意	
	修改语句中如果不加条件,则将所有数据都会被修改!

4.3删除数据

删除数据:delete from 表名 [ where 条件 ]

-- 1. 删除 tb_emp 表中ID为1的员工
delete from tb_emp where id = 1;

-- 2. 删除 tb_emp 表中的所有员工
delete from tb_emp;

-- 注意
	删除语句中如果不加条件,则将所有数据都会被删除!	

4.4数据查询

4.4.1准备数据 

-- 员工管理(带约束)
drop table if exists tb_emp;
create table tb_emp (
    id int unsigned primary key auto_increment comment 'ID',
    username varchar(20) not null unique comment '用户名',
    password varchar(32) default '123456' comment '密码',
    name varchar(10) not null comment '姓名',
    gender tinyint not null comment '性别, 说明: 1 男, 2 女',
    image varchar(300) comment '图像',
    job tinyint comment '职位, 说明: 1 班主任,2 讲师, 3 学工主管, 4 教研主管',
    entrydate date comment '入职时间',
    create_time datetime not null comment '创建时间',
    update_time datetime not null comment '修改时间'
) comment '员工表';

-- 准备测试数据
INSERT INTO tb_emp (id, username, password, name, gender, image, job, entrydate, create_time, update_time) VALUES
    (1, 'jinyong', '123456', '金庸', 1, '1.jpg', 4, '2000-01-01', '2022-10-27 16:35:33', '2022-10-27 16:35:35'),
    (2, 'zhangwuji', '123456', '张无忌', 1, '2.jpg', 2, '2015-01-01', '2022-10-27 16:35:33', '2022-10-27 16:35:37'),
    (3, 'yangxiao', '123456', '杨逍', 1, '3.jpg', 2, '2008-05-01', '2022-10-27 16:35:33', '2022-10-27 16:35:39'),
    (4, 'weiyixiao', '123456', '韦一笑', 1, '4.jpg', 2, '2007-01-01', '2022-10-27 16:35:33', '2022-10-27 16:35:41'),
    (5, 'changyuchun', '123456', '常遇春', 1, '5.jpg', 2, '2012-12-05', '2022-10-27 16:35:33', '2022-10-27 16:35:43'),
    (6, 'xiaozhao', '123456', '小昭', 2, '6.jpg', 3, '2013-09-05', '2022-10-27 16:35:33', '2022-10-27 16:35:45'),
    (7, 'jixiaofu', '123456', '纪晓芙', 2, '7.jpg', 1, '2005-08-01', '2022-10-27 16:35:33', '2022-10-27 16:35:47'),
    (8, 'zhouzhiruo', '123456', '周芷若', 2, '8.jpg', 1, '2014-11-09', '2022-10-27 16:35:33', '2022-10-27 16:35:49'),
    (9, 'dingminjun', '123456', '丁敏君', 2, '9.jpg', 1, '2011-03-11', '2022-10-27 16:35:33', '2022-10-27 16:35:51'),
    (10, 'zhaomin', '123456', '赵敏', 2, '10.jpg', 1, '2013-09-05', '2022-10-27 16:35:33', '2022-10-27 16:35:53'),
    (11, 'luzhangke', '123456', '鹿杖客', 1, '11.jpg', 2, '2007-02-01', '2022-10-27 16:35:33', '2022-10-27 16:35:55'),
    (12, 'hebiweng', '123456', '鹤笔翁', 1, '12.jpg', 2, '2008-08-18', '2022-10-27 16:35:33', '2022-10-27 16:35:57'),
    (13, 'fangdongbai', '123456', '方东白', 1, '13.jpg', 1, '2012-11-01', '2022-10-27 16:35:33', '2022-10-27 16:35:59'),
    (14, 'zhangsanfeng', '123456', '张三丰', 1, '14.jpg', 2, '2002-08-01', '2022-10-27 16:35:33', '2022-10-27 16:36:01'),
    (15, 'yulianzhou', '123456', '俞莲舟', 1, '15.jpg', 2, '2011-05-01', '2022-10-27 16:35:33', '2022-10-27 16:36:03'),
    (16, 'songyuanqiao', '123456', '宋远桥', 1, '16.jpg', 2, '2010-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:05'),
    (17, 'chenyouliang', '12345678', '陈友谅', 1, '17.jpg', null, '2015-03-21', '2022-10-27 16:35:33', '2022-10-27 16:36:07'),
    (18, 'zhang1', '123456', '张一', 1, '2.jpg', 2, '2015-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:09'),
    (19, 'zhang2', '123456', '张二', 1, '2.jpg', 2, '2012-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:11'),
    (20, 'zhang3', '123456', '张三', 1, '2.jpg', 2, '2018-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:13'),
    (21, 'zhang4', '123456', '张四', 1, '2.jpg', 2, '2015-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:15'),
    (22, 'zhang5', '123456', '张五', 1, '2.jpg', 2, '2016-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:17'),
    (23, 'zhang6', '123456', '张六', 1, '2.jpg', 2, '2012-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:19'),
    (24, 'zhang7', '123456', '张七', 1, '2.jpg', 2, '2006-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:21'),
    (25, 'zhang8', '123456', '张八', 1, '2.jpg', 2, '2002-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:23'),
    (26, 'zhang9', '123456', '张九', 1, '2.jpg', 2, '2011-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:25'),
    (27, 'zhang10', '123456', '张十', 1, '2.jpg', 2, '2004-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:27'),
    (28, 'zhang11', '123456', '张十一', 1, '2.jpg', 2, '2007-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:29'),
    (29, 'zhang12', '123456', '张十二', 1, '2.jpg', 2, '2020-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:31');

4.4.2基本语法 

查询所有字段:select * from 表名

查询指定字段:select 字段1,字段2 from 表名

查询指定字段起别名:select name as '别名1' ,entrydate as '别名2' from tb_emp;

查询不重复字段: select distinct 字段 from tb_emp;

-- 1. 查询指定字段 name,entrydate 并返回
select name,entrydate from tb_emp;

-- 2. 查询返回所有字段
select * from tb_emp;

-- 3. 查询所有员工的 name,entrydate, 并起别名(姓名、入职日期)  --- as 关键字可以省略
select name as '姓名' ,entrydate as '入职日期' from tb_emp;
select name  '姓名' ,entrydate '入职日期' from tb_emp;

-- 4. 查询员工有哪几种职位(不要重复)
select distinct job from tb_emp;

 4.4.3条件查询

条件查询:selsct 字段列表 from 表名 where 条件

比较运算符功能逻辑运算符功能
>大于and并且 (多个条件同时成立)
>=大于等于or或者 (多个条件任意一个成立)
<小于!非 , 不是
<=小于等于
=等于
<> 或 !=不等于
is null是null
between ... and ...在某个范围之内(含最小、最大值)
in(...)在in之后的列表中的值,多选一
like 占位符模糊匹配(_匹配单个字符, %匹配任意个字符)
-- 1-1. 查询 姓名 为 杨逍 的员工
select * from tb_emp where name = '杨逍';

-- 1-2. 查询在 id小于等于5 的员工信息
select * from tb_emp where id <=5;

-- 1-3. 查询 密码不等于 '123456' 的员工信息
select * from tb_emp where password != '123456';

-- 1-4. 查询 没有分配职位 的员工信息
select * from tb_emp where job is null;

-- 1-5. 查询 有职位 的员工信息
select * from tb_emp where job is not null;


-- 2-1. 查询 id<=5 并且 job=2  的员工信息
select * from tb_emp where id <=5 and job = 2;

-- 2-1. 查询 id<=5 或者 job=2  的员工信息
select * from tb_emp where id <=5 or job = 2;


-- 3-1. 查询入职日期 在 '2000-01-01' (包含) 到 '2010-01-01'(包含) 之间的员工信息
select * from tb_emp where entrydate >= '2000-01-01' and entrydate <= '2010-01-01';
select * from tb_emp where entrydate between '2000-01-01' and '2010-01-01';

-- 3-2. 查询职位是 2 (讲师), 3 (学工主管), 4 (教研主管) 的员工信息
select * from tb_emp where job = 2 or job = 3 or job = 4;
select * from tb_emp where job in (2,3,4);


-- 4-1. 查询姓 '张' 的员工信息
select * from tb_emp where name like '张%';

-- 4-2. 查询姓名中包含 '三' 的员工信息
select * from tb_emp where name like '%三%';

-- 4-3. 查询姓'张',并且姓名为三个字的员工信息
select * from tb_emp where name like '张__';

4.4.4聚合函数

函数功能
count统计数量
max最大值
min最小值
avg平均值
sum求和

 count 解释:
count(1):统计所有的数量(包括null)。
count(*):统计所有的数量(包括null)。
count(字段):统计该"字段"不为null的数量。
count(distinct 字段):统计该"字段"去重且不为null的数量。

4.4.5分组过滤

分组过滤:select 分组字段,聚合函数() from 表名 group by 分组字段名 having 分组后过滤条件

-- 1. 根据性别分组, 统计男性和女性员工的数量
select gender,count(1) from tb_emp group by gender;

-- 2. 先查询入职时间在 '2015-01-01' (包含) 以前的员工
select * from tb_emp where entrydate <= '2015-01-01';

-- 3. 先查询入职时间在 '2015-01-01' (包含) 以前的员工,并对结果根据职位分组
select job,count(1) from tb_emp where entrydate <= '2015-01-01' group by job;

-- 4. 先查询入职时间在 '2015-01-01' (包含) 以前的员工,并对结果根据职位分组,获取员工数量大于等于2的职位
select job,count(1) from tb_emp where entrydate <= '2015-01-01' group by job having count(1) > 2;

4.4.6排序

排序:select 字段列表 from 表名 order by 字段1 排序方式1 , 字段2 排序方式2

ASC:升序(默认值)

DESC:降序

-- 1. 根据入职时间,对员工进行降序排序
select * from tb_emp order by entrydate desc;

-- 2. 根据入职时间,对员工进行升序排序
select * from tb_emp order by entrydate asc;

-- 3. 根据入职时间对公司的员工进行升序排序,入职时间相同再按照ID进行降序排序
select * from tb_emp order by entrydate asc, id desc;

4.4.7分页

分页:select 字段列表 from 表名 limit 起始索引, 查询记录数

-- 1. 查询第1页员工数据, 每页展示5条记录
select * from tb_emp limit 0,5;

-- 2. 查询第2页员工数据, 每页展示5条记录
select * from tb_emp limit 5,5;

-- 3. 查询第3页员工数据, 每页展示5条记录
select * from tb_emp limit 10,5;

-- 4. 查询第4页员工数据, 每页展示5条记录
select * from tb_emp limit 15,5;

五.多表查询

5.0准备数据

-- 创建部门表(主表)
CREATE TABLE dept (
  id INT PRIMARY KEY AUTO_INCREMENT,
  NAME VARCHAR(20)
);
INSERT INTO dept (NAME) VALUES ('开发部'),('市场部'),('财务部');

-- 创建员工表(从表)
CREATE TABLE emp (
  id INT PRIMARY KEY AUTO_INCREMENT,
  NAME VARCHAR(10),
  gender CHAR(1),  -- 性别(sex)
  salary DOUBLE,   -- 工资
  join_date DATE,  -- 入职日期
  dept_id INT -- 外键字段
);
INSERT INTO emp(NAME,gender,salary,join_date,dept_id) VALUES('孙悟空','男',7200,'2013-02-24',1);
INSERT INTO emp(NAME,gender,salary,join_date,dept_id) VALUES('猪八戒','男',3600,'2010-12-02',1);
INSERT INTO emp(NAME,gender,salary,join_date,dept_id) VALUES('蜘蛛精','女',6666,'2011-03-14',2);
INSERT INTO emp(NAME,gender,salary,join_date,dept_id) VALUES('沙僧','男',4500,'2017-03-04',null);

5.1了解多表查询

项目开发中,因为业务之间相互关联,所以实体与实体之间存在联系,故而表跟表之间也存在着各种联系

我们把这种能够表示表间关系的数据库称为关系型数据库(RDBMS)

在数据库设计上,表关系分为三种:一对多、多对多、一对一

  

  • 多表查询:多张表联合在一起查询。

  • 查询方式:

    • 笛卡尔积(交叉查询)(了解)

    • 内连接:隐式内连接、显示内连接

    • 外连接:左外连接、右外连接

    • 子查询

5.2笛卡尔积(交叉查询)

 语法:select * from A,B;

-- 语法:select * from A,B;
select * from dept, emp;

5.3 内连接:隐式内连接、显示内连接

-- 内连接:隐式内连接、显示内连接
-- 隐式内连接语法:select * from A, B where 连接条件

-- 显示内连接: select * from A a inner join B b on a.主键 = b.外键;


select * from dept, emp where dept.id = emp.dept_id;

select * from dept as d, emp e where d.id = e.dept_id; 

select * from dept d inner join emp e on d.id = e.dept_id;       

 三张表以上操作

select * from A a, B b, C c, D d
where a.id = b.a_id and b.id = c.bid and c.id = d.c_id;

select * from A a
  inner join B b on a.id = b.a_id
  inner join C c on b.id = c.bid
  inner join D c on c.id = d.c_id;

5.4外链接(左外链接,右外链接)

-- 外连接:左外连接、右外连接
-- 左外连接:查询左表A的所有数据,如果条件成立将关联显示右表B的数据,如果条件不成立将显示null
-- 语法:select * from A a left outer join B b on 条件;
-- 需求:显示所有的员工,同时关联显示部门信息,没有显示null

-- 右外连接:查询右表B的所有数据,如果条件成立将关联显示左A表的数据,如果条件不成立将显示null
-- 语法:select * from A a right outer join B b on 条件;

select * from emp e
  left outer join dept d on e.dept_id = d.id;
	

select * from dept d
  right outer join emp e on e.dept_id = d.id;

5.5 子查询

子查询:一条sql语句成为另一条sql语句语法的一部分。

5.6代码实现 

-- 子查询 ,查询员工时,显示部门信息
select id,name,gender, dept_id from emp;

-- 通过 部门id 查询部门名称
select name from dept where id = 1

select id,name,gender, (select name from dept where id = dept_id) as deptName from emp;



-- 子查询:查询id=1和id=2员工信息,同时显示部门信息

-- 查询id=1和id=2员工信息
select * from emp where id in (1,2)

-- 多表查询
select * from t, dept d where t.dept_id = d.id;
select * from (select * from emp where id in (1,2)) as t, dept d where t.dept_id = d.id;

 六.sql常用的单词积累

单词翻译
SELECT查询
INSERT插入
UPDATE更新
DELETE删除
FROM从哪个表
WHERE条件
JOIN连接
GROUP BY分组
ORDER BY排序
ASC升序
DESC降序
COUNT计数
SUM求和
AVG平均值
MAX最大值
MIN最小值
DISTINCT去重
auto_increment自增
UNION合并两个查询的结果集
LIKE模糊匹配
BETWEEN在指定的两个值之间
IN包含在指定的值集合中
NOT否定条件
IS NULL包含空值的行
EXISTS判断是否存在
ALL / ANY与子查询一起使用
ON在 JOIN 操作中指定关联条件
AS / alias给表或列起别名
NULL空值 / 未知值
PRIMARY KEY主键 / 唯一标识符
FOREIGN KEY外键
INDEX索引

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1518242.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【PTA】L1-032 L1-033(c)第六天

L1-032 Left-pad 分数 20 作者 陈越 单位 浙江大学 根据新浪微博上的消息&#xff0c;有一位开发者不满NPM&#xff08;Node Package Manager&#xff09;的做法&#xff0c;收回了自己的开源代码&#xff0c;其中包括一个叫left-pad的模块&#xff0c;就是这个模块把javas…

【开源-土拨鼠充电系统】鸿蒙 HarmonyOS 4.0+微信小程序+云平台

本人自己开发的开源项目&#xff1a;土拨鼠充电系统 ✍GitHub开源项目地址&#x1f449;&#xff1a;https://github.com/cheinlu/groundhog-charging-system ✍Gitee开源项目地址&#x1f449;&#xff1a;https://gitee.com/cheinlu/groundhog-charging-system ✨踩坑不易&am…

集合系列(一) -集合框架简介

一、集合类简介 Java集合就像一种容器&#xff0c;可以把多个对象&#xff08;实际上是对象的引用&#xff0c;但习惯上都称对象&#xff09;“丢进”该容器中。从Java 5 增加了泛型以后&#xff0c;Java集合可以记住容器中对象的数据类型&#xff0c;使得编码更加简洁、健壮。…

使用点链云管家创建瑜伽约课小程序

点链云管家 点链云管家是由上海点链科技开发的门店管理系统&#xff0c;为线下门店商家提供一站式门店运营服务平台解决方案&#xff0c;适用于瑜伽健身、美业、新零售会员制电商、母婴店、宠物店、按摩养生、服装、美容、美甲、汽车服务、商超零售、餐饮、KTV娱乐、干洗等18个…

如何在Linux使用docker部署Swagger Editor并实现无公网IP远程协同编辑API文档

目录 前言 Swagger Editor本地接口文档公网远程访问 1. 部署Swagger Editor 2. Linux安装Cpolar 3. 配置Swagger Editor公网地址 4. 远程访问Swagger Editor 5. 固定Swagger Editor公网地址 结语 前言 作者简介&#xff1a; 懒大王敲代码&#xff0c;计算机专业应届生 …

Linux的一些常用指令

一、文件中 r w x - 的含义 r&#xff08;read&#xff09;是只读权限&#xff0c; w&#xff08;write&#xff09;是写的权限&#xff0c; x&#xff08;execute&#xff09;是可执行权限&#xff0c; -是没有任何权限。 二、一些指令 # 解压压缩包 tar [-zxvf] 压缩包名…

springboot+ssm基于vue.js的客户关系Crm管理系统

系统包含两种角色&#xff1a;管理员、用户&#xff0c;主要功能如下。 ide工具&#xff1a;IDEA 或者eclipse 编程语言: java 数据库: mysql5.7 框架&#xff1a;ssmspringboot都有 前端&#xff1a;vue.jsElementUI 详细技术&#xff1a;springbootSSMvueMYSQLMAVEN 数据库…

揭秘动态住宅代理:如何合法获取全球数据洞察

文章目录 写在前面代理网络的崛起什么是代理网络&#xff1f;动态住宅代理的革命为什么选择亮数据动态代理 如何利用采集工具获取全球亮数据写在最后 写在前面 随着互联网技术的发展&#xff0c;数据已经成为企业生存和发展的不可或缺的资源。尤其在商业世界里&#xff0c;如何…

使用 ChatGPT 写高考作文

写作文&#xff0c;很简单&#xff0c;但写一篇好的作文&#xff0c;是非常有难度的。 想要写一篇高分作文&#xff0c;需要对作文题目有正确的理解&#xff0c;需要展现独到的观点和深入的思考&#xff0c;需要具备清晰的逻辑结构&#xff0c;需要准确而得体的语言表达。 正…

租个阿里云的服务器多少钱?30元、61元、99元、165元、199元

2024年租个阿里云的服务器多少钱&#xff1f;很便宜&#xff0c;云服务器2核2G3M固定带宽99元一年、2核4G服务器30元3个月、199元一年&#xff0c;轻量应用服务器2核2G3M配置61元一年、2核4G4M带宽165元一年&#xff0c;可以在阿里云CLUB中心查看 aliyun.club 当前最新的优惠券…

Elastic Agent 的安装及使用

概述 Elastic Agent是Elastic Stack中的一个全新组件&#xff0c;旨在简化和统一监控和集成管理流程。它是一个轻量级的代理&#xff0c;可以部署到各种不同类型的主机和容器中&#xff0c;用于收集系统指标、日志和事件数据&#xff0c;并将其发送到Elasticsearch进行存储和分…

【Qt】QListView 显示富文本,设置文本内容颜色

【Qt】QListView 显示富文本&#xff0c;设置文本内容颜色 文章目录 I - 控件使用II - 显示富文本III - 注意事项 I - 控件使用 Qt 的 MVC 架构为 MV &#xff0c;Controller 部分继承到了 View 里&#xff0c;View(视图) 设置 Model(模型)&#xff0c;Model 设置数据 这里使用…

新鲜出炉!界面控件DevExpress WinForms 2024产品路线图预览(三)

DevExpress WinForm拥有180组件和UI库&#xff0c;能为Windows Forms平台创建具有影响力的业务解决方案。DevExpress WinForm能完美构建流畅、美观且易于使用的应用程序&#xff0c;无论是Office风格的界面&#xff0c;还是分析处理大批量的业务数据&#xff0c;它都能轻松胜任…

专业140+总400+重庆邮电大学801信号与系统考研经验重邮电子信息与通信工程,真题,大纲,参考书。

今年报考重庆邮电大学研究生&#xff0c;初试专业课801信号与系统140总分400&#xff0c;总结一下自己去年的复习经验&#xff0c;希望对大家复习有帮助。 专业课&#xff1a; 重邮专业801信号与系统难度中等&#xff0c;今年140算是正常发挥&#xff0c;没有达到Jenny老师要求…

【经验分享】Windows10无法通过SSHFS连接服务器

【经验分享】Windows10如何通过SSHFS连接服务器 前言问题分析解决方法 前言 现在很多公司出于成本考虑&#xff0c;不会为每一台电脑都提供高配置&#xff0c;所以需要通过访问云服务器来进行编译等操作。程序员如果配备的是一台windows电脑&#xff0c;那么需要访问linux服务…

Java复习04 注解和反射

Java复习04 注解和反射 初学 注解和反射的时候 我的问题是 什么是注解&#xff1f; 什么是反射&#xff1f;单例模式 Stream ForkJoin有什么区别&#xff1f; 注解的分类有哪些&#xff1f;怎么区分&#xff1f;反射的分类有哪些&#xff1f;怎么区分&#xff1f; 反射里面Con…

视频水印如何去除?看看这三款工具!

在处理视频内容时&#xff0c;经常会遇到带有水印的视频素材。这些水印有时会遮挡重要的视觉信息&#xff0c;或者影响视频的美观性。为了保持视频内容的完整性和专业性&#xff0c;一个高效的视频去水印工具就显得尤为重要。下面我为大家推荐三款能够轻松去除视频水印的工具。…

Qt+FFmpeg+opengl从零制作视频播放器-3.解封装

解封装&#xff1a;如下图所示&#xff0c;就是将FLV、MKV、MP4等文件解封装为视频H.264或H.265压缩数据&#xff0c;音频MP3或AAC的压缩数据&#xff0c;下图为常用的基本操作。 ffmpeg使用解封装的基本流程如下&#xff1a; 在使用FFmpeg API之前&#xff0c;需要先注册API&a…

离线安装数据库 mysql 5.7 linux

离线安装数据库 mysql 5.7 linux 方法一 参考链接Linux(Debian10.2)安装MySQL5.7.24环境 赋予文件执行权限chmod x 文件名 使用root用户sudo su解压文件tar xvf mysql-5.7.42-linux-glibc2.12-x86_64.tar.gz重命名mv mysql-5.7.42-linux-glibc2.12-x86_64 mysql将桌面的mys…

探索5个启发人心的网页设计案例,助您打造独特个人作品集!

对于网页设计师来说&#xff0c;网页设计作品集不仅是网页的门面&#xff0c;也是个人专业素养的体现。那么我们就不能掉以轻心地设计作品集了。无论是制作简单大方的作品集还是表现力极强的优秀作品集&#xff0c;设计师都必须非常努力地参考大量的设计作品来获得灵感。 国产…