MySQL 初探:从基础到优化

news2024/10/10 20:08:58

什么是 MySQL?

  • MySQL 是一个开源的关系型数据库管理系统 (RDBMS),使用结构化查询语言 (SQL) 进行数据管理。作为最流行的数据库之一,MySQL 被广泛应用于各类网站和应用中,从小型应用到大型复杂系统。

MySQL 的特点

  • 开源免费:尽管 MySQL 有商业版本,但其开源版本已经足够满足大部分应用需求。
  • 跨平台:支持多种操作系统,包括 Windows、Linux 和 macOS。
  • 高性能:通过优化的存储引擎如 InnoDB 提供高效的读写能力。
  • 支持事务:事务管理使得 MySQL 能够确保数据一致性和完整性。
  • 社区支持:拥有庞大的用户和开发者社区,提供丰富的资源和支持。

mac 下安装启动不了

sudo chown -R mysql /usr/local/mysql/data
sudo /usr/local/mysql/support-files/mysql.server start

navcat 连接不上 mysql

https://blog.csdn.net/dabao87/article/details/80571877

mysql 基本操作

  1. 显示所有数据库
show databases;
  1. 进入某人数据库
use databases;
  1. 查看数据库里的表
show tables;
  1. 查看在某个数据库
slect database()
  1. 创建一个表
create table info(id int name varchar(20));
  1. 查看表结构
desc ifof(表名)

  1. 查看数据
select * from info(表名)
  1. 查看数据库版本
select version()

mysql 语法规范

  1. 不区分大小写,但关建议关键字,表名,列名小写
  2. 每条命令最好用分号结尾
  3. 每条命令根据需要,可以进行缩进或换行

DQL 查询语言

  1. 查询表中单个字段
SELECT last_name (字段名) FROM employees;
  1. 查询表中多个字段
SELECT last_name,salary,email from employees;
  1. 查询表中所有字段
SELECT * FROM employees;
  1. 查询常量值
SELECT 100;
  1. 查询表过式
SELECT 100 * 98;
  1. 查询函数
SELECT VERSION()
  1. 起别名
SELECT 100%92 as 结果;
SELECT last_name as 姓,first_name as 名 FROM employees;
  1. 去重
SELECT DISTINCT department_id from employees
  1. 字符串的拼接
SELECT CONCAT(last_name,first_name) as 姓名 FROM employees;

条件查询

  1. 按条件表过式筛选
SELECT * FROM employees WHERE salary > 12000
  1. 按逻辑运算符进行筛选
SELECT last_name,salary,commission_pct FROM employees WHERE salary >=10000 AND salary <=20000;
SELECT * FROM employees WHERE NOT(department_id >=90 AND department_id <=110) OR salary >15000;
  1. 模糊查询 like between and in is null is not null
SELECT * FROM employees WHERE last_name LIKE '%a%';

  1. 查询两者之间 between and 包含临界值,临界值的顺序不能错序
SELECT * FROM employees WHERE employee_id BETWEEN 100 AND 120;

  1. in 判断某个字段的值是否属于 in 列表中的某一项
SELECT last_name,job_id FROM employees WHERE job_id IN('IT_PROT','AD_VP','AD_PRES');
  1. is null = 或<>不能用于判断 null 值
SELECT last_name,commission_pct FROM employees WHERE commission_pct IS NULL

排序查询

  1. 从高到低进行排序
SELECT * FROM employees ORDER BY salary DESC;
  1. 排序+筛选
SELECT * FROM employees WHERE department_id >=90 ORDER BY hiredate ASC
  1. 按字节进行排序
SELECT LENGTH(last_name) last_name,salary FROM employees ORDER BY LENGTH(last_name) DESC;

  1. 模糊查询排序
SELECT *,LENGTH(email) FROM employees WHERE email LIKE '%e%' ORDER BY LENGTH(email) DESC, department_id ASC;

字符函数

  1. 获取字符串的字节个数
SELECT LENGTH("hello world");
  1. 拼接字符口串
SELECT CONCAT(last_name,'_',first_name) as 姓名 FROM employees;
  1. upper,lower 将字符串变大写,小写
