【MySQL】數據庫、數據表的基本操作

在這里插入圖片描述

個人主頁:Guiat
歸屬專欄:MySQL

在這里插入圖片描述

文章目錄

  • 1. MySQL基礎命令
    • 1.1 連接MySQL
    • 1.2 基本命令概覽
  • 2. 數據庫操作
    • 2.1 創建數據庫
    • 2.2 查看數據庫
    • 2.3 選擇數據庫
    • 2.4 修改數據庫
    • 2.5 刪除數據庫
    • 2.6 數據庫備份與恢復
  • 3. 表操作基礎
    • 3.1 創建表
    • 3.2 查看表信息
    • 3.3 創建臨時表
    • 3.4 創建表的復制
  • 4. 表結構修改
    • 4.1 添加列
    • 4.2 修改列
    • 4.3 刪除列
    • 4.4 重命名表
    • 4.5 刪除表
  • 5. 約束與鍵
    • 5.1 主鍵約束
    • 5.2 外鍵約束
    • 5.3 唯一約束
    • 5.4 檢查約束
    • 5.5 默認值約束
  • 6. 索引操作
    • 6.1 創建索引
    • 6.2 查看索引
    • 6.3 刪除索引
  • 7. 表數據操作
    • 7.1 插入數據
    • 7.2 更新數據
    • 7.3 刪除數據
    • 7.4 查詢數據
  • 8. 高級表操作
    • 8.1 表分區
    • 8.2 視圖操作
    • 8.3 存儲過程
  • 9. 事務控制
    • 9.1 事務基本操作
    • 9.2 設置保存點
    • 9.3 事務隔離級別
  • 10. 實際應用案例
    • 10.1 電子商務數據庫設計
    • 10.2 數據庫維護操作
    • 10.3 常見查詢和操作示例

正文

1. MySQL基礎命令

MySQL是一種流行的關系型數據庫管理系統,掌握基本的數據庫和表操作命令是使用MySQL的基礎。

1.1 連接MySQL

# 連接本地MySQL服務器
mysql -u username -p# 連接遠程MySQL服務器
mysql -h hostname -u username -p -P port

1.2 基本命令概覽

-- 顯示MySQL版本
SELECT VERSION();-- 顯示當前日期時間
SELECT NOW();-- 顯示當前用戶
SELECT USER();-- 顯示可用的命令
HELP;-- 退出MySQL客戶端
EXIT;
-- 或
QUIT;

2. 數據庫操作

2.1 創建數據庫

-- 基本語法
CREATE DATABASE database_name;-- 指定字符集和排序規則
CREATE DATABASE database_name 
CHARACTER SET utf8mb4 
COLLATE utf8mb4_unicode_ci;-- 僅當數據庫不存在時創建
CREATE DATABASE IF NOT EXISTS database_name;

2.2 查看數據庫

-- 顯示所有數據庫
SHOW DATABASES;-- 顯示創建數據庫的SQL語句
SHOW CREATE DATABASE database_name;-- 顯示數據庫狀態
SHOW STATUS;

2.3 選擇數據庫

-- 切換到指定數據庫
USE database_name;-- 查看當前選中的數據庫
SELECT DATABASE();

2.4 修改數據庫

-- 修改數據庫字符集
ALTER DATABASE database_name 
CHARACTER SET = utf8mb4;-- 修改數據庫排序規則
ALTER DATABASE database_name 
COLLATE = utf8mb4_unicode_ci;

2.5 刪除數據庫

-- 刪除數據庫
DROP DATABASE database_name;-- 僅當數據庫存在時刪除
DROP DATABASE IF EXISTS database_name;

2.6 數據庫備份與恢復

# 使用mysqldump備份數據庫
mysqldump -u username -p database_name > backup_file.sql# 恢復數據庫
mysql -u username -p database_name < backup_file.sql

3. 表操作基礎

3.1 創建表

-- 基本表創建語法
CREATE TABLE table_name (column1 datatype constraints,column2 datatype constraints,...columnN datatype constraints
);-- 示例:創建學生表
CREATE TABLE students (student_id INT PRIMARY KEY AUTO_INCREMENT,first_name VARCHAR(50) NOT NULL,last_name VARCHAR(50) NOT NULL,email VARCHAR(100) UNIQUE,birth_date DATE,enrollment_date TIMESTAMP DEFAULT CURRENT_TIMESTAMP,active BOOLEAN DEFAULT TRUE
);

