sqlite3 学习笔记

news2025/1/29 14:10:44

文章目录

  • 前言
  • SQL的概念
  • 与表格相关的操作
    • i.创建表格(增)
    • ii 删除表格(删)
    • iii 更改表格(改)
    • iv 查询表格(查)
  • 与记录相关的操作
    • i 插入记录
    • ii 删除记录
    • iii 查询记录
    • iv 修改记录
  • Linux中使用sqlite3

前言

SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统。

SQLite 非常适合用于嵌入式系统、物联网设备、移动应用程序和客户端应用程序,它不需要服务器,简单易用。

SQL的概念

SQLite3是一个数据库,而SQL是一种编程语言。我们需要使用SQL来操作SQLite3数据库。

SQL语言包括四种主要程序设计语言类别的语句:数据定义语言(DDL),数据查询语言(DQL),数据操作语言(DML),数据控制语言(DCL)。

SQL语言中完成核心功能的9个动词

SQL功能动词
数据定义DDCreate、Drop(删除)、Alter(修改)
数据查询DQSelect
数据操纵DMInsert(插入)、Update(更新)、Delete(删除)
数据控制DCGrant(授权)、Revoke(撤销授权)

SQLite3 是一个 轻量级的嵌入式数据库系统,它仅实现了 SQL 标准的一个子集。即SQLite3中只能使用部分SQL语句,而且不支持数据控制语句(DCL)

  • SQLITE3支持的 DML关键字有
    • CREATE:创建一个新的表,一个表的视图,或者数据库中的其他对象
    • ALTER:修改数据库中的某个已有的数据库对象,比如一个表
    • DROP:删除整个表,或者表的视图,或者数据库中的其他对象
  • SQLITE3支持的 DDL关键字有
    • INSERT:创建一条记录
    • UPDATE:修改记录
    • DELETE:删除记录
  • SQLITE3支持的 DQL关键字有
    • SELECT:从一个或多个表中检索某些记录

与表格相关的操作

i.创建表格(增)

基本语法

CREATE TABLE IF NOT EXISTS table_name (
    column1_name data_type [constraints],
    column2_name data_type [constraints],
    ...
    columnN_name data_type [constraints]
);

例子
-- 创建一个名为 "users" 的表格
CREATE TABLE IF NOT EXISTS users (
    user_id INT PRIMARY KEY,
    username TEXT NOT NULL,
    email TEXT UNIQUE,
    password TEXT NOT NULL
);
  1. CREATE TABLE: 创建表格的关键字。
  2. IF NOT EXISTS: 可以避免出现添加已存在数据表的SQL错误信息
  3. table_name: 要创建的表格的名称。
  4. column_name: 列的名称。
  5. data_type: 数据类型,例如 INT, TEXT, REAL, BLOB 等。
  6. constraints: 约束,例如 PRIMARY KEY, UNIQUE, NOT NULL, FOREIGN KEY 等。

列(字段)相关的配置