SELECT CONCAT(UPPER(last_name),UPPER(first_name)) as 姓名 FROM employees;

  1. substr 截取从指定索引处后面的所有字符
SELECT SUBSTR("李莫悉爱上了陆展元",7) as out_put;
SELECT SUBSTR("李莫悉爱上了陆展元",1,3) as out_put;
  1. instr 返回子串第一次出现的索引,如果找不到返回 0
SELECT INSTR('杨不悔爱上了六侠','六侠') as out_put;
  1. trim

  1. lpad 用指定的字符实现左填充指定长度
SELECT LPAD("刘德华",10,"*") as out_put;

  1. rpad 用指定的字符实现右填充指定的长度
SELECT RPAD("刘德华",10,"*") as out_put;
  1. replace 替换
SELECT REPLACE("张无忌爱上周芷若","周芷若","赵敏") as out_put;

常用数学函当我

  1. round 四舍五入
SELECT ROUND(1.55) as out_put;

  1. ceil 向上取整
SELECT CEIL(1.01) as out_put;
  1. floor 向下取整
SELECT FLOOR(1.65) as out_out;
  1. truncate 截断
SELECT TRUNCATE(1.65,1) as out_put;
  1. mod 取余
SELECT MOD(10,3) as out_put;

日期函数

  1. now 返回当前系统日期+时间
SELECT NOW() as out_put;
  1. curdate 返回当前系统日期,不包含时间
SELECT CURDATE();
  1. curtime 返回当前日间,不包含日期
SELECT curtime();
  1. 指定返回年,月,日,时 ,分,秒
SELECT YEAR(NOW()) as out_put;

流程控制函数

  1. if 函数
SELECT IF(10 > 5,'大','小');
SELECT last_name,commission_pct,IF(commission_pct IS NULL,'没奖金,呵呵','有奖金,嘻嘻')  备注 FROM employees;
  1. case 函数
SELECT salary 原始工资,department_id,
CASE department_id
	WHEN 20 THEN salary * 1.1
	WHEN 40 THEN salary * 1.2
	WHEN 50 THEN salary * 1.3
	ELSE salary
END AS 新工资 FROM employees;

分组函数

  1. sum 求合
SELECT SUM(salary) FROM employees;
  1. avg 求平均值
SELECT AVG(salary) FROM employees;
  1. distinct 去重
SELECT SUM(DISTINCT salary) FROM employees;
  1. count 统计
SELECT COUNT(DISTINCT salary) FROM employees;
  1. 求最大值,最小值,总合
SELECT MAX(salary) as 最大值,MIN(salary) as 最小值,SUM(salary) as 总合 from employees;
  1. 求两个时间相差的天数
SELECT DATEDIFF(MAX(hiredate),MIN(hiredate)) as 差异 FROM employees;
  1. 统计某个部门 id 的个数
SELECT COUNT(*) 个数 FROM employees WHERE department_id = 90;

group by 函数

  1. 查询每个工种的最高工资
SELECT MAX(salary),job_id FROM employees GROUP BY job_id;
  1. 查询每个位置上的部门数
SELECT COUNT(*),location_id FROM departments GROUP BY location_id;

  1. 查询每个部门的平均工资
SELECT AVG(salary),department_id FROM employees GROUP BY department_id;
  1. 查询有奖金的每个领导手下员工的最高工资
SELECT MAX(salary),manager_id FROM employees WHERE commission_pct IS NOT NULL GROUP BY manager_id;
  1. 查询每个部门员工数大于 2 的
SELECT COUNT(*),department_id FROM employees GROUP BY department_id HAVING COUNT(*) > 2

join 连接查询

  1. 查询员工名对应的部门名
SELECT last_name,department_name FROM employees,departments WHERE employees.department_id = departments.department_id;

  1. 查询员工名,工种号,工种名
SELECT last_name,employees.job_id,job_title FROM employees,jobs WHERE employees.job_id = jobs.job_id;

  1. 查询有奖金的员工名,部门名