3.2 查看表信息

-- 顯示當前數據庫的所有表
SHOW TABLES;-- 顯示表結構
DESCRIBE table_name;
-- 或
DESC table_name;-- 顯示創建表的SQL語句
SHOW CREATE TABLE table_name;-- 顯示表狀態
SHOW TABLE STATUS LIKE 'table_name';

3.3 創建臨時表

臨時表在會話結束時自動刪除:

-- 創建臨時表
CREATE TEMPORARY TABLE temp_table (id INT,name VARCHAR(50)
);

3.4 創建表的復制

-- 復制表結構
CREATE TABLE new_table LIKE original_table;-- 復制表結構和數據
CREATE TABLE new_table AS SELECT * FROM original_table;-- 復制表結構和部分數據
CREATE TABLE new_table AS 
SELECT * FROM original_table WHERE condition;

4. 表結構修改

4.1 添加列

-- 添加新列
ALTER TABLE table_name 
ADD COLUMN column_name datatype constraints;-- 在特定位置添加列
ALTER TABLE table_name 
ADD COLUMN column_name datatype constraints 
AFTER existing_column;-- 添加列到表的第一個位置
ALTER TABLE table_name 
ADD COLUMN column_name datatype constraints 
FIRST;-- 添加多列
ALTER TABLE table_name
ADD COLUMN column1 datatype constraints,
ADD COLUMN column2 datatype constraints;

4.2 修改列

-- 修改列的數據類型
ALTER TABLE table_name 
MODIFY COLUMN column_name new_datatype;-- 修改列名和數據類型
ALTER TABLE table_name 
CHANGE COLUMN old_column_name new_column_name new_datatype constraints;-- 修改列的默認值
ALTER TABLE table_name 
ALTER COLUMN column_name SET DEFAULT default_value;-- 刪除列的默認值
ALTER TABLE table_name 
ALTER COLUMN column_name DROP DEFAULT;

4.3 刪除列

-- 刪除單列
ALTER TABLE table_name 
DROP COLUMN column_name;-- 刪除多列
ALTER TABLE table_name 
DROP COLUMN column1,
DROP COLUMN column2;

4.4 重命名表

-- 重命名表
RENAME TABLE old_table_name TO new_table_name;-- 或使用ALTER TABLE
ALTER TABLE old_table_name 
RENAME TO new_table_name;

4.5 刪除表

-- 刪除表
DROP TABLE table_name;-- 僅當表存在時刪除
DROP TABLE IF EXISTS table_name;-- 刪除多個表
DROP TABLE table1, table2, table3;

5. 約束與鍵

5.1 主鍵約束

-- 創建表時定義主鍵
CREATE TABLE products (product_id INT PRIMARY KEY,product_name VARCHAR(100) NOT NULL
);-- 復合主鍵
CREATE TABLE order_items (order_id INT,product_id INT,quantity INT NOT NULL,PRIMARY KEY (order_id, product_id)
);-- 為已有的表添加主鍵
ALTER TABLE table_name 
ADD PRIMARY KEY (column_name);-- 刪除主鍵
ALTER TABLE table_name 
DROP PRIMARY KEY;

5.2 外鍵約束

-- 創建表時定義外鍵
CREATE TABLE orders (order_id INT PRIMARY KEY,customer_id INT,order_date DATE,FOREIGN KEY (customer_id) REFERENCES customers(customer_id)
);-- 為已有的表添加外鍵
ALTER TABLE orders
ADD CONSTRAINT fk_customer
FOREIGN KEY (customer_id) REFERENCES customers(customer_id);-- 添加帶有刪除和更新行為的外鍵
ALTER TABLE orders
ADD CONSTRAINT fk_customer
FOREIGN KEY (customer_id) REFERENCES customers(customer_id)
ON DELETE CASCADE
ON UPDATE CASCADE;-- 刪除外鍵約束
ALTER TABLE orders
DROP FOREIGN KEY fk_customer;