每个列(字段)都有对应的配置,如列名称,列数据类型,类约束,列默认值等。列配置的具体内容如下:

  1. 列的数据类型

    • INT: 整数。
    • TEXT: 文本字符串。
    • REAL: 浮点数。
    • BLOB: 二进制数据。专门用于存放图像、视频动画和其他类型的文件等。
    • DATE: 日期。
    • DATETIME: 日期和时间。
  2. 列的默认值
    DEFAULT 关键字用于为表格中的列设置默认值。当插入新记录时(注意:这不是创建表时存在的默认值),如果该列的值没有被明确指定,则会自动使用默认值。
    CREATE TABLE table_name ( column_name data_type DEFAULT default_value, ... );
    DEFAULT: 设置默认值的关键字。
    default_value: 默认值,可以是常量、表达式、函数等

  3. 列(字段)的约束:

    • PRIMARY KEY: 主键,用于唯一标识每条记录。
      在数据表中能够唯一识别记录的字段,都会被人们设置为主键,如“学号”字段。
      当某个字段被设置为主键后,该字段中就不能再有重复值,也不能有空值,数据库管理系统将强制执行这一规则,这就是主键约束。
    • FOREIGN KEY: 外键,用于建立两个表格之间的关系。
  4. 列的索引(略读)

    • 索引 (INDEX):定义索引,用于提高查询效率。除表之外,索引是大型数据库系统中最重要的对象之一!索引是一种树形结构,如果使用正确的话,可以减少定位和查询数据所需的IO操作。

    • 索引的用途
      索引类似于书籍的目录,它让数据库系统不必扫描整个表就能快速定位到需要的数据行。 如果一个查询的 WHERE 子句中包含了索引列,数据库系统可以快速地找到匹配的行,从而提高查询速度。 索引的创建需要消耗磁盘空间和一些额外的维护成本,但是对查询速度的提升通常是值得的。

    • 如何创建索引
      使用 CREATE INDEX 语句来创建索引。 以下是 SQLite 中创建索引的语法:
      CREATE INDEX 索引名 ON 表名 (列名1, 列名2, ...);
      索引名: 为索引取一个名称。
      表名: 要为其创建索引的表。
      列名1, 列名2, ...: 要索引的列。 多个列可以同时索引(复合索引),提高多条件查询的效率。

      • 示例:
        假设有一个名为 products 的表,包含 idnameprice 列。 你想在 name 列上创建索引:
        CREATE INDEX idx_product_name ON products (name);
        或者,你想在 nameprice 列上创建复合索引:
        CREATE INDEX idx_product_name_price ON products (name, price);

ii 删除表格(删)

使用drop删除表,会将表彻底的删除掉,包括表结构和表数据。

DROP TABLE table_name;

例子
-- 删除一个名为 "users" 的表格
DROP TABLE users;

用户若只是想删除表的数据
可以通过 删除记录的SQL语句 DELETE FROM 表名; 来实现相同的相关

iii 更改表格(改)

SQLite只支持部分的SQL更改表格的语句。支持的操作有:

  • 修改表名
  • 添加列

SQLite 不直接支持的修改表结构的操作有:

  • 删除列: SQLite 不直接支持删除列。 要删除列,你需要创建一个新的表,只包含你想要保留的列,然后将数据从旧表复制到新表,最后删除旧表,并将新表改名为旧表的名称。
  • 修改主键: SQLite 不直接支持修改主键。 通常需要创建新的表,添加新的主键,并复制数据。

修改表名:(SQLite支持)

ALTER TABLE old_table_nameRENAME TO new_table_name;

例子:
-- 名为 "users_new " 的表格,修改名字为“users”
ALTER TABLE users_new RENAME TO users;
  • old_table_name:要修改的表格的旧名称。
  • new_table_name:要修改的表格的新名称。

添加列:(SQLite支持)

ALTER TABLE table_name ADD column_name data_type [column_attributes];

例子:
-- 名为 "users" 的表格,增加一列,列名称为job ,列数据类型为TEXT,约束为NOT NULL,默认值为 default_value
ALTER TABLE users ADD job TEXT NOT NULL DEFAULT default_value;
  • table_name:要修改的表格名。
  • column_name:要添加的列名。
  • data_type:新列的数据类型。
  • column_attributes:可选的列属性,例如 NOT NULL、DEFAULT 等。

删除列:(SQLite间接支持)

SQLite虽然不可以直接通过DROP来删除列,但是却可通过间接的方法实现,如下。

假设你有一个名为 users 的表,包含 id (INTEGER) 和 name (TEXT) 列。

ALTER TABLE users ADD job TEXT NOT NULL DEFAULT default_value;

删除 job 列 (间接方法):

-- 创建一个新的表,不包含 email 列
CREATE TABLE users_new (id INTEGER, name TEXT);

-- 将数据从旧表复制到新表
INSERT INTO users_new SELECT id, name FROM users;

-- 删除旧表
DROP TABLE users;

-- 将新表改名为旧表的名称
ALTER TABLE users_new RENAME TO users;

iv 查询表格(查)