SELECT last_name,department_name,commission_pct FROM employees e,departments d WHERE e.department_id = d.department_id AND e.commission_pct IS NOT NULL;

  1. 查询城市名第二个字符为 o 的部门名和城市名
SELECT department_name,city FROM departments d,locations l WHERE d.location_id = l.location_id AND city LIKE '_o%';
  1. 查询每个城市的部门个数
SELECT COUNT(*) AS 个数,city FROM departments d,locations l WHERE d.location_id = l.location_id GROUP BY city;
  1. 查询每个工种的工种名和员工个数,并且按员工个数降序
SELECT job_title,COUNT(*) FROM employees e,jobs j WHERE e.job_id = j.job_id GROUP BY job_title ORDER BY COUNT(*) DESC;

  1. 等值链查询员工名,部门名
SELECT last_name,department_name FROM employees e INNER JOIN departments d ON e.department_id = d.department_id;

  1. 查询名字中包含 e 的员工名和工种名
SELECT last_name,job_title FROM employees e INNER JOIN jobs j ON e.job_id = j.job_id WHERE e.last_name LIKE '%e%';

  1. 查询部门数大于 3 的城市名和部门数
SELECT city,COUNT(*) AS 部门个数 FROM departments AS d INNER JOIN locations AS l ON d.location_id = l.location_id GROUP BY city HAVING COUNT(*) > 3;

日期与时间

SELECT CURDATE(),CURRENT_DATE(), CURTIME(), NOW(),SYSDATE(),UTC_DATE(),UTC_TIME() FROM DUAL;

  1. 日期与时间 cho
SELECT UNIX_TIMESTAMP();
SELECT FROM_UNIXTIME(1702247160)

子查询

  1. 标是子查询 查询工资比 Abel 高的
SELECT * FROM employees WHERE salary > (SELECT salary FROM employees WHERE last_name = "Abel");
  1. 返回公司工资最低的员工的 last_name,job_id 和 salary
SELECT last_name,job_id,salary FROM employees
WHERE salary = (SELECT MIN(salary) FROM employees);
SELECT MIN(salary),department_id FROM employees
GROUP BY department_id
HAVING MIN(salary) > (SELECT MIN(salary) FROM employees WHERE department_id = 50);
  1. 行子查询

分页查询

  1. 查询前 5 条员工信息
SELECT * FROM employees LIMIT 0, 5;
  1. 查询第 11 条到第 25 条
SELECT * FROM employees LIMIT 10, 15;

DDL 语句

插入语法

  1. 插入的值的类型要与列的类型兼容或一致
INSERT INTO beauty(id,`name`,sex,borndate,phone,photo,boyfriend_id) VALUES(13,'刘德华','男','1789-4-23','15083356190',NULL,2)
  1. 插入方式 2
INSERT INTO beauty SET id = 15,`name` = "刘涛", borndate = "1978-09-10", phone = "15082256191"

修改语法

  1. 修改单表的记录
UPDATE beauty SET `name` = "阿涛" WHERE id = 15
UPDATE beauty SET phone = "15083356190" WHERE `name` LIKE "阿%"

删除语语

  1. 单表的删除
DELETE FROM beauty WHERE id = 15;

  1. 删除手机号为 9 结层的用户信息
DELETE FROM beauty WHERE phone LIKE '%9';
  1. 多表连接删除
DELETE b FROM beauty b INNER JOIN boys bo NO b.boyfriend_id = bo.id WHERE bo.boyName = "张无忌";
  1. 创建表
CREATE TABLE my_employess(
	id INT(10),
	first_name VARCHAR(10),
	last_name VARCHAR(10),
	salary DOUBLE(10,2)
);

DDL 数据定义语言

  1. 创建数据库
CREATE DATABASE books;
CREATE DATABASE IN NOT EXISTS books;
  1. 删除库
DROP DATABASE books;
  1. 创建表
CREATE TABLE book(
	id INT,
	bname VARCHAR(25),
	price DOUBLE,
	author VARCHAR(20)
);
  1. 修改表的字段名
ALTER TABLE book CHANGE COLUMN author pub_author  VARCHAR(20);

  1. 添加表的新列