5.3 唯一約束

-- 創建表時定義唯一約束
CREATE TABLE users (user_id INT PRIMARY KEY,username VARCHAR(50) UNIQUE,email VARCHAR(100) UNIQUE
);-- 為已有的表添加唯一約束
ALTER TABLE users
ADD CONSTRAINT uq_email UNIQUE (email);-- 刪除唯一約束
ALTER TABLE users
DROP INDEX uq_email;

5.4 檢查約束

MySQL 8.0及以上版本支持CHECK約束:

-- 創建表時定義檢查約束
CREATE TABLE employees (employee_id INT PRIMARY KEY,name VARCHAR(100),salary DECIMAL(10,2) CHECK (salary > 0),age INT CHECK (age >= 18)
);-- 為已有的表添加檢查約束
ALTER TABLE employees
ADD CONSTRAINT chk_salary CHECK (salary > 0);-- 刪除檢查約束
ALTER TABLE employees
DROP CHECK chk_salary;

5.5 默認值約束

-- 創建表時定義默認值
CREATE TABLE articles (article_id INT PRIMARY KEY,title VARCHAR(200) NOT NULL,content TEXT,published BOOLEAN DEFAULT FALSE,created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);-- 為已有的列添加默認值
ALTER TABLE articles
ALTER COLUMN published SET DEFAULT TRUE;-- 刪除默認值
ALTER TABLE articles
ALTER COLUMN published DROP DEFAULT;

6. 索引操作

6.1 創建索引

-- 創建普通索引
CREATE INDEX idx_name ON table_name (column_name);-- 創建唯一索引
CREATE UNIQUE INDEX idx_email ON users (email);-- 創建復合索引
CREATE INDEX idx_name_email ON users (name, email);-- 創建前綴索引
CREATE INDEX idx_title ON articles (title(50));-- 在表創建時定義索引
CREATE TABLE customers (id INT PRIMARY KEY,name VARCHAR(100),email VARCHAR(100),INDEX idx_name (name)
);-- 使用ALTER TABLE添加索引
ALTER TABLE customers
ADD INDEX idx_email (email);

6.2 查看索引

-- 查看表的所有索引
SHOW INDEX FROM table_name;

6.3 刪除索引

-- 刪除索引
DROP INDEX index_name ON table_name;-- 使用ALTER TABLE刪除索引
ALTER TABLE table_name
DROP INDEX index_name;

7. 表數據操作

7.1 插入數據

-- 插入單行數據
INSERT INTO table_name (column1, column2, ...) 
VALUES (value1, value2, ...);-- 插入多行數據
INSERT INTO table_name (column1, column2, ...) 
VALUES (value1, value2, ...),(value1, value2, ...),(value1, value2, ...);-- 插入所有列的數據
INSERT INTO table_name 
VALUES (value1, value2, ...);-- 從另一個表插入數據
INSERT INTO target_table (column1, column2, ...)
SELECT column1, column2, ... 
FROM source_table
WHERE condition;

7.2 更新數據

-- 更新所有行
UPDATE table_name
SET column1 = value1, column2 = value2
WHERE condition;-- 使用子查詢更新數據
UPDATE table_name
SET column1 = (SELECT column2 FROM another_table WHERE condition)
WHERE condition;-- 多表更新
UPDATE table1 t1
JOIN table2 t2 ON t1.id = t2.id
SET t1.column1 = t2.column2
WHERE condition;

7.3 刪除數據

-- 刪除滿足條件的行
DELETE FROM table_name
WHERE condition;-- 刪除所有行
DELETE FROM table_name;-- 截斷表(更快但不可回滾)
TRUNCATE TABLE table_name;-- 多表刪除
DELETE t1 FROM table1 t1
JOIN table2 t2 ON t1.id = t2.ref_id
WHERE condition;

7.4 查詢數據