在linux系统中,使用sqlite3命令进入数据库后,可以通过.schema来查看所有的表格信息

sqlite>.schema 
CREATE TABLE IF NOT EXISTS users (
    user_id INT PRIMARY KEY,
    username TEXT NOT NULL,
    email TEXT UNIQUE,
    password TEXT NOT NULL
);

您可以使用 SQLIte 命令中的 .tables 命令来验证表是否已成功创建,该命令用于列出附加数据库中的所有表。

sqlite>.tables
users 

与记录相关的操作

i 插入记录

在 SQLite 数据库中,用户可以使用 INSERT 语句来添加新的记录到表中。 INSERT 语句有多种形式,取决于你如何指定要插入的值。

  1. 指定所有列的值:

这是最常用的方法,你需要指定表中的每一列的值,并按照列的顺序排列。

INSERT INTO 表名 (列名1, 列名2, 列名3, ...) VALUES (值1, 值2, 值3, ...);

例子
假设你有一个名为 `users` 的表,包含 `id` (INTEGER), `name` (TEXT), `age` (INTEGER) 列。 要添加一个新的用户记录:
INSERT INTO users (id, name, age) VALUES (1, 'John Doe', 30);
  • 表名: 要插入记录的表名。
  • 列名1, 列名2, 列名3, …: 表中的列名,必须与 VALUES 子句中的值一一对应。
  • 值1, 值2, 值3, …: 要插入的值,数据类型必须与相应的列匹配。
  1. 省略列名 (自动推断):

如果你要为表中的所有列都赋值,你可以省略列名,只需要提供值即可。 但是,值的顺序必须与表中列的顺序一致。

INSERT INTO 表名 VALUES (值1, 值2, 值3, ...);

示例 (延续上例):
INSERT INTO users VALUES (2, 'Jane Doe', 25);
  1. 使用默认值:

如果你想使用列的默认值(如果列定义了默认值),你可以省略该列的值。 但是,你必须至少提供一个列的值。

示例 (假设 age 列有默认值 20):

INSERT INTO users (id, name) VALUES (3, 'Peter Pan');
  1. 插入多行记录:

你可以使用单一 INSERT 语句插入多行记录:

INSERT INTO 表名 (列名1, 列名2, ...)
VALUES (值1, 值2, ...),
       (值3, 值4, ...),
       (值5, 值6, ...);

省略列名也可以。

INSERT INTO 表名
VALUES (值1, 值2, ...),
       (值3, 值4, ...),
       (值5, 值6, ...);

示例:

INSERT INTO users (id, name, age)
VALUES (4, 'Alice', 28),
       (5, 'Bob', 35);

注意事项:

  • 数据类型匹配:
    确保你提供的值与表中列的数据类型匹配。 否则,插入操作可能会失败。
  • 主键冲突:
    如果你有主键约束,确保插入的主键值是唯一的。 否则,插入操作会失败,并返回错误。
  • 自动递增:
    如果你的表中有一列定义为 AUTOINCREMENT,则该列的值会自动生成。 你不需要在 INSERT 语句中提供该列的值。
  • 事务处理:
    如果你要插入多行记录,或者需要将插入操作与其他数据库操作组合在一起,建议使用事务处理 (BEGIN TRANSACTION, COMMIT, ROLLBACK) 来确保数据的一致性。

ii 删除记录

在 SQLite 数据库中,用户可以使用 DELETE 语句来删除表中的记录。 DELETE 语句的基本语法如下:

DELETE FROM 表名
WHERE 条件;
  • DELETE FROM 表名: 指定要删除记录的表名。

  • WHERE 条件: 指定删除哪些记录。 这部分是必须的,否则会删除表中的所有记录! 条件可以使用各种比较运算符(=, !=, >, <, >=, <=),ANDOR 运算符组合条件,以及其他 SQL 函数,如LIKEBETWEEN xx AND xx
    具体的运用请看示例。

示例:

假设你有一个名为 users 的表,包含 id、name 和 email 列。

  • 删除 id 为 1 的记录:
DELETE FROM users
WHERE id = 1;
  • 删除 name 为 ‘John Doe’ 的记录:
DELETE FROM users
WHERE name = 'John Doe';
  • 删除 email 包含 ‘@example.com’ 的记录:
DELETE FROM users
WHERE email LIKE '%@example.com%';
  • 删除 id 在 1 到 5 之间的记录(注意,这是闭区间,包含了id=1和id=5的记录):
DELETE FROM users
WHERE id BETWEEN 1 AND 5;
  • 删除多条件: 删除 id 为 1 并且 name 为 ‘Alice’ 的记录:
DELETE FROM users
WHERE id = 1 AND name = 'Alice';
  • 删除全部记录
DELETE FROM users;

重要提示:

  • 谨慎使用 DELETE 语句! 没有 WHERE 子句的 DELETE 语句会删除表中的所有记录。 在执行 DELETE 语句之前,务必仔细检查你的 WHERE 子句,确保它只删除你想要删除的记录。

  • 备份数据库: 在执行重要的 DELETE 操作之前,最好先备份你的数据库,以防万一发生错误。

  • 事务处理: 对于多个 DELETE 操作或与其他操作一起进行 DELETE 操作,建议使用事务处理 (BEGIN TRANSACTION, COMMIT, ROLLBACK) 来确保数据的一致性。 例如:

BEGIN TRANSACTION;
DELETE FROM users WHERE id = 1;
DELETE FROM orders WHERE user_id = 1;
COMMIT;  -- or ROLLBACK;

iii 查询记录

在 SQLite 数据库中,用户可以使用 SELECT 语句来查询表中的记录。 SELECT 语句有很多种形式,可以满足各种查询需求。

  1. 查询所有列的所有记录:

这是最简单的查询方式,它会返回表中所有列的所有记录。

SELECT * FROM 表名;

例如,如果你的表名为 users,则查询语句为:

SELECT * FROM users;
  1. 查询指定的列:

你可以选择只查询表中的某些列,而不是所有列。

SELECT 列名1, 列名2, ... FROM 表名;

例如,要查询 users 表中的 nameemail 列:

SELECT name, email FROM users;
  1. 使用 WHERE 子句过滤记录:

你可以使用 WHERE 子句来过滤记录,只返回满足特定条件的记录。

SELECT * FROM 表名 WHERE 条件;

例如,要查询 users 表中 id 为 1 的记录:

SELECT * FROM users WHERE id = 1;

用户可以使用各种比较运算符(=, !=, >, <, >=, <=),ANDOR 运算符组合条件,以及 LIKE 运算符进行模式匹配。
查询 age 大于 25 的用户:SELECT * FROM users WHERE age > 25;
查询 name 包含 “John” 的用户:SELECT * FROM users WHERE name LIKE '%John%';
查询 age 大于 25email 包含 “@example.com” 的用户:SELECT * FROM users WHERE age > 25 AND email LIKE '%@example.com%';

  1. 使用 ORDER BY 子句排序记录:

用户可以使用 ORDER BY 子句来对查询结果进行排序。

SELECT * FROM 表名 ORDER BY 列名 [ASC|DESC];

ASC 表示升序排序(默认),DESC 表示降序排序。

例如,要按 age 升序排序查询结果:

SELECT * FROM users ORDER BY age ASC;

要按 name 降序排序:

SELECT * FROM users ORDER BY name DESC;
  1. 使用 LIMIT 子句限制返回的记录数:
    你可以使用 LIMIT 子句来限制返回的记录数。
SELECT * FROM 表名 LIMIT n;

n 表示要返回的记录数。

例如,要只返回前 10 条记录:

SELECT * FROM users LIMIT 10;

你还可以指定起始位置和返回的记录数:

SELECT * FROM 表名 LIMIT m, n;

m 表示起始位置(从 0 开始),n 表示返回的记录数。 例如,返回从第 5 条记录开始的 10 条记录:

SELECT * FROM users LIMIT 4, 10;
  1. 使用 OFFSET 子句 (与LIMIT配合使用):
    OFFSET 用于跳过指定数量的行数,之后才开始返回结果,常与 LIMIT 子句一起使用。