ALTER TABLE book ADD COLUMN salary DOUBLE;

  1. 删除表的一列
ALTER TABLE book DROP COLUMN salary;
  1. 修改表名
ALTER TABLE book RENAME TO book_info;

  1. 表的删除
DROP TABLE book_info;
  1. 复制表的结构
CREATE TABLE copy LIKE book;
  1. 复制表的结构与数据
CREATE TABLE copy2 SELECT * FROM book;

sql 的执行过程

form ... -> on -> (left/ right join) -> where -> group by -> having ->
select -> distinct -> order by -> limit

外键约束

添加外键关联

ALTER TABLE emp add CONSTRAINT fk_emp_dept_id FOREIGN KEY(dept_id) REFERENCES dept(id);

删除外键

ALTER TABLE emp drop FOREIGN KEY fk_emp_dept_id

表结构多对多

CREATE TABLE users(
	id int PRIMARY KEY auto_increment COMMENT "主键",
	uname VARCHAR(10) NOT NULL UNIQUE COMMENT "姓名",
	age int CHECK(age > 0 && age < 120) COMMENT "年龄",
	ustatus CHAR(1) DEFAULT '1' COMMENT "状态",
	gender char(1) COMMENT "性别"
) COMMENT "用户表"


DROP TABLE users;


DESC users;

SELECT * FROM users;

INSERT INTO users(uname,age,ustatus,gender) VALUES("tom1",19,'1',"男"),("tom2",25,'0',"男")

SELECT * FROM users;

INSERT INTO users(uname,age,ustatus,gender) VALUES("tom3",119,'0','女');

SELECT * FROM users;

INSERT INTO users(uname,age,gender) VALUES("tom2",20,"女");

SELECT * FROM users;


CREATE TABLE dept(
	id int PRIMARY KEY auto_increment COMMENT "id",
	dname VARCHAR(50) NOT NULL COMMENT "部门名称"
) COMMENT "部门表"

INSERT INTO dept(id,dname) VALUES(1,"研发部"),(2,"市场部"),(3,"财务部"),(4,"销售部"),(5,"总经办");

CREATE TABLE emp(
	id INT PRIMARY KEY auto_increment COMMENT "id",
	ename VARCHAR(50) NOT NULL COMMENT "姓名",
	age int COMMENT "年龄",
	job VARCHAR(20) COMMENT "职位",
	salary INT COMMENT "薪资",
	entrydate date COMMENT "入职时间",
	managerid INT COMMENT "直属领导",
	dept_id INT COMMENT "部门is"
) COMMENT "员工表"

DROP TABLE emp;


INSERT INTO emp(ename,age,job,salary,entrydate,managerid,dept_id) VALUES
("金庸",66,"总载",20000,"2000-01-01",NULL,5),
("张小小",20,"项目经理",12500,"2005-12-05",1,1),
("杨逍",33,"开发",8400,"2000-11-03",2,1),
("韦一笑",48,"开发",11000,"2002-02-05",2,1),
("常遇春",43,"开发",10500,"2004-09-7",3,1),
("小昭",19,"程序员鼓励师",6000,"2004-10-12",2,1);

SELECT * FROM emp;

## 添加外键关联 
# ALTER TABLE emp add CONSTRAINT fk_emp_dept_id FOREIGN KEY(dept_id) REFERENCES dept(id);

ALTER TABLE emp ADD CONSTRAINT fk_emp_dept_id FOREIGN KEY(dept_id) REFERENCES dept(id);


## 删除外键
# ALTER TABLE emp drop FOREIGN KEY fk_emp_dept_id

ALTER TABLE emp drop FOREIGN KEY fk_emp_dept_id;

CREATE TABLE students(
	id int PRIMARY KEY auto_increment COMMENT "主键",
	sname VARCHAR(10) COMMENT "姓名",
	no VARCHAR(10) COMMENT "学号"
) COMMENT "学生表";

DROP TABLE students;

INSERT INTO students(sname,no)  VALUES
("黛绮丝","2000100101"),
("谢逊","2000100102"),
("天正","2000100103"),
("韦一笑","2000100104");