-- 基本查詢
SELECT column1, column2
FROM table_name
WHERE condition;-- 查詢所有列
SELECT * FROM table_name;-- 查詢唯一值
SELECT DISTINCT column FROM table_name;-- 使用條件查詢
SELECT * FROM table_name
WHERE column = value AND/OR another_column > value;-- 使用排序
SELECT * FROM table_name
ORDER BY column1 ASC, column2 DESC;-- 使用限制
SELECT * FROM table_name
LIMIT 10 OFFSET 20;-- 分組查詢
SELECT column1, COUNT(*) as count
FROM table_name
GROUP BY column1
HAVING count > 5;

8. 高級表操作

8.1 表分區

-- 創建分區表(按范圍分區)
CREATE TABLE sales (id INT,amount DECIMAL(10,2),sale_date DATE
)
PARTITION BY RANGE (YEAR(sale_date)) (PARTITION p0 VALUES LESS THAN (2020),PARTITION p1 VALUES LESS THAN (2021),PARTITION p2 VALUES LESS THAN (2022),PARTITION p3 VALUES LESS THAN MAXVALUE
);-- 查看分區信息
SHOW CREATE TABLE sales;
SELECT * FROM information_schema.PARTITIONS 
WHERE TABLE_NAME = 'sales';

8.2 視圖操作

-- 創建視圖
CREATE VIEW view_name AS
SELECT column1, column2
FROM table_name
WHERE condition;-- 查看視圖
SHOW FULL TABLES WHERE TABLE_TYPE = 'VIEW';-- 更新視圖
ALTER VIEW view_name AS
SELECT column1, column2, column3
FROM table_name
WHERE condition;-- 刪除視圖
DROP VIEW IF EXISTS view_name;

8.3 存儲過程

-- 創建存儲過程
DELIMITER //
CREATE PROCEDURE procedure_name(IN param1 INT, OUT param2 VARCHAR(100))
BEGIN-- 存儲過程體SELECT column INTO param2 FROM table WHERE id = param1;
END //
DELIMITER ;-- 調用存儲過程
CALL procedure_name(5, @result);
SELECT @result;-- 刪除存儲過程
DROP PROCEDURE IF EXISTS procedure_name;

9. 事務控制

9.1 事務基本操作

-- 開始事務
START TRANSACTION;-- 執行SQL語句
INSERT INTO accounts (account_id, balance) VALUES (1, 1000);
UPDATE accounts SET balance = balance - 500 WHERE account_id = 1;
INSERT INTO transactions (account_id, amount) VALUES (1, -500);-- 提交事務
COMMIT;-- 或回滾事務
-- ROLLBACK;

9.2 設置保存點

-- 開始事務
START TRANSACTION;-- 執行操作
INSERT INTO table1 VALUES (1, 'value');-- 設置保存點
SAVEPOINT point1;-- 執行更多操作
INSERT INTO table2 VALUES (2, 'value');-- 回滾到保存點
ROLLBACK TO SAVEPOINT point1;-- 提交事務(只提交保存點之前的操作)
COMMIT;

9.3 事務隔離級別

-- 查看當前事務隔離級別
SELECT @@TRANSACTION_ISOLATION;-- 設置事務隔離級別
SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;
SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ;
SET SESSION TRANSACTION ISOLATION LEVEL SERIALIZABLE;
SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
隔離性最低
默認級別
SQL標準默認
隔離性最高
問題
問題
問題
解決
解決
部分問題
解決
問題
問題
解決
解決
解決
事務隔離級別
READ UNCOMMITTED
REPEATABLE READ
READ COMMITTED
SERIALIZABLE
臟讀
不可重復讀
幻讀

10. 實際應用案例

10.1 電子商務數據庫設計