SELECT * FROM 表名 LIMIT n OFFSET m;

这些是 SQLite 中 SELECT 语句的一些基本用法,你可以根据实际需要组合使用这些功能来实现更复杂的查询。 记住在编写复杂查询时,使用括号来明确操作的优先级。

  1. 使用DISTINCT去除重复的信息
    DISTINCT 关键字用于在 SQL 查询结果中去除重复的行。 它只返回唯一的值。 DISTINCT 放在要返回的列的列表的前面。
SELECT DISTINCT 列名1, 列名2, ...
FROM 表名
[WHERE 条件];
  • DISTINCT: 关键字,表示只返回唯一的值。
  • 列名1, 列名2, ...: 要选择的列。 如果省略,则表示对所有列进行去重。
  • FROM 表名: 指定要查询的表。
  • WHERE 条件 (可选): 用于过滤记录,在去除重复行之前进行筛选。

前面介绍了SELECT语句最基本的语法格式,实际上SELECT语句的完整语法格式要比其复杂得多。

下面将经常用到的带有主要子句的语法格式归纳如下

SELECT 	[DISTINCTIALL] 	select list
FROM					table source
[WHERE					search condition]
[GROUPBY				group_by_expression]
[HAVING					searching_condition]
[ORDER BY				order_expression[ASC|DESC]]

假设SELECT语句带有所有的子句,则其执行顺序如下:
(1)FROM 子句。
(2)WHERE 子句。
(3)GROUP BY 子句。
(4)HAVING 子句。
(5)SELECT 子句。
(6)ORDER BY 子句

iv 修改记录

在 SQLite 数据库中,用户可以使用 UPDATE 语句来修改表中的记录。 UPDATE 语句的基本语法如下:

UPDATE 表名
SET 列名1 = 新值1, 列名2 = 新值2, ...
WHERE 条件;
  • UPDATE 表名: 指定要修改记录所在的表名。
  • SET 列名1 = 新值1, 列名2 = 新值2, ...: 指定要修改的列以及它们的新值。 可以用逗号分隔多个列和值。
  • WHERE 条件: 指定要修改哪些记录。 这部分是必须的,否则会更新表中的所有记录! 条件可以使用各种比较运算符(=, !=, >, <, >=, <=),ANDOR 运算符组合条件,以及其他 SQL 函数。

示例:

假设你有一个名为 users 的表,包含 idnameemailage 列。

  1. 修改 id 为 1 的用户的 nameage:
UPDATE users
SET name = 'John Doe Updated', age = 35
WHERE id = 1;
  1. 修改 email 包含 ‘@example.com’ 的用户的 age:
UPDATE users
SET age = 40
WHERE email LIKE '%@example.com%';

修改多个列,多条件更新: 修改 id 为 2 并且 name 为 ‘Jane Doe’ 的用户的 emailage

UPDATE users
SET email = 'jane.doe.updated@example.com', age = 30
WHERE id = 2 AND name = 'Jane Doe';

注意点:

  • 谨慎使用 UPDATE 语句! 没有 WHERE 子句的 UPDATE 语句会更新表中的所有记录。 在执行 UPDATE 语句之前,务必仔细检查你的 WHERE 子句,确保它只更新你想要更新的记录。

  • 备份数据库: 在执行重要的 UPDATE 操作之前,最好先备份你的数据库,以防万一发生错误。

  • 事务处理: 对于多个 UPDATE 操作或与其他操作一起进行 UPDATE 操作,建议使用事务处理 (BEGIN TRANSACTION, COMMIT, ROLLBACK) 来确保数据的一致性。

  • 数据类型: 确保新值的数据类型与要更新的列的数据类型匹配。 如果不匹配,更新操作可能会失败或导致数据错误。

Linux中使用sqlite3

待续

参考内容:
菜鸟教程-sqlite3

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

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

相关文章

FPGA 使用 CLOCK_LOW_FANOUT 约束

