Mariadb操作命令指南

news2024/11/25 12:59:06

MariaDB简介

​ 以下内容仅是站长或网友个人学习笔记、总结和研究收藏。不保证正确性,因使用而带来的风险与本站无关!

数据库应用程序与主应用程序分开存在,并存储数据集合。 每个数据库都使用一个或多个API来创建,访问,管理,搜索和复制它所包含的数据。

数据库也使用非关系数据源,如对象或文件。 然而,数据库证明了大数据集的最佳选择,这些数据集将受到缓慢的检索和其他数据源的写入的影响。

关系数据库管理系统(RDBMS)将数据存储在各种表中。这些表之间的关系是使用主键和外键建立的。

RDBMS提供以下功能 -

  • 它们使您能够使用表,列和索引来实现数据源。
  • 它们确保跨多行表的引用的完整性。
  • 它们自动更新索引。
  • 它们解释SQL查询和操作来处理或从表中获取数据。

RDBMS术语

在开始讨论MariaDB之前,让我们回顾一下与数据库相关的一些术语。

  • 数据库 - 数据库是由包含相关数据的表组成的数据源。
  • - 表示电子表格,是包含行列数据的矩阵。
  • - 表示数据元素的列是保存一种类型的数据的结构; 例如,发货日期。
  • - 行是结构分组的相关数据; 例如,客户的数据。 它也被称为元组,记录或记录。
  • 冗余 - 这个术语是指两次存储数据以加速系统数据的访问。
  • 主键 - 这是指唯一的识别值。 该值不能在表中出现两次,并且只有一行与其关联。
  • 外键 - 外键用作两个表之间的连接。
  • 复合键 - 复合键或复合键是引用多个列的键。由于列缺乏唯一的数量,它指的是多列。
  • 索引 - 索引实际上与书籍的索引目录类似相同,用于加快查找数据。
  • 引用完整性 - 此术语是指确保所有外键值指向现有行。

MariaDB数据库

MariaDB是MySQL原始开发人员创建的一个MySQL的流行分支。它源于与MySQL被Oracle收购有关的担忧。它支持小数据处理任务和企业需求。 它的目标是成为MySQL的替代品,只需要简单地卸载MySQL并安装MariaDB。MariaDB提供了与MySQL相同的功能。

MariaDB的主要特点

MariaDB的重要功能是 -

  • 所有MariaDB都在GPL,LGPL或BSD使用协议之下发布。
  • MariaDB包含多种存储引擎,包括高性能存储引擎,用于与其他RDBMS数据源一起工作。
  • MariaDB使用标准和流行的查询语言。
  • MariaDB在许多操作系统上运行,并支持各种编程语言。
  • MariaDB提供对PHP的支持,PHP是最流行的Web开发语言之一。
  • MariaDB提供Galera群集技术。
  • MariaDB还提供许多在MySQL中不可用的操作和命令,并消除/取代影响性能的消极因素。
MariaDB入门

在开始本教程之前,请确保您对PHP和SQL的一些基本知识。

本指南着重介绍如何在Windows 10环境中使用MariaDB,因此我们的示例对于MariaDB/PHP开发人员非常有用。

如果您不熟悉或需要查看PHP,强烈建议您阅读学习我们的PHP教程。

MariaDB数据类型

​ 以下内容仅是站长或网友个人学习笔记、总结和研究收藏。不保证正确性,因使用而带来的风险与本站无关!

以下是MariaDB中的数据类型列表:

  • 字符串数据类型
  • 数字数据类型
  • 日期/时间数据类型
  • 大对象数据类型

下面我们来一个一个地汇总列出。

字符串数据类型