-- 創建數據庫
CREATE DATABASE ecommerce CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
USE ecommerce;-- 創建客戶表
CREATE TABLE customers (customer_id INT PRIMARY KEY AUTO_INCREMENT,first_name VARCHAR(50) NOT NULL,last_name VARCHAR(50) NOT NULL,email VARCHAR(100) NOT NULL UNIQUE,password VARCHAR(255) NOT NULL,phone VARCHAR(20),created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,INDEX idx_email (email),INDEX idx_name (last_name, first_name)
);-- 創建地址表
CREATE TABLE addresses (address_id INT PRIMARY KEY AUTO_INCREMENT,customer_id INT NOT NULL,address_type ENUM('billing', 'shipping') DEFAULT 'shipping',address_line1 VARCHAR(100) NOT NULL,address_line2 VARCHAR(100),city VARCHAR(50) NOT NULL,state VARCHAR(50),postal_code VARCHAR(20) NOT NULL,country VARCHAR(50) NOT NULL,is_default BOOLEAN DEFAULT FALSE,FOREIGN KEY (customer_id) REFERENCES customers(customer_id) ON DELETE CASCADE,INDEX idx_customer (customer_id)
);-- 創建類別表
CREATE TABLE categories (category_id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(50) NOT NULL,description TEXT,parent_id INT,FOREIGN KEY (parent_id) REFERENCES categories(category_id) ON DELETE SET NULL
);-- 創建產品表
CREATE TABLE products (product_id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(100) NOT NULL,description TEXT,price DECIMAL(10, 2) NOT NULL CHECK (price > 0),stock_quantity INT NOT NULL DEFAULT 0 CHECK (stock_quantity >= 0),category_id INT,created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,FOREIGN KEY (category_id) REFERENCES categories(category_id) ON DELETE SET NULL,INDEX idx_category (category_id),INDEX idx_name (name)
);-- 創建訂單表
CREATE TABLE orders (order_id INT PRIMARY KEY AUTO_INCREMENT,customer_id INT NOT NULL,order_date TIMESTAMP DEFAULT CURRENT_TIMESTAMP,status ENUM('pending', 'processing', 'shipped', 'delivered', 'cancelled') DEFAULT 'pending',shipping_address_id INT NOT NULL,billing_address_id INT NOT NULL,shipping_fee DECIMAL(10, 2) DEFAULT 0.00,total_amount DECIMAL(10, 2) NOT NULL,payment_method ENUM('credit_card', 'paypal', 'bank_transfer'),notes TEXT,FOREIGN KEY (customer_id) REFERENCES customers(customer_id) ON DELETE RESTRICT,FOREIGN KEY (shipping_address_id) REFERENCES addresses(address_id) ON DELETE RESTRICT,FOREIGN KEY (billing_address_id) REFERENCES addresses(address_id) ON DELETE RESTRICT,INDEX idx_customer (customer_id),INDEX idx_date (order_date)
);-- 創建訂單明細表
CREATE TABLE order_items (order_id INT,product_id INT,quantity INT NOT NULL CHECK (quantity > 0),unit_price DECIMAL(10, 2) NOT NULL,PRIMARY KEY (order_id, product_id),FOREIGN KEY (order_id) REFERENCES orders(order_id) ON DELETE CASCADE,FOREIGN KEY (product_id) REFERENCES products(product_id) ON DELETE RESTRICT
);-- 創建產品評價表
CREATE TABLE reviews (review_id INT PRIMARY KEY AUTO_INCREMENT,product_id INT NOT NULL,customer_id INT NOT NULL,rating TINYINT NOT NULL CHECK (rating BETWEEN 1 AND 5),comment TEXT,review_date TIMESTAMP DEFAULT CURRENT_TIMESTAMP,FOREIGN KEY (product_id) REFERENCES products(product_id) ON DELETE CASCADE,FOREIGN KEY (customer_id) REFERENCES customers(customer_id) ON DELETE CASCADE,UNIQUE KEY unique_review (product_id, customer_id),INDEX idx_product (product_id)
);-- 創建產品庫存歷史表
CREATE TABLE inventory_history (id INT PRIMARY KEY AUTO_INCREMENT,product_id INT NOT NULL,quantity_change INT NOT NULL,reason ENUM('purchase', 'sale', 'return', 'adjustment'),reference_id INT,changed_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,FOREIGN KEY (product_id) REFERENCES products(product_id) ON DELETE CASCADE,INDEX idx_product (product_id),INDEX idx_date (changed_at)
);-- 創建訂單狀態歷史視圖
CREATE VIEW order_status_history AS
SELECT orders.order_id,customers.email,orders.status,orders.total_amount,orders.order_date
FROM orders
JOIN customers ON orders.customer_id = customers.customer_id;-- 創建存儲過程:處理訂單
DELIMITER //
CREATE PROCEDURE process_order(IN order_id_param INT)
BEGINDECLARE current_status VARCHAR(20);-- 獲取當前訂單狀態SELECT status INTO current_status FROM orders WHERE order_id = order_id_param;-- 只處理待處理訂單IF current_status = 'pending' THENSTART TRANSACTION;-- 更新訂單狀態UPDATE orders SET status = 'processing' WHERE order_id = order_id_param;-- 更新產品庫存UPDATE products pJOIN order_items oi ON p.product_id = oi.product_idSET p.stock_quantity = p.stock_quantity - oi.quantityWHERE oi.order_id = order_id_param;-- 記錄庫存變更INSERT INTO inventory_history (product_id, quantity_change, reason, reference_id)SELECT product_id, -quantity, 'sale', order_id_paramFROM order_itemsWHERE order_id = order_id_param;COMMIT;SELECT 'Order processed successfully' AS message;ELSESELECT CONCAT('Cannot process order. Current status: ', current_status) AS message;END IF;
END //
DELIMITER ;