使用 CLOCK_LOW_FANOUT 约束 您可以使用 CLOCK_LOW_FANOUT 约束在单个时钟区域中包含时钟缓存负载。在由全局时钟缓存直接驱动的时钟网段 上对 CLOCK_LOW_FANOUT 进行设置&#xff0c;而且全局时钟缓存扇出必须低于 2000 个负载。 注释&#xff1a; 当与其他时钟约束配合…

RabbitMQ模块新增消息转换器

文章目录 1.目录结构2.代码1.pom.xml 排除logging2.RabbitMQConfig.java3.RabbitMQAutoConfiguration.java 1.目录结构 2.代码 1.pom.xml 排除logging <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/PO…

机器学习:支持向量机

支持向量机&#xff08;Support Vector Machine&#xff09;是一种二类分类模型&#xff0c;其基本模型定义为特征空间上的间隔最大的广义线性分类器&#xff0c;其学习策略便是间隔最大化&#xff0c;最终可转化为一个凸二次规划问题的求解。 假设两类数据可以被 H x : w T x…

Spring Boot(6)解决ruoyi框架连续快速发送post请求时,弹出“数据正在处理,请勿重复提交”提醒的问题

一、整个前言 在基于 Ruoyi 框架进行系统开发的过程中&#xff0c;我们常常会遇到各种有趣且具有挑战性的问题。今天&#xff0c;我们就来深入探讨一个在实际开发中较为常见的问题&#xff1a;当连续快速发送 Post 请求时&#xff0c;前端会弹出 “数据正在处理&#xff0c;请…

2023年版本IDEA复制项目并修改端口号和运行内存

2023年版本IDEA复制项目并修改端口号和运行内存 1 在idea中打开server面板&#xff0c;在server面板中选择需要复制的项目右键&#xff0c;点击弹出来的”复制配置…&#xff08;Edit Configuration…&#xff09;“。如果idea上没有server面板或者有server面板但没有springbo…

微信小程序怎么制作自己的小程序?手把手带你入门(适合新手小白观看)

对于初学者来说&#xff0c;制作一款微信小程序总感觉高大上&#xff0c;又害怕学不会。不过&#xff0c;今天我就用最简单、最有耐心的方式&#xff0c;一步一步给大家讲清楚!让你知道微信小程序的制作&#xff0c;居然可以这么轻松(希望你别吓跑啊!)。文中还加了实战经验&…

EventBus事件总线的使用以及优缺点

EventBus EventBus &#xff08;事件总线&#xff09;是一种组件通信方法&#xff0c;基于发布/订阅模式&#xff0c;能够实现业务代码解耦&#xff0c;提高开发效率 发布/订阅模式 发布/订阅模式是一种设计模式&#xff0c;当一个对象的状态发生变化时&#xff0c;所有依赖…

vim如何设置自动缩进

:set autoindent 设置自动缩进 :set noautoindent 取消自动缩进 &#xff08;vim如何使设置自动缩进永久生效&#xff1a;vim如何使相关设置永久生效-CSDN博客&#xff09;

LongLoRA:高效扩展大语言模型上下文长度的微调方法

论文地址&#xff1a;https://arxiv.org/abs/2309.12307 github地址&#xff1a;https://github.com/dvlab-research/LongLoRA 1. 背景与挑战 大语言模型&#xff08;LLMs&#xff09;通常在预定义的上下文长度下进行训练&#xff0c;例如 LLaMA 的 2048 个 token 和 Llama2 的…

NoSQL使用详解

文章目录 NoSQL使用详解一、引言二、NoSQL数据库的基本概念三、NoSQL数据库的分类及使用场景1. 键值存储数据库示例代码&#xff08;Redis&#xff09;&#xff1a; 2. 文档存储数据库示例代码&#xff08;MongoDB&#xff09;&#xff1a; 3. 列存储数据库4. 图数据库 四、使用…

《FreqMamba: 从频率角度审视图像去雨问题》学习笔记