CREATE TABLE course(
	id INT PRIMARY KEY auto_increment COMMENT "主键id",
	cnme VARCHAR(10) COMMENT "课程名称"
) COMMENT "课程表";


INSERT INTO course(cnme) VALUES
("java"),
("php"),
("mysql"),
("hadoop");


CREATE TABLE students_course(
	id INT PRIMARY KEY auto_increment COMMENT "主键",
	studentid INT NOT NULL COMMENT "学生id",
	courseid INT NOT NULL COMMENT "课程id",
	CONSTRAINT fk_courseid FOREIGN KEY(courseid) REFERENCES course(id),
	CONSTRAINT fk_studentid FOREIGN KEY(studentid) REFERENCES students(id)
) COMMENT "学生课程中间表";

INSERT INTO students_course(studentid,courseid) VALUES
(1,1),
(1,2),
(1,3),
(2,3),
(3,4);

隐式内连接

SELECT * FROM emp,dept WHERE emp.dept_id = dept.id;

显示内连接

SELECT * FROM emp INNER JOIN dept ON emp.dept_id = dept.id;

外链接

SELECT * FROM emp;

左外链接

SELECT * FROM emp LEFT OUTER JOIN dept ON emp.dept_id = dept.id;

右外连接

SELECT * FROM emp RIGHT OUTER JOIN dept ON emp.dept_id = dept.id;

自连接

SELECT e.ename,b.ename FROM emp e,emp b WHERE e.managerid = b.id;

联合查询

SELECT * FROM emp WHERE salary < 8400 UNION SELECT * FROM emp WHERE age > 40;

标量子查询

SELECT * FROM emp WHERE dept_id = (SELECT id FROM dept WHERE dname = '研发部');

mysql 高级

Linux 安装 mysql

  1. 下载 mysql 的 repo 源
$ wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm
  1. 安装 mysql-community-release-el7-5.noarch.rpm 包
sudo rpm -ivh mysql-community-release-el7-5.noarch.rpm
  • 安装这个包后,会获得两个 mysql 的 yum repo 源:/etc/yum.repos.d/mysql-community.repo,/etc/yum.repos.d/mysql-community-source.repo。
  1. 安装 mysql
sudo yum install mysql-server
  • 根据步骤安装就可以了,不过安装完成后,没有密码,需要重置密码。
  1. 重置密码,重置密码前,首先要登录
mysql -u root
  • 登录时有可能报这样的错:ERROR 2002 (HY000): Can‘t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock‘ (2),原因是/var/lib/mysql 的访问权限问题。下面的命令把/var/lib/mysql 的拥有者改为当前用户:
sudo chown -R openscanner:openscanner /var/lib/mysql
  • 假如出现
  • chown: invalid user: ‘openscanner:openscanner’

chown root /var/lib/mysql/
  1. 重启服务
service mysqld restar
  1. 设置 mysql 密码
/usr/bin/mysqladmin -u root password tungee1024Zhang

mysql 安装位置

  1. 查看 mysql 安装位置
ps -ef | grep mysql

CREATE DATABASE iblog CHARACTER SET utf8 COLLATE utf8_general_ci;

mysql 高级

mysql 字符集

  1. 查看 mysql 字符集
show variables like '%character%';
  1. 设置为 utf8
vim /etc/my.cnf
character_set_server=utf8
  1. 重启 mysql
systemctl restart mysqld.service

用户管理

  1. 创建用户
CREATE USER 'zhangsan' IDENTIFIED by 'abc123';
  1. 修改密码
ALTER USER 'zhangdezhi' IDENTIFIED by 'tungee1024Zhang';

查看存储引擎

show engines;

查看默认存储引擎

select @@default_storage_engine;

mysql 高级

索引

创建索引

create index indexName on mytable(columname(length))

分析查询

explain select * from tbl_emp;

查询索引

show index from table

创建索引

create index idx_索引名称 on article(category_id,views);
ALTER  TABLE  book  ADD  INDEX  Y (`card`);

删除索引

drop index idx_索引名称 on table()

慢查询的开启

show variables like '%slow_query_log%';