10.2 數據庫維護操作

-- 分析表
ANALYZE TABLE customers, orders, products;-- 檢查表
CHECK TABLE customers, orders, products;-- 優化表
OPTIMIZE TABLE customers, orders, products;-- 修復表
REPAIR TABLE customers, orders, products;

10.3 常見查詢和操作示例

-- 插入客戶
INSERT INTO customers (first_name, last_name, email, password, phone)
VALUES ('John', 'Doe', 'john.doe@example.com', SHA2('password123', 256), '555-123-4567');-- 插入產品
INSERT INTO categories (name, description) VALUES ('Electronics', 'Electronic devices and accessories');
INSERT INTO products (name, description, price, stock_quantity, category_id)
VALUES ('Smartphone X', 'Latest smartphone with advanced features', 699.99, 50, 1);-- 創建訂單(簡化版)
INSERT INTO addresses (customer_id, address_type, address_line1, city, postal_code, country)
VALUES (1, 'shipping', '123 Main St', 'New York', '10001', 'USA');INSERT INTO orders (customer_id, shipping_address_id, billing_address_id, total_amount, payment_method)
VALUES (1, 1, 1, 699.99, 'credit_card');INSERT INTO order_items (order_id, product_id, quantity, unit_price)
VALUES (1, 1, 1, 699.99);-- 處理訂單
CALL process_order(1);-- 復雜查詢:查找暢銷產品
SELECT p.product_id,p.name,p.price,SUM(oi.quantity) AS total_sold,SUM(oi.quantity * oi.unit_price) AS total_revenue
FROM products p
JOIN order_items oi ON p.product_id = oi.product_id
JOIN orders o ON oi.order_id = o.order_id
WHERE o.order_date >= DATE_SUB(CURDATE(), INTERVAL 30 DAY)
GROUP BY p.product_id, p.name, p.price
ORDER BY total_sold DESC
LIMIT 10;-- 創建每日銷售報表視圖
CREATE VIEW daily_sales AS
SELECT DATE(o.order_date) AS sale_date,COUNT(DISTINCT o.order_id) AS order_count,SUM(oi.quantity) AS items_sold,SUM(o.total_amount) AS total_revenue
FROM orders o
JOIN order_items oi ON o.order_id = oi.order_id
GROUP BY DATE(o.order_date)
ORDER BY sale_date DESC;

掌握數據庫和表的基本操作是使用MySQL的基礎。這些操作包括數據庫的創建、修改和刪除,表的設計、修改和管理,以及數據的增刪改查。隨著經驗的積累,您可以進一步探索更高級的功能,如存儲過程、觸發器、視圖和事務管理,以構建更復雜、更高效的數據庫應用程序。

結語
感謝您的閱讀!期待您的一鍵三連!歡迎指正!

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/79229.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/79229.shtml
英文地址,請注明出處:http://en.pswp.cn/web/79229.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

cursor sign in 網頁登錄成功,sursor軟件里一直登陸不成功沒有登陸信息

今天在使用cursor登陸無法登陸&#xff0c;點擊sigin in打開網址登陸成功后&#xff0c;軟件里一直無法顯示登陸信息。 點擊sigin in 在網址登陸成功后 解決辦法&#xff1a; 方法1.設置windows默認應用為chrome. 辦法2: 刪除代理 cursor上ctrl, 打開設置&#xff0c;找到…