paper&#xff1a;FreqMamba: Viewing Mamba from a Frequency Perspective for Image Deraining GitHub&#xff1a;GitHub - aSleepyTree/FreqMamba 目录 摘要 1、介绍 2、相关工作 2.1 图像去雨 2.2 频率分析 2.3 状态空间模型 3、方法 3.1 动机 3.2 预备知识 3…

试用ChatGPT开发一个大语言模型聊天App

参考官方文档&#xff0c;安装android studio https://developer.android.com/studio/install?hlzh-cn 参考这个添加permission权限&#xff1a; https://blog.csdn.net/qingye_love/article/details/14452863 参考下面链接完成Android Studio 给项目添加 gradle 依赖 ht…

第30周:文献阅读

目录 摘要 Abstract 文献阅读 问题引入 方法论 堆叠集成模型 深度学习模型 创新点 堆叠模型 敏感性和不确定性分析 优化模型 实验研究 数据集 水质指数WQI的计算 模型的构建与训练 模型性能评估 敏感性和不确定性分析 结论 摘要 本文聚焦于利用深度学习算…

The just sharing principle: advice for advice givers

原文 A while ago I wrote about how Only you know what’s best for your application. That’s because only you fully understand the context within which you are making technical decisions. Any advice need to filtered through that context in order to determi…

【PVE】PVE部署磁盘阵列

什么是磁盘阵列&#xff1f; 磁盘阵列是一种存储技术&#xff0c;通过将多个物理磁盘组合成一个逻辑存储单元&#xff0c;提供数据冗余和/或性能提升。它的核心目的是提高数据的可靠性、可用性和访问速度。磁盘阵列可以由专用硬件或软件实现。 PVE部署磁盘阵列并加入虚拟机 …

FlinkSql使用中rank/dense_rank函数报错空指针

问题描述 在flink1.16(甚至以前的版本)中&#xff0c;使用rank()或者dense_rank()进行排序时&#xff0c;某些场景会导致报错空指针NPE(NullPointerError) 报错内容如下 该报错没有行号/错误位置&#xff0c;无法排查 现状 目前已经确认为bug&#xff0c;根据github上的PR日…

Ubuntu介绍、与centos的区别、基于VMware安装Ubuntu Server 22.04、配置远程连接、安装jdk+Tomcat

目录 ?编辑 一、Ubuntu22.04介绍 二、Ubuntu与Centos的区别 三、基于VMware安装Ubuntu Server 22.04 下载 VMware安装 1.创建新的虚拟机 2.选择类型配置 3.虚拟机硬件兼容性 4.安装客户机操作系统 5.选择客户机操作系统 6.命名虚拟机 7.处理器配置 8.虚拟机内存…

一个基于Python+Appium的手机自动化项目~~

本项目通过PythonAppium实现了抖音手机店铺的自动化询价&#xff0c;可以直接输出excel&#xff0c;并带有详细的LOG输出。 1.excel输出效果: 2. LOG效果: 具体文件内容见GitCode&#xff1a; 项目首页 - douyingoods:一个基于Pythonappium的手机自动化项目&#xff0c;实现了…

ubuntu 更新24LTS中断导致“系统出错且无法恢复,请联系系统管理员”

22LTS to 24LTS 更新过程中手jian把更新程序controlC导致的。 解决 目前企图完成更新来恢复&#xff0c;重启后有软件包冲突&#xff0c;sudo apt upgrade报冲突。无法进行。 将原来source.list重新 sudo dpkg --configure -a sudo apt install -f 这些都不管用。还是显示gno…

(2025,DeepSeek-R1-Zero,DeepSeek-R1,两阶段强化学习,两阶段监督微调,蒸馏,冷启动数据)通过强化学习激励 LLM 的推理能力

DeepSeek-R1: Incentivizing Reasoning Capability in LLMs via Reinforcement Learning 目录 0. 摘要 1. 简介 1.1 贡献 1.2 评测结果总结 2. 方法 2.1 概述 2.2 DeepSeek-R1-Zero&#xff1a;基础模型上的强化学习 2.2.1. 强化学习算法 2.2.2. 奖励建模 2.2.3. 训练…