数据类型语法最大长度描述
char(size)最大长度为255个字符。size是要存储的字符数。固定长度的字符串。使用空格填充右边与size大小相等的字符。
varchar(size)最大size255个字符。size是要存储的字符数。可变长度的字符串。
tinytext(size)最大size255个字符。size是要存储的字符数。
text(size)最大size65535个字符。size是要存储的字符数。
mediumtext(size)最大size16777215个字符。size是要存储的字符数。
longtext(size)最大尺寸4GB4,294,967,295个字符。size是要存储的字符数。
binary(size)最大size255个字符。size是要存储的二进制字符的数量。 固定长度的字符串。 空格填充右边与size相等的字符数。

日期时间数据类型

数据类型语法最大长度描述
date取值范围从"1000-01-01""9999-12-31"显示格式为:'yyyy-mm-dd'
datetime取值范围从"1000-01-01 00:00:00""9999-12-31 23:59:59"显示格式为:'yyyy-mm-dd hh:mm:ss'
timestamp(m)值范围从'1970-01-01 00:00:01' utc到'2038-01-19 03:14:07' utc。显示格式为:'yyyy-mm-dd hh:mm:ss'
time值范围从'-838:59:59''838:59:59'显示格式为:'hh:mm:ss'
year[(2/4)]年份数值为2位或4位数。默认是4位数字值。

数字数据类型

数据类型语法最大长度
bit非常小的整数值,相当于tinyint(1)。有符号值范围从-128127,无符号值范围从0255
tinyint(m)非常小的整数值。有符号值范围从-128127。无符号值范围从0255
smallint(m)小型整数值。有符号值范围从-3276832767。无符号值范围从065535
mediumint(m)中等大小的整数值。有符号值范围从-83886088388607。无符号值范围从016777215
int(m)标准整数值。有符号值范围从-21474836482147483647。无符号值范围从04294967295
integer(m)标准整数值。有符号值范围从-21474836482147483647。无符号值范围从04294967295
bigint(m)大整数值。有符号的值范围从-92233720368547758089223372036854775807。无符号值范围从018446744073709551615
decimal(m,d)解压后的定点数字值。如果没有指定,m默认为10,如果d没有指定,默认为0
dec(m,d)解压后的定点数值。如果未指定,则m默认为10。如果没有指定,d默认为0
numeric(m,d)解压后的定点数值。如果没有指定,m默认为10,如果没有指定,d默认为0
fixed(m,d)解压后的定点数值。如果未指定,则m默认为10。如果没有指定,d默认为0
float(m,d)单精度浮点数。
double(m,d)双精度浮点数。
double precision(m,d)双精度浮点数。
real(m,d)双精度浮点数。
float(p)浮点数。
booltinyint(1)的同义词
booleantinyint(1)的同义词

大对象(LOB)数据类型

数据类型语法最大长度
tinyblob最大为255个字节。
blob(size)最大为65535字节。
mediumblob最大为16777215字节。
longtext最大尺寸4GB4,294,967,295个字符。

MariaDB创建数据库

​ 以下内容仅是站长或网友个人学习笔记、总结和研究收藏。不保证正确性,因使用而带来的风险与本站无关!

在这节中,我们来学习如何在MariaDB中创建一个数据库。

创建一个名称为"products"的数据库。

语法:

CREATE DATABASE Database_name;
SQL

示例

CREATE DATABASE products;
SQL

或者指定使用默认的字符集来创建数据库:

CREATE DATABASE testdb
  CHARACTER SET = 'utf8'
  COLLATE = 'utf8_general_ci';
SQL

注意,数据库名称不区分大小写。因此:Products,products以及PRODUCTS均表示同一个数据库。

显示数据库

SHOW DATABASES命令用于查看创建的数据库。

语法:

SHOW DATABASES;
SQL

使用MariaDB客户端,执行上面查询语句,得到以下结果 -

img

MariaDB选择数据库

​ 以下内容仅是站长或网友个人学习笔记、总结和研究收藏。不保证正确性,因使用而带来的风险与本站无关!

USE database命令用于选择数据库,如果想在一个数据库上工作,比如:创建表,查询表,更新,创建存储过程等等,那么首先需要选择一个目标数据库。