深入理解卷積神經網絡的輸入層:數據的起點與預處理核心

內容摘要 本文圍繞卷積神經網絡輸入層展開&#xff0c;詳細介紹其在網絡中的重要作用&#xff0c;包括接收不同領域數據的形式及傳遞數據的過程。深入解讀數據預處理的關鍵操作&#xff0c;如去均值、歸一化和PCA/白化。助力讀者透徹理解輸入層&#xff0c;為構建高效卷積神經…

解決 MySQL 數據庫無法遠程連接的問題

在使用 MySQL 數據庫時&#xff0c;遇到這樣的問題&#xff1a; 本地可以連接 MySQL&#xff0c;但遠程機器連接時&#xff0c;總是報錯 Host ... is not allowed to connect to this MySQL server。 這通常是因為 MySQL 的用戶權限或配置限制了遠程訪問。 1. 登錄 MySQL 數據…

MCP認證全解析:從零到微軟認證專家

MCP認證全解析&#xff1a;從零到微軟認證專家 什么是MCP認證&#xff1f; Microsoft Certified Professional&#xff08;MCP&#xff09;是由微軟官方頒發的技術認證&#xff0c;旨在驗證IT從業者在微軟技術棧&#xff08;如Azure、Windows Server、SQL Server等&#xff0…

驅動開發系列57 - Linux Graphics QXL顯卡驅動代碼分析(四)顯示區域更新

一&#xff1a;概述 前面在介紹了顯示模式設置&#xff08;分辨率&#xff0c;刷新率&#xff09;之后&#xff0c;本文繼續分析下&#xff0c;顯示區域的繪制&#xff0c;詳細看看虛擬機的畫面是如何由QXL顯卡繪制出來的。 二&#xff1a;相關數據結構介紹 struct qxl_moni…

遠程調用負載均衡LoadBalancer

1. 什么是負載均衡 負載均衡就是將負載&#xff08;工作任務&#xff0c;訪問請求&#xff09;進行分攤到多個操作單元&#xff08;服務器,組件&#xff09;上進行執行。 根據負載均衡發生位置的不同,一般分為服務端負載均衡和客戶端負載均衡。 服務端負載均衡&#xff1a;指的…

【深度學習】【目標檢測】【Ultralytics-YOLO系列】YOLOV3核心文件detect.py解讀