相关链接

演示地址
获取更多
源码地址

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

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

相关文章

antdv树形表格 大量tooltip等组件导致页面卡顿问题优化

vue3、ant-design-vue 4.2.3 遇到的问题&#xff1a;页面中有个展示树形数据的表格&#xff0c;默认需要全部展开&#xff0c;有一组数据量较大时页面首次渲染时非常卡顿&#xff0c;发现每次都大概用了7、8秒才完成渲染。表格展开的数据大概300条数据&#xff0c;操作列中有5…

SpringBoot框架下的服装生产管理系统

1 绪论 1.1 研究背景 当今时代是飞速发展的信息时代。在各行各业中离不开信息处理&#xff0c;这正是计算机被广泛应用于信息管理系统的环境。计算机的最大好处在于利用它能够进行信息管理。使用计算机进行信息控制&#xff0c;不仅提高了工作效率&#xff0c;而且大大的提高…

leetcode:反转字符串中的单词III

题目链接 string reverse(string s1) {string s2;string::reverse_iterator rit s1.rbegin();while (rit ! s1.rend()){s2 *rit;rit;}return s2; } class Solution { public:string reverseWords(string s) {string s1; int i 0; int j 0; int length s.length(); for (i …

2024年【金属非金属矿山(地下矿山)安全管理人员】复审考试及金属非金属矿山(地下矿山)安全管理人员在线考试

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 金属非金属矿山&#xff08;地下矿山&#xff09;安全管理人员复审考试考前必练&#xff01;安全生产模拟考试一点通每个月更新金属非金属矿山&#xff08;地下矿山&#xff09;安全管理人员在线考试题目及答案&#…

防汛可视化系统:提升应急响应能力

通过图扑可视化系统实时监测水情、雨情和地理数据&#xff0c;辅助防汛决策与调度&#xff0c;提供直观的风险预警信息&#xff0c;从而优化资源分配&#xff0c;提高防汛应急响应效率。

进程通讯方式区别(从不同角度看)

*常用到的不同主机间进程通讯&#xff1a;Socket。比如&#xff1a;host和引擎间socket指令通讯、分派和复判之间指令通讯&#xff1b; *共享内存&#xff1a;在Windows系统中&#xff0c;共享内存的实现通常有以下几种方式&#xff1a; 1.内存映射文件(最常用)&#xff1a;(…

linux上的smb共享文件夹

需求描述 公司的打印机使用扫描功能的时候&#xff0c;需要发送大量文件。然鹅公司的电脑都是加入了AzureAD的&#xff0c;不能在公司电脑上简单设置共享。好在公司有很多阿里云上的服务器&#xff0c;Linux和Windows的都有&#xff0c;所以就来尝试用阿里云的服务器来进行smb…

正点原子学习笔记之汇编LED驱动实验

1 汇编LED原理分析 为什么要写汇编     需要用汇编初始化一些SOC外设     使用汇编初始化DDR、I.MX6U不需要     设置sp指针&#xff0c;一般指向DDR&#xff0c;设置好C语言运行环境 1.1 LED硬件分析 可以看到LED灯一端接高电平&#xff0c;一端连接了GPIO_3上面…

华捷艾米3D结构光模组测试

1.测试项目总览 本次测试主要测试以下几个方面&#xff1a; 模组的基本属性和SDK基本功能&#xff1b;华捷艾米提供的人脸防伪算法性能&#xff1b;模组的逆光性能。 2.基本属性和SDK基本功能 图像属性&#xff1a; 模组提供的3d深度数据标称分辨率最大为640x480&#xff0…

软件测试学习笔记丨MongoDB

本文转自测试人社区&#xff0c;原文链接&#xff1a;https://ceshiren.com/t/topic/32359 一、MangoDB数据库 1.1 关系与非关系 1.1.1 关系型数据库 关系型数据库 MySQL&#xff0c;Oracle&#xff0c; SQLServer&#xff0c; Access…SQL&#xff08;结构化查询语句&#x…

[图形学]smallpt代码详解(上)

一、简介 本文介绍了著名的99行代码实现全局光照的光线跟踪代码smallpt。 包括对smallpt的功能介绍、编译运行介绍&#xff0c;和对代码的详细解释。希望能够帮助读者更进一步的理解光线跟踪。 二、smallpt介绍 1.smallpt是什么 smallpt(small Path Tracing) 是一个全局光照…

微信服务号灰度测试折叠,看谁该慌了?

2024年国庆节前夕&#xff0c;突然发现我的微信的会话列表清静了不少。 紧接着&#xff0c;我马上就慌了... &#x1f914;怎么“丰巢快递”不见了&#xff0c;我要找取件码 &#x1f914;我的flomo浮墨笔记公众号呢&#xff1f;我要记笔记啊 &#x1f914;这个月怎么没有…

3个步骤轻松集成Push Kit,实现App消息推送

推送通知作为App重要的消息传递工具&#xff0c;广泛应用于电子商务、社交媒体、旅游交通等领域的通知场景。比如当应用有新功能或安全补丁时&#xff0c;系统将推送消息提醒用户及时更新&#xff1b;如果是航班出行类的应用&#xff0c;会发送最新的班次时间表给用户&#xff…

44 C 语言输入输出流、scanf 与 printf 函数详解、清除输入缓冲区

目录 1 文件基本介绍 1.1 文件的主要功能 1.2 输入输出流 2 C 语言中的输入与输出 2.1 输入 2.2 输出 2.3 标准文件与文件指针 3 scanf() 函数详解 3.1 功能描述 3.2 函数原型 3.3 常用格式说明符 3.4 返回值 3.5 注意事项 3.5.1 处理空白字符 3.5.2 防止缓冲区…

基于K-means和RFM模型的电商行业用户画像及商品个性化推荐研究

文章目录 有需要本项目的代码或文档以及全部资源&#xff0c;或者部署调试可以私信博主项目介绍数据概览数据预处理可视化过程展示RFM模型K-means及改进算法每文一语 有需要本项目的代码或文档以及全部资源&#xff0c;或者部署调试可以私信博主 项目介绍 本研究基于阿里天池…

玩转OurBMC第十一期:kdump原理分析(上)

栏目介绍&#xff1a;“玩转OurBMC”是OurBMC社区开创的知识分享类栏目&#xff0c;主要聚焦于社区和BMC全栈技术相关基础知识的分享&#xff0c;全方位涵盖了从理论原理到实践操作的知识传递。OurBMC社区将通过“玩转OurBMC”栏目&#xff0c;帮助开发者们深入了解到社区文化、…

echarts 中添加图片/图标

let myChart echarts.init(this.$refs.chartOne); // 注意这里的 ref 引用 myChart.setOption({ tooltip: {trigger: item,formatter: {b} : {c}},series: [{type: pie,radius: 50%,data: this.swjList,label: {formatter: (params) > {if (params.name ! ) {let percent…

代码随想录 -- 回溯 -- N皇后

51. N 皇后 - 力扣&#xff08;LeetCode&#xff09; 题解&#xff1a; 从抽象树中可以看出递归的层数取决于棋盘的行数&#xff0c;for循环的次数取决于棋盘的列数。 递归参数&#xff1a;存放当前棋盘的数组chessboard、当前行row、总行数n。递归终止条件&#xff1a;当 ro…

【C++网络编程】(二)Linux平台下UDP客户/服务端程序

Linux平台下UDP客户/服务端程序 图片来源&#xff1a;https://subingwen.cn/linux/udp/ UDP服务器无法直接检测客户端断开连接。 UDP 服务端 server.cpp #include <iostream> #include <cstdlib> // std::exit #include <cstring> // memset #i…

在线制作PPT图表!这个好用轻量的ppt软件值得推荐!

ppt图表怎么制作&#xff1f; ppt是一种可以承载多种内容形式的媒介&#xff0c;我们在一个ppt页面中添加文本、形状、图片、视频、图表、思维导图等&#xff0c;对于其中的图表&#xff0c;在ppt中应该怎么制作呢&#xff1f; Office Powerpoint是很多人非常熟悉的演示软件&…