USE database_name;
SQL

示例

假设在MariaDB数据库服务器中,存在有多个数据库,我们必须选择一个特定的数据库。

例如,在下图中显示了多个数据库:

MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| products           |
| test               |
| testdb             |
+--------------------+
6 rows in set (0.00 sec)
Shell

这里我们将使用"testdb"数据库来创建表等。所以需要使用以下USE命令。

USE testdb;
SQL

在执行上面查询语句后,就已经选择"testdb"数据库。之后就可以在里面创建表等数据对象了。执行上面查询语句效果如下 -

MariaDB [(none)]> USE testdb;
Database changed
MariaDB [testdb]>

MariaDB删除数据库

​ 以下内容仅是站长或网友个人学习笔记、总结和研究收藏。不保证正确性,因使用而带来的风险与本站无关!

DROP DATABASE命令用于删除创建过(已存在)的数据库。DROP DATABASE删除数据库中的所有表并删除数据库。使用这个语句时要非常小心! 要使用DROP DATABASE,您需要数据库的DROP权限。 DROP SCHEMADROP DATABASE的同义词。

重要提示:删除数据库时,数据库的用户权限不会自动删除。

语法

DROP DATABASE Database_name;
SQL
示例

在前面的例子中,我们创建了一个数据库名称为Product。使用以下语句,删除这个数据库。

DROP DATABASE products;
SQL

在执行上面语句后,数据库"products"现在被删除。可以使用SHOW DATABASES命令来验证它。

img

可以看到"products"数据库在数据库列表中不再有显示。

MariaDB创建表

​ 以下内容仅是站长或网友个人学习笔记、总结和研究收藏。不保证正确性,因使用而带来的风险与本站无关!

在MariaDB中,CREATE TABLE语句用于在选定的数据库中创建表。使用CREATE TABLE语句创建一个具有给定名称(tbl_name)的表。 必须具有表或数据库的CREATE权限才能创建表。

语法如下 -