【深度學習】【目標檢測】【Ultralytics-YOLO系列】YOLOV3核心文件detect.py解讀 文章目錄 【深度學習】【目標檢測】【Ultralytics-YOLO系列】YOLOV3核心文件detect.py解讀前言if name ‘main’parse_opt函數main函數run函數不同命令參數的推理結果常規推理命令推理命令(新增…

NextPolish1.4.1 安裝與使用-bioinformatics tools54

01 簡介 NextPolish 是一個用于修正由低準確度長讀段&#xff08;如 ONT 或 CLR&#xff09;組裝出來的基因組序列中堿基錯誤&#xff08;SNV/Indel&#xff09;的工具。它支持&#xff1a; 僅使用短讀段 僅使用長讀段 同時使用短讀段與長讀段 NextPolish 包含兩個核心模塊…

Vue3 el-tree:全選時只返回父節點,半選只返回勾選中的節點(省-市區-縣-鎮-鄉-村-街道)

需求原因&#xff1a;全選時&#xff0c;傳給接口的code數據太多了&#xff1b; 如果加上 check-strictly 父節點與子節點無關聯&#xff0c;可以初步滿足需求 效果如下使用了check-strictly的話&#xff0c;tree就沒有了半選效果 不好的地方&#xff1a;用戶體驗感不好&#x…

使用 docker 安裝 nacos3.x

一、安裝 nacos 1.拉取鏡像 使用如下指令拉取鏡像 docker pull nacos/nacos-server 拉取完成后&#xff0c;可以使用以下命令查看是否拉取到對應的鏡像&#xff0c;默認拉取最新鏡像 docker images 2.新建掛載文件目錄 mkdir -p /home/ubuntu/nacos/conf/mkdir -p /home/…

高性能Python Web 框架--FastAPI 學習「基礎 → 進階 → 生產級」

以下是針對 FastAPI 的保姆級教程&#xff0c;包含核心概念、完整案例和關鍵注意事項&#xff0c;采用「基礎 → 進階 → 生產級」的三階段教學法&#xff1a; 一、FastAPI介紹 FastAPI 是一個現代化的、高性能的 Python Web 框架&#xff0c;專門用于構建 APIs&#xff08;應…

H2 Database Select 語句執行流程

H2 Database Select 語句執行流程 使用 // CREATE TABLE IF NOT EXISTS test(id INT primary key, name VARCHAR(255)) // insert into test(id, name) values(1, name1), (2, name2), (3, name3), (4, name4); String sql "SELECT * FROM test where id > 1 and na…

理解 Envoy 的架構

理解 Envoy 的架構對于深入理解 Istio 至關重要&#xff0c;因為 Envoy 是 Istio 數據平面的核心。Envoy 是一個高性能的 C 分布式代理&#xff0c;設計為云原生應用和大規模微服務架構的網絡基礎。 以下是 Envoy 架構的關鍵組成部分和核心理念&#xff1a; 核心設計理念&…

Android開發-常用布局

在Android應用開發中&#xff0c;布局決定了用戶界面的結構和元素之間的相對位置。選擇合適的布局不僅能夠提升用戶體驗&#xff0c;還能提高代碼的可維護性和靈活性。本文將介紹幾種最常用的Android布局方式&#xff0c;包括LinearLayout、RelativeLayout、ConstraintLayout以…

如何在MySQL中實現類似Redis的PING命令的功能來檢測連接狀態?

要在MySQL中實現類似Redis的PING命令的功能來檢測連接狀態&#xff0c;可以采用以下方法&#xff1a; 方法一&#xff1a;使用簡單的SQL查詢 最直接的方法是通過執行一個簡單的查詢來檢測連接狀態&#xff0c;例如&#xff1a; SELECT 1;如果查詢成功并返回結果&#xff08;…

Vue 系列之:defineProps、defineEmits、...

defineProps 用于接收父組件傳遞的屬性值。 父組件&#xff1a; <!-- 父組件 --> <template><Child1 str"字符串" :num"num" />-----------------<Child2 str"字符串" :num"num" /> </template><…

windows服務器部署Gitlab

代碼托管,如果對工具功能要求不高,Gitea也可以滿足需要,只是功能相對比較簡單。 通常GltLab是部署在linux服務器上的,windows版本已經不維護了。不過現在windows10 11已經可以實現部署了,一個是windows本機部署linux虛擬機(windows商店直接安裝或者其他虛擬機平臺都可以)…

剖析 FFmpeg:從基本功能到過濾器,實現音視頻處理的靈活性

目錄 1.解復用2 解碼2.1 音頻解碼2.2 視頻解碼 3 修飾3.1 avio3.2 重采樣 4 過濾器4.1 過濾器基本知識4.2 簡單過濾器4.3 復雜濾鏡圖 1.解復用 解復用就是把容器中的媒體流分離出來&#xff0c;方便我們對媒體流處理。 step1&#xff1a;對媒體文件上下文初始化 AVFormatCont…

kafka學習筆記(四、生產者、消費者(客戶端)深入研究(三)——事務詳解及代碼實例)

1.事務簡介 Kafka事務是Apache Kafka在流處理場景中實現Exactly-Once語義的核心機制。它允許生產者在跨多個分區和主題的操作中&#xff0c;以原子性&#xff08;Atomicity&#xff09;的方式提交或回滾消息&#xff0c;確保數據處理的最終一致性。例如&#xff0c;在流處理中…

Missashe計網復習筆記(隨時更新)

Missashe計算機網絡復習筆記 前言&#xff1a;這篇筆記用于博主對計網這門課所學進行記錄和總結&#xff0c;也包括一些個人的理解。正在更新當中…… 第一章 計算機網絡體系結構 考綱內容 (一) 計算機網絡概述 計算機網絡的概念、組成與功能;計算機網絡的分類; 計算機網絡…