CREATE [OR REPLACE] [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
    (create_definition,...) [table_options    ]... [partition_options]
CREATE [OR REPLACE] [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
    [(create_definition,...)] [table_options   ]... [partition_options]
    select_statement
CREATE [OR REPLACE] [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
   { LIKE old_table_name | (LIKE old_table_name) }

select_statement:
    [IGNORE | REPLACE] [AS] SELECT ...   (Some legal select statement)
SQL

在最基本的形式中,CREATE TABLE语句提供了一个表名称,后跟一列,索引和约束。 默认情况下,该表是在默认数据库中创建的。 用db_name.tbl_name指定一个数据库。 如果引用表名称,则必须分别将数据库名称和表名引用为db_name.tbl_name。 这对于CREATE TABLE ... SELECT是特别有用的,因为它允许在包含来自其他数据库的数据的数据库中创建表。

最基本的语法如下 -

CREATE TABLE table_name (column_name column_type);
SQL

也可以指定一个column_name作为主键 - primary_key,它必须是一个NOT NULL值。

示例

"testdb"数据库中创建一个"students"表。参考以下创建语句 -

USE testdb;
CREATE TABLE students(  
    student_id INT NOT NULL AUTO_INCREMENT,  
    student_name VARCHAR(100) NOT NULL,  
    student_address VARCHAR(40) NOT NULL,  
    admission_date DATE,  
    PRIMARY KEY ( student_id )
);
SQL

执行上面查询语句,结果如下 -

img

查询数据库中的表

您可以使用SHOW TABLES命令验证是否创建表成功了。

MariaDB [testdb]> show tables;
+------------------+
| Tables_in_testdb |
+------------------+
| students         |
+------------------+
1 row in set (0.00 sec)

MariaDB [testdb]>
SQL

在上面结果中,可以看到有创建了"students"表。查看"students"表的结构:

SHOW CREATE TABLE `testdb`.`students`;
SQL

执行上面查询语句,输出结果如下 -

CREATE TABLE `students` (
    `student_id` INT(11) NOT NULL AUTO_INCREMENT,
    `student_name` VARCHAR(100) NOT NULL,
    `student_address` VARCHAR(40) NOT NULL,
    `admission_date` DATE NULL DEFAULT NULL,
    PRIMARY KEY (`student_id`)
)
COLLATE='utf8_general_ci'
ENGINE=InnoDB;

MariaDB删除表

​ 以下内容仅是站长或网友个人学习笔记、总结和研究收藏。不保证正确性,因使用而带来的风险与本站无关!

在MariaDB中,DROP TABLE语句用于从数据库中删除表。它将会永久删除表,不能恢复表结构和数据。

语法:

DROP TABLE table_name ;
SQL

示例:

删除"testdb"数据库中的students表。参考以下语句 -

DROP TABLE students;
SQL

在执行删除语句后,可以验证表是否被删除成功。参考以下查询表的语句 -

SHOW TABLES;
SQL

完整的过程,如下所示 -

img

MariaDB修改表

​ 以下内容仅是站长或网友个人学习笔记、总结和研究收藏。不保证正确性,因使用而带来的风险与本站无关!

ALTER TABLE命令是用于更改现有表的结构。 例如,可以添加或删除列,创建或销毁索引,更改现有列的类型或重命名列或表本身。也可以更改表的注释和表的存储引擎。

如果另一个连接正在使用该表,则元数据锁将处于活动状态,并且此语句将等待,直到释放该锁。对于非事务性表也是如此。

在具有重复值的列(或一组列)上添加一个UNIQUE索引时,将会产生一个错误,并且该语句将被停止。要抑制错误并强制创建UNIQUE索引,丢弃重复项,可以指定IGNORE选项。 如果一列(或一组列)应该是唯一的,但是它包含重复的值,这有时可能是有用的; 然而,这种技术不能控制哪些行被保存,哪些被删除。

1. 添加一列

要在原有的表上添加一列,可参考以下语法 -

ALTER TABLE xxxx ADD COLUMN [IF NOT EXISTS]  (col_name column_definition,...)
SQL

示例

CREATE TABLE t(id INT PRIMARY KEY, u INT UNSIGNED NOT NULL UNIQUE)
ENGINE=InnoDB;

INSERT INTO t(id,u) VALUES(1,1),(2,2),(3,3);

ALTER TABLE t ADD COLUMN
(d DATETIME DEFAULT current_timestamp(),
 p POINT NOT NULL DEFAULT ST_GeomFromText('POINT(0 0)'),
 t TEXT CHARSET utf8 DEFAULT 'The quick brown fox jumps over the lazy dog');

UPDATE t SET t=NULL WHERE id=3;

SELECT id,u,d,ST_AsText(p),t FROM t;

SELECT variable_value FROM information_schema.global_status
WHERE variable_name = 'innodb_instant_alter_column';
SQL
2. 删除一列

语法

ALTER TABLE xxxx DROP COLUMN [IF EXISTS] col_name [CASCADE|RESTRICT]
SQL

删除属于多列UNIQUE约束的列是不允许的。例如:

CREATE TABLE a (
  a int,
  b int,
  primary key (a,b)
);

ALTER TABLE x DROP COLUMN a;
[42000][1072] Key column 'A' doesn't exist in table
SQL

原因是,删除列a将导致新的约束,即列b中的所有值都是唯一的。 为了删除该列,将需要明确的DROP PRIMARY KEYADD PRIMARY KEY。从MariaDB 10.2.7版本起,该列被删除,并应用了额外的约束,导致以下结构:

ALTER TABLE x DROP COLUMN a;
Query OK, 0 rows affected (0.46 sec)

DESC x;
+-------+---------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| b     | int(11) | NO   | PRI | NULL    |       |
+-------+---------+------+-----+---------+-------+
SQL
3. MODIFY COLUMN修改列

允许修改列的类型。该列与原始列位于同一位置,列中的所有索引都将保留。 请注意,修改列时,应指定新列的所有属性。

CREATE TABLE t1 (a INT UNSIGNED AUTO_INCREMENT, PRIMARY KEY((a));
ALTER TABLE t1 MODIFY a BIGINT UNSIGNED AUTO_INCREMENT;
SQL

除了改变列的名字。该列与原始列位于同一位置,列中的所有索引都将保留。

CREATE TABLE t1 (a INT UNSIGNED AUTO_INCREMENT, PRIMARY KEY(a));
ALTER TABLE t1 CHANGE a b BIGINT UNSIGNED AUTO_INCREMENT;
SQL
4. 添加约束 - ADD CONSTRAINT

修改在表的特定列或列上添加约束。

语法

ALTER TABLE table_name 
ADD CONSTRAINT [constraint_name] CHECK(expression);
SQL

在插入或更新行之前,所有约束都将按照它们定义的顺序进行评估。如果任何约束失败,那么该行将不会被更新。

示例

CREATE TABLE account_ledger (
    id INT PRIMARY KEY AUTO_INCREMENT,
    transaction_name VARCHAR(100),
    credit_account VARCHAR(100),
    credit_amount INT,
    debit_account VARCHAR(100),
    debit_amount INT);

ALTER TABLE account_ledger 
ADD CONSTRAINT is_balanced 
    CHECK((debit_amount + credit_amount) = 0);
SQL

删除DROP CONSTRAINT

修改表结构,删除给定的约束。

ALTER TABLE table_name
DROP CONSTRAINT constraint_name;
SQL

向表中添加约束时,无论是通过CREATE TABLE还是ALTER TABLE ... ADD CONSTRAINT语句,都可以自己设置constraint_name,或者允许MariaDB自动为您生成一个约束。例如,

CREATE TABLE t (
   a INT,
   b INT,
   c INT,
   CONSTRAINT CHECK(a > b),
   CONSTRAINT check_equals CHECK(a = c)); 

SELECT CONSTRAINT_NAME, TABLE_NAME, CONSTRAINT_TYPE 
FROM information_schema.TABLE_CONSTRAINTS
WHERE TABLE_NAME = 't';

+-----------------+----------------+-----------------+
| CONSTRAINT_NAME | TABLE_NAME     | CONSTRAINT_TYPE |
+-----------------+----------------+-----------------+
| check_equals    | t              | CHECK           |
| CONSTRAINT_1    | t              | CHECK           |
+-----------------+----------------+-----------------+
SQL

要从表中删除约束,请使用ALTER TABLE ... DROP CONSTRAINT语句。 例如,

ALTER TABLE t DROP CONSTRAINT is_unique;
SQL
4. 常用语句

添加一个新的列:

ALTER TABLE t1 ADD x INT;
SQL

删除一个列:

ALTER TABLE t1 DROP x;
SQL

修改列的类型:

ALTER TABLE t1 MODIFY x bigint unsigned;
SQL

更改列的名称和类型:

ALTER TABLE t1 CHANGE a b bigint unsigned auto_increment;
SQL

更改列的名称和类型:

ALTER TABLE t1 CHANGE a b bigint unsigned auto_increment;
SQL

在单个ALTER TABLE语句中组合多个子句,用逗号分隔:

ALTER TABLE t1 DROP x, ADD x2 INT,  CHANGE y y2 INT;
SQL

更改存储引擎:

ALTER TABLE t1 ENGINE = InnoDB;
SQL

重建表(前面的例子也将重建表,如果它已经是InnoDB):

ALTER TABLE t1 FORCE;

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

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

相关文章

恒创科技:无法与服务器建立安全连接怎么解决?

在使用互联网服务时,有时会出现无法与服务器建立安全连接的问题,此错误消息通常出现在尝试访问需要安全连接的网站(例如使用 HTTPS 的网站)时,这可能是由于多种原因造成的,以下是一些常见的解决方法,帮助你解决问题。 …

svg实现一个圆形以及方形的环形进度条

1. svg实现圆形进度条 效果图: 1. 写个假接口: let res {curLegendList: [{ progress: "87", name: "进度1",color:"#00fe41" },{ progress: "66", name: "进度2" ,color:"orange"},{ p…

看到大厂工时爆料,我沉默了。。

大厂工时爆料 今天逛脉脉的时候,看到一篇名为「一人一句,大厂工时爆料」的帖子: 点开之后,我沉默了 ... 出来爆料的基本上都是 10 小时。 好奇心之下,我搜索了一下去年很热的排行榜: 2023 年最新互联网公司…

if constexpr实现条件编译

#include <iostream>// 利用if constexpr实现了条件编译 template<typename T1, typename T2> void test_func() {if constexpr (std::is_same_v<T1, T2>) {std::cout << "hit stage\n";} else {std::cout << "miss\n";} }i…

IDEA 常用技巧

1、代码块整体移动 选中&#xff0c;tab整体右移选中&#xff0c;shifttab整体左 移 2、统一修改变量 3.方法分割线 seting >> editor >> apperance >> show method separators 4、快捷键 构造器、set与get方法、方法重写、toString 等快捷操 鼠标停留在…

启智CV机器人,ROS, ubuntu 18.04

资料&#xff1a; https://wiki.ros.org/kinetic/Installation/Ubuntu https://blog.csdn.net/qq_44339029/article/details/120579608 http://wiki.ros.org/melodic/Installation/Ubuntu https://github.com/6-robot/wpb_cv 一、安装ros环境 装VM。 装ubuntu18.04 desktop.…

数字化的本质是什么?

数字化的本质其实就是把日常生活、工作等各个方面的信息、操作、交流等转化成数字形式&#xff0c;让它们更加便于存储、传输、分析和处理。简单说就是把各种各样的东西变成了0和1&#xff0c;让计算机能够更好地理解和运用这些信息。但数字化的本质并不只是简单地把事物变成数…

广告联盟四大家

国内四大广告承接商&#xff1a;①抖音旗下-穿山甲②快手旗下-快手联盟③百度旗下-百青藤④腾讯旗下-优量汇 我们目前在互联网上能看到的所有广告都是由他们发放的&#xff0c;在其中我们打小游戏复活看广告&#xff0c;获得道具看广告&#xff0c;看剧看广告&#xff0c;这…

springboot + Vue前后端项目(第十四记)

项目实战第十三记 写在前面1. 建立字典表2. 后端DictController3. Menu.vue4. 建立sys_role_menu中间表5.分配菜单接口6. 前端Role.vue改动总结写在最后 写在前面 本篇主要讲解动态分配菜单第二章节 菜单页面优化 引入图标 角色界面优化 角色自主分配菜单&#xff0c;并保存至…

透明度技术在AI去衣中的双刃剑作用

引言&#xff1a; 在当今这个数字化时代&#xff0c;人工智能&#xff08;AI&#xff09;已经成为我们生活中不可或缺的一部分。它不仅改变了我们的工作方式&#xff0c;还影响了我们的娱乐和社交活动。然而&#xff0c;随着AI技术的不断发展&#xff0c;一些伦理问题也逐渐浮出…

Linux:subshell(子shell)和childprocess(子进程)

相关阅读 Linuxhttps://blog.csdn.net/weixin_45791458/category_12234591.html?spm1001.2014.3001.5482 一、预备知识 在进行这个话题之前&#xff0c;首先要了解Linux系统中一个进程是如何创建的&#xff0c;当一个命令被执行时&#xff0c;首先会在当前进程创建一个子进程…

SpringBoot发送Gmail邮件

1. 登录Gmail Gmail网址 点击右上角“小齿轮”&#xff0c;然后点击"查看所有设置" 点击“转发和 POP/IMAP”&#xff0c;按图中设置&#xff0c;然后点击保存&#xff1a; 2. 启用两步验证(https://myaccount.google.com/security) 登录上述网址&#xff0c;找…

msvcp100.dll丢失怎样修复?几种快速有效修复msvcp100.dll丢失的方法

在使用电脑时是不是遇到过关于msvcp100.dll丢失文件丢失的情况&#xff1f;出现这样的情况有什么办法可以将丢失的msvcp100.dll文件快速恢复&#xff1f;今天的这篇文章就将教大家几种能够有效的解决msvcp100.dll丢失问题的方法。 方法一&#xff1a;重启电脑 重启电脑是一种简…

jmeter多用户登录并退出教程

有时候为了模拟更真实的场景&#xff0c;在项目中需要多用户登录并退出操作&#xff0c;大致参考如下 多用户登录前面已经实现&#xff1a;参考博文 多用户登录并退出jmx文件&#xff1a;百度网盘 提取码&#xff1a;0000 一、多用户退出操作 添加一个setUp线程组&#xff0…

基恩士激光 速度 曝光等关系

一、基恩士 CtrlN 二、速度设置 计算扫描速度 曝光时间&#xff1a; 1:1 相机点间隔是0.025 &#xff0c;我们要扫描的图像也是1&#xff1a;1的话&#xff0c;速度可以为 采样周期我们设定为3K&#xff0c;假如我们的7000行就够了 速度V0.025&#xff08;线间隔&#xff0…

YOLOv10全网最新创新点改进系列:YOLOv10改进加入新型高效的多尺度注意力(EMA)模块保留每个通道的信息并减少计算成本!助力v10检测性能遥遥领先!

YOLOv10全网最新创新点改进系列&#xff1a;YOLOv10改进加入新型高效的多尺度注意力&#xff08;EMA&#xff09;模块保留每个通道的信息并减少计算成本&#xff01;助力v10检测性能遥遥领先&#xff01; 所有改进代码均经过实验测试跑通&#xff01; 此项目不低于30种改进&am…

hadoop(1)--hdfs部署(亲测可用)

一、准备&#xff1a; 1、三台集群部署&#xff0c;配置hosts #cat /etc/hosts 192.168.46.128 node1 #nameNode dataNode secondaryNameNode 192.168.46.129 node2 #datanode 192.168.46.130 node3 #datanode说明&#xff1a; NameNode: 主节点管理者 DataNode&…

解决el-dialog里嵌入el-tabs卡死的问题

文章目录 1. 解决 el-dialog 里嵌入 el-tabs 卡死的问题 1. 解决 el-dialog 里嵌入 el-tabs 卡死的问题 今天发现在element ui里面使用 el-dialog 会导致页面卡死&#xff0c;本来我心想这么简单的一个弹窗&#xff0c;怎么会卡死解决思路&#xff1a;以为是项目的问题&#x…

展台搭建时打造完美的展示空间

1、确定主题和目标 在展台设计搭建之前&#xff0c;需要明确展示的主题和目标&#xff0c;包括展示内容、目标观众、品牌形象等。这有助于为展台设计搭建提供明确的方向和指导。 2、精细化设计 展台设计需要精细化&#xff0c;注重每一个细节的把控。包括展台结构、色彩搭配、材…

4. MySQL 约束

文章目录 【 1. 主键约束 PRIMARY KEY 】1.1 在创建表时设置主键约束设置单字段主键在创建表时设置联合主键 1.2 在修改表时添加主键约束1.3 删除主键约束1.4 主键自增长 AUTO_INCREMENT指定自增字段初始值自增字段不连续 【 2. 外键约束 FOREIGN KEY 】2.1 在创建表时设置外键…