前言

前面的两篇文章中,我们已经对MySQL有了基本了解。

并且知道了怎么用工具连接数据库?怎么创建数据库?怎么创建表?

这一篇呢我们就来看看怎么在我们创建的表中插入数据、删除数据和修改数据。也就是上一篇文章中提到的DML 数据操作语言

准备

根据上一章所说的,我们创建一个db_xiezhr 数据库,并向数据库中添加一张用户信息表。

① 通过命令行建库,建表

mysql> create database if not exists db_xiezhr;
Query OK, 1 row affected (0.00 sec)
mysql> use db_xiezhr
Database changed
mysql> drop table if exists user_profile;
Query OK, 0 rows affected, 1 warning (0.00 sec) mysql> CREATE TABLE `user_profile`
(`id` int NOT NULL,
`device_id` int NOT NULL,
`user_name` varchar(100) NOT NULL ,
`gender` varchar(14) NOT NULL,
`age` int ,
`user_email` varchar(50) ,
`user_zip` varchar(10),
`university` varchar(32) NOT NULL,
`province` varchar(32) NOT NULL,);
Query OK, 0 rows affected (0.01 sec)

② 当然了,我们可以通过上一篇文章中说到的工具之一建库、建表

这里以sqlyog工具为例,建立db_xiezhr数据库,并创建用user_profile户信息表

  • 建立db_xiezhr数据库



  • 创建用user_profile户信息表





    以上,我们数据库和数据表就都已经创建成功了

插入数据

语法格式

#方式一:
INSERT INTO 表名 VALUES(值,...);
#方式二:
INSERT INTO 表名(字段名,...) VALUES(值,...);
#方式三:
INSERT INTO 表名(字段名,...) SELECT (字段名,...) FROM 表名;

插入完整行数据

①简单写法

  • 存储到每个里表中的数据在VALUES子句中给出,值得顺序也必须要与定义时候的字段顺序一致,没有的值需要使用NULL。
  • 这种写法简单,但并不安全,应尽量避免使用。一旦表结构变化了,可能就会出问题
# 向user_profile用户信息表中添加一条数据
insert into user_profile
values(
1,
1,
'张三',
'male',
'28',
null,
null,
'北京大学',
'BeiJing'
);

② 安全写法

  • 跟上面简单写法效果一样,往用户信息表中插入一条数据
  • 在表名后括号中明确给出了列名,在插入数据时,将用VALUES列表中的相应值填入对应的列名中。第一个列名对应第一个值,第二个列名对应第二个值......
  • 因为提供了列名,所以值也不需要按照表中的次序来插入。即使表结构变化了,sql语句也能正常执行。
  • 不需要插入的列user_email和user_zip 列,值也可以不用写出来了,也比较灵活
INSERT INTO `db_xiezhr`.`user_profile` (
`id`,
`device_id`,
`user_name`,
`gender`,
`age`,
`university`,
`province`
)
VALUES
(
1,
1,
'张三',
'male',
'28',
'北京大学',
'BeiJing'
) ;

注:

  • 不管使用哪种insert语法,都必须给出values的正确数目。
  • 如果不提供列名,则必须给每个列都提供一个值
  • 如果提供列名,则必须对每个写出的列提供一个值
  • 在insert语法中省略某列时,需要具备两个条件,一是该列被定义为允许NULL值二是表定义中给出了默认值

插入多行数据

这里你可能说我多写几条sql语句不就可以了么,哈哈,这也可以实现了么?

INSERT INTO `user_profile` (
`id`,
`device_id`,
`user_name`,
`gender`,
`age`,
`university`,
`province`
)
VALUES
(
2,
2,
'李四',
'male',
'36',
'天津大学',
'TianJin'
) ; INSERT INTO `user_profile` (
`id`,
`device_id`,
`user_name`,
`gender`,
`age`,
`university`,
`province`
)
VALUES
(
3,
3,
'王五',
'female',
'25',
'天津大学',
'TianJin'
) ;

但这里提供另一种语法,一条语句就可以完成


INSERT INTO `user_profile` (
`id`,
`device_id`,
`user_name`,
`gender`,
`age`,
`university`,
`province`
)
VALUES
(
2,
2,
'李四',
'male',
'36',
'天津大学',
'TianJin'
),
(
3,
3,
'王五',
'female',
'25',
'天津大学',
'TianJin'
) ;

将检索出来的数据插入表

这里有两张表,一张是user_profile,数据如下



一张表是tmp_user_profile,数据如下



我们需要将tmp_user_profile 表中数据插入到user_profile 表中,可以通过如下脚本实现

INSERT INTO `user_profile` (
`id`,
`device_id`,
`user_name`,
`gender`,
`age`,
`university`,
`province`
)
SELECT
`id`,
`device_id`,
`user_name`,
`gender`,
`age`,
`university`,
`province`
FROM tmp_user_profile;

执行完上面脚本后,user_profile表中数据

更新数据

准备两张表

  • 下面我们建两张表,一张表为 product 表,用来存放产品信息,其中有产品价格字段 saleprice;另外一张表是 product_price 表。
# 产品信息表product
mysql> select * from product;
+----+-----------+--------------------------------------------+-----------+--------+
| id | productid | productname | saleprice | author |
+----+-----------+--------------------------------------------+-----------+--------+
| 1 | 10001 | 公众号XiezhrSpace【Oralce从入门到放弃】 | 100 | xiezhr |
| 2 | 10002 | 公众号XiezhrSpace【MySQL从入门到放弃】 | 99 | xiezhr |
| 3 | 10003 | 公众号XiezhrSpace【快速上手Linux核心命令】 | 88 | xiezhr |
| 4 | 10004 | 公众号XiezhrSpace【Java从入门到精通】 | 150 | xiezhr |
| 5 | 10005 | 公众号XiezhrSpace【Idea从入门到上瘾】 | 200 | xiezhr |
| 6 | 10006 | 公众号XiezhrSpace【如何快速搭建个人博客】 | 120 | xiezhr |
+----+-----------+--------------------------------------------+-----------+--------+
6 rows in set (0.02 sec) # 产品价格表product_price
mysql> select * from product_price;
+----+-----------+-------+
| id | productid | price |
+----+-----------+-------+
| 1 | 10001 | NULL |
| 2 | 10002 | NULL |
| 3 | 10003 | NULL |
| 4 | 10004 | NULL |
| 5 | 10005 | NULL |
| 6 | 1006 | NULL |
+----+-----------+-------+
6 rows in set (0.00 sec)

语法

# 1、单表更新
UPDATE 表名 SET 列 = 值,... WHERE 查询条件;
# 2、根据一张表更新另一张表
# ① 使用update
UPDATE
表1 别名,
表2 别名
SET
列 = 值,
...
WHERE 连接条件 AND 筛选条件 ;
# ②通过INNER JOIN
UPDATE
表1 别名
INNER JOIN 表2 别名
ON 连接条件 AND 筛选条件
SET
列 = 值,
...;
# ③ 通过LEFT JOIN
UPDATE
表1 别名
LEFT JOIN 表2 别名
ON 连接条件 AND 筛选条件
SET
列 = 值,
...;
# ③ 通过子查询
UPDATE
表2 别名
SET 列 = (SELECT 表达式 FROM 表1 WHERE 连接条件 AND 筛选条件);
# 2、同时更新两张表
UPDATE
表1
INNER JOIN 表2
ON 连接条件 AND 筛选条件
SET 表1.列=值1,
表2.列=值2;

实践操作

① 将产品信息表product 中10001 号产品价格更新为999

mysql> UPDATE product t SET t.`saleprice` =999 WHERE t.`productid` = '10001';
Query OK, 1 row affected (0.01 sec)
Rows matched: 1 Changed: 1 Warnings: 0 mysql> select * from product;
+----+-----------+--------------------------------------------+-----------+--------+
| id | productid | productname | saleprice | author |
+----+-----------+--------------------------------------------+-----------+--------+
| 1 | 10001 | 公众号XiezhrSpace【Oralce从入门到放弃】 | 999 | xiezhr |
| 2 | 10002 | 公众号XiezhrSpace【MySQL从入门到放弃】 | 99 | xiezhr |
| 3 | 10003 | 公众号XiezhrSpace【快速上手Linux核心命令】 | 88 | xiezhr |
| 4 | 10004 | 公众号XiezhrSpace【Java从入门到精通】 | 150 | xiezhr |
| 5 | 10005 | 公众号XiezhrSpace【Idea从入门到上瘾】 | 200 | xiezhr |
| 6 | 10006 | 公众号XiezhrSpace【如何快速搭建个人博客】 | 120 | xiezhr |
+----+-----------+--------------------------------------------+-----------+--------+
6 rows in set (0.00 sec)

② 将 product_price 表中的价格字段 price 更新为 product 表中价格字段 price 的 80%。

# 使用“UPDATE table1 t1,table2,...,table n”的方式来多表更新
mysql> UPDATE product t1, product_price t2 SET t2.price = t1.`saleprice` * 0.8 WHERE t1.productid= t2.productId;
Query OK, 5 rows affected, 2 warnings (0.01 sec)
Rows matched: 5 Changed: 5 Warnings: 2 mysql> select * from product_price;
+----+-----------+-------+
| id | productid | price |
+----+-----------+-------+
| 1 | 10001 | 80 |
| 2 | 10002 | 79 |
| 3 | 10003 | 70 |
| 4 | 10004 | 120 |
| 5 | 10005 | 160 |
| 6 | 1006 | NULL |
+----+-----------+-------+
6 rows in set (0.00 sec) # 通过INNER JOIN
mysql> select * from product_price;
+----+-----------+-------+
| id | productid | price |
+----+-----------+-------+
| 1 | 10001 | 80 |
| 2 | 10002 | 79 |
| 3 | 10003 | 70 |
| 4 | 10004 | 120 |
| 5 | 10005 | 160 |
| 6 | 1006 | NULL |
+----+-----------+-------+
6 rows in set (0.00 sec)
# 通过LEFT JOIN
mysql> UPDATE product t1 LEFT JOIN product_price t2 ON t1.productid= t2.productid SET t2.price = t1.`saleprice` * 0.8 WHERE t1.productid='10001';
Query OK, 1 row affected (0.01 sec)
Rows matched: 1 Changed: 1 Warnings: 0 mysql> select * from product_price;
+----+-----------+-------+
| id | productid | price |
+----+-----------+-------+
| 1 | 10001 | 80 |
| 2 | 10002 | NULL |
| 3 | 10003 | NULL |
| 4 | 10004 | NULL |
| 5 | 10005 | NULL |
| 6 | 1006 | NULL |
+----+-----------+-------+
6 rows in set (0.00 sec)
# 通过子查询
mysql> UPDATE product_price t2 SET t2.price=(SELECT t1.`saleprice` *0.8 FROM product t1 WHERE t1.productid = t2.productid);
Query OK, 5 rows affected, 2 warnings (0.01 sec)
Rows matched: 6 Changed: 5 Warnings: 2 mysql> select * from product_price;
+----+-----------+-------+
| id | productid | price |
+----+-----------+-------+
| 1 | 10001 | 80 |
| 2 | 10002 | 79 |
| 3 | 10003 | 70 |
| 4 | 10004 | 120 |
| 5 | 10005 | 160 |
| 6 | 1006 | NULL |
+----+-----------+-------+
6 rows in set (0.00 sec)

③ 同时更新两张表(正式开发中用得比较少)

  • 两张表做关联,同时更新了 product_price 表的 price 字段和 product 表的 author两个字段。
mysql> UPDATE product t1 INNER JOIN product_price t2 ON t1.productid= t2.productid SET t2.price = t1.`saleprice` * 0.8, t1.`author` = 'xiezhr001';
Query OK, 5 rows affected, 2 warnings (0.00 sec)
Rows matched: 10 Changed: 5 Warnings: 2 mysql> select * from product;
+----+-----------+--------------------------------------------+-----------+-----------+
| id | productid | productname | saleprice | author |
+----+-----------+--------------------------------------------+-----------+-----------+
| 1 | 10001 | 公众号XiezhrSpace【Oralce从入门到放弃】 | 100 | xiezhr001 |
| 2 | 10002 | 公众号XiezhrSpace【MySQL从入门到放弃】 | 99 | xiezhr001 |
| 3 | 10003 | 公众号XiezhrSpace【快速上手Linux核心命令】 | 88 | xiezhr001 |
| 4 | 10004 | 公众号XiezhrSpace【Java从入门到精通】 | 150 | xiezhr001 |
| 5 | 10005 | 公众号XiezhrSpace【Idea从入门到上瘾】 | 200 | xiezhr001 |
| 6 | 10006 | 公众号XiezhrSpace【如何快速搭建个人博客】 | 120 | xiezhr |
+----+-----------+--------------------------------------------+-----------+-----------+
6 rows in set (0.00 sec) mysql> select * from product_price;
+----+-----------+-------+
| id | productid | price |
+----+-----------+-------+
| 1 | 10001 | 80 |
| 2 | 10002 | 79 |
| 3 | 10003 | 70 |
| 4 | 10004 | 120 |
| 5 | 10005 | 160 |
| 6 | 1006 | NULL |
+----+-----------+-------+
6 rows in set (0.00 sec)

删除数据

语法

# 1、单表删除
DELETE FROM 表名 【WHERE 筛选条件 】;
# 2、多表删除(级联删除)
① 关联删除
DELETE
表1的别名,
表2的别名
FROM
表1 别名,
表2 别名
WHERE 连接条件 AND 筛选条件 ;
② 内连接、左右连接删除
DELETE
表1的别名,
表2的别名
FROM
表1 别名
INNER | LEFT | RIGHT JOIN 表2 别名 ON 连接条件
WHERE 筛选条件 ;

实践操作

① 单表删除

# 删除产品id为10005的产品信息
mysql> select * from product;
+----+-----------+--------------------------------------------+-----------+-----------+
| id | productid | productname | saleprice | author |
+----+-----------+--------------------------------------------+-----------+-----------+
| 1 | 10001 | 公众号XiezhrSpace【Oralce从入门到放弃】 | 100 | xiezhr001 |
| 2 | 10002 | 公众号XiezhrSpace【MySQL从入门到放弃】 | 99 | xiezhr001 |
| 3 | 10003 | 公众号XiezhrSpace【快速上手Linux核心命令】 | 88 | xiezhr001 |
| 4 | 10004 | 公众号XiezhrSpace【Java从入门到精通】 | 150 | xiezhr001 |
| 5 | 10005 | 公众号XiezhrSpace【Idea从入门到上瘾】 | 200 | xiezhr001 |
| 6 | 10006 | 公众号XiezhrSpace【如何快速搭建个人博客】 | 120 | xiezhr |
+----+-----------+--------------------------------------------+-----------+-----------+
6 rows in set (0.00 sec) mysql> delete from product where productid = '10005';
Query OK, 1 row affected (0.02 sec) mysql> select * from product;
+----+-----------+--------------------------------------------+-----------+-----------+
| id | productid | productname | saleprice | author |
+----+-----------+--------------------------------------------+-----------+-----------+
| 1 | 10001 | 公众号XiezhrSpace【Oralce从入门到放弃】 | 100 | xiezhr001 |
| 2 | 10002 | 公众号XiezhrSpace【MySQL从入门到放弃】 | 99 | xiezhr001 |
| 3 | 10003 | 公众号XiezhrSpace【快速上手Linux核心命令】 | 88 | xiezhr001 |
| 4 | 10004 | 公众号XiezhrSpace【Java从入门到精通】 | 150 | xiezhr001 |
| 6 | 10006 | 公众号XiezhrSpace【如何快速搭建个人博客】 | 120 | xiezhr |
+----+-----------+--------------------------------------------+-----------+-----------+
5 rows in set (0.00 sec)

② 多表级联删除

mysql> select * from product;
+----+-----------+--------------------------------------------+-----------+-----------+
| id | productid | productname | saleprice | author |
+----+-----------+--------------------------------------------+-----------+-----------+
| 1 | 10001 | 公众号XiezhrSpace【Oralce从入门到放弃】 | 100 | xiezhr001 |
| 2 | 10002 | 公众号XiezhrSpace【MySQL从入门到放弃】 | 99 | xiezhr001 |
| 3 | 10003 | 公众号XiezhrSpace【快速上手Linux核心命令】 | 88 | xiezhr001 |
| 4 | 10004 | 公众号XiezhrSpace【Java从入门到精通】 | 150 | xiezhr001 |
| 6 | 10006 | 公众号XiezhrSpace【如何快速搭建个人博客】 | 120 | xiezhr |
+----+-----------+--------------------------------------------+-----------+-----------+
5 rows in set (0.00 sec) mysql> select * from product_price;
+----+-----------+-------+
| id | productid | price |
+----+-----------+-------+
| 1 | 10001 | 80 |
| 2 | 10002 | 79 |
| 3 | 10003 | 70 |
| 4 | 10004 | 120 |
| 5 | 10005 | 160 |
| 6 | 1006 | NULL |
+----+-----------+-------+
6 rows in set (0.00 sec) mysql> DELETE t1, t2 FROM product t1, product_price t2 WHERE t1.`productid` = t2.`productid` AND t1.`productid` = '10002';
Query OK, 2 rows affected (0.01 sec) mysql> select * from product;
+----+-----------+--------------------------------------------+-----------+-----------+
| id | productid | productname | saleprice | author |
+----+-----------+--------------------------------------------+-----------+-----------+
| 1 | 10001 | 公众号XiezhrSpace【Oralce从入门到放弃】 | 100 | xiezhr001 |
| 3 | 10003 | 公众号XiezhrSpace【快速上手Linux核心命令】 | 88 | xiezhr001 |
| 4 | 10004 | 公众号XiezhrSpace【Java从入门到精通】 | 150 | xiezhr001 |
| 6 | 10006 | 公众号XiezhrSpace【如何快速搭建个人博客】 | 120 | xiezhr |
+----+-----------+--------------------------------------------+-----------+-----------+
4 rows in set (0.00 sec) mysql> select * from product_price;
+----+-----------+-------+
| id | productid | price |
+----+-----------+-------+
| 1 | 10001 | 80 |
| 3 | 10003 | 70 |
| 4 | 10004 | 120 |
| 5 | 10005 | 160 |
| 6 | 1006 | NULL |
+----+-----------+-------+
5 rows in set (0.00 sec)
mysql> select * from product;
+----+-----------+--------------------------------------------+-----------+-----------+
| id | productid | productname | saleprice | author |
+----+-----------+--------------------------------------------+-----------+-----------+
| 1 | 10001 | 公众号XiezhrSpace【Oralce从入门到放弃】 | 100 | xiezhr001 |
| 3 | 10003 | 公众号XiezhrSpace【快速上手Linux核心命令】 | 88 | xiezhr001 |
| 4 | 10004 | 公众号XiezhrSpace【Java从入门到精通】 | 150 | xiezhr001 |
| 6 | 10006 | 公众号XiezhrSpace【如何快速搭建个人博客】 | 120 | xiezhr |
+----+-----------+--------------------------------------------+-----------+-----------+
4 rows in set (0.00 sec) mysql> select * from product_price;
+----+-----------+-------+
| id | productid | price |
+----+-----------+-------+
| 1 | 10001 | 80 |
| 3 | 10003 | 70 |
| 4 | 10004 | 120 |
| 5 | 10005 | 160 |
| 6 | 1006 | NULL |
+----+-----------+-------+
5 rows in set (0.00 sec) mysql> DELETE t1, t2 FROM product_price t2 INNER JOIN product t1 ON t1.`productid` = t2.`productid` WHERE t1.`productid` = '10003';
Query OK, 2 rows affected (0.01 sec) mysql> select * from product;
+----+-----------+-------------------------------------------+-----------+-----------+
| id | productid | productname | saleprice | author |
+----+-----------+-------------------------------------------+-----------+-----------+
| 1 | 10001 | 公众号XiezhrSpace【Oralce从入门到放弃】 | 100 | xiezhr001 |
| 4 | 10004 | 公众号XiezhrSpace【Java从入门到精通】 | 150 | xiezhr001 |
| 6 | 10006 | 公众号XiezhrSpace【如何快速搭建个人博客】 | 120 | xiezhr |
+----+-----------+-------------------------------------------+-----------+-----------+
3 rows in set (0.00 sec) mysql> select * from product_price;
+----+-----------+-------+
| id | productid | price |
+----+-----------+-------+
| 1 | 10001 | 80 |
| 4 | 10004 | 120 |
| 5 | 10005 | 160 |
| 6 | 1006 | NULL |
+----+-----------+-------+
4 rows in set (0.00 sec)

小结

  • 这篇文章主要说了MySQL中单表多表的增删改,在update、delete 使用的时候一定要细心
  • 除非打算更新删除表中所有数据,否则绝对不要使用不带where子句的update或delete语句
  • 保证每个表都有主键
  • 在对update或delete语句使用where子句之前,先用select进行查询测试,保证过滤出来的记录是正确的;
  • update或delete语句执行前,尽量做好数据备份

【必知必会的MySQL知识】③DML语言的更多相关文章

  1. mysql必知必会系列(一)

    mysql必知必会系列是本人在读<mysql必知必会>中的笔记,方便自己以后查看. MySQL. Oracle以及Microsoft SQL Server等数据库是基于客户机-服务器的数据 ...

  2. mysql 必知必会总结

    以前 mysql 用的不是很多, 2 天看了一遍 mysql 必知必会又复习了一下基础.  200 页的书,很快就能看完, 大部分知识比较基础, 但还是了解了一些以前不知道的知识点.自己做一个备份,随 ...

  3. MySql必知必会内容导图

    <MySQL必知必会>从介绍简单的数据检索开始,逐步深入一些复杂的内容,包括联结的使用.子查询.正则表达式和基于全文本的搜索.存储过程.游标.触发器.表约束,等等.通过重点突出的章节,条理 ...

  4. 《MySQL 必知必会》读书总结

    这是 <MySQL 必知必会> 的读书总结.也是自己整理的常用操作的参考手册. 使用 MySQL 连接到 MySQL shell>mysql -u root -p Enter pas ...

  5. mysql学习--mysql必知必会1

     例如以下为mysql必知必会第九章開始: 正則表達式用于匹配特殊的字符集合.mysql通过where子句对正則表達式提供初步的支持. keywordregexp用来表示后面跟的东西作为正則表達式 ...

  6. 《MySQL必知必会》[01] 基本查询

    <MySQL必知必会>(点击查看详情) 1.写在前面的话 这本书是一本MySQL的经典入门书籍,小小的一本,也受到众多网友推荐.之前自己学习的时候是啃的清华大学出版社的计算机系列教材< ...

  7. 《mysql必知必会》读书笔记--存储过程的使用

    以前对mysql的认识与应用只是停留在增删改查的阶段,最近正好在学习mysql相关内容,看了一本书叫做<MySQL必知必会>,看了之后对MySQL的高级用法有了一定的了解.以下内容只当读书 ...

  8. mysql必知必会

    春节放假没事,找了本电子书mysql必知必会敲了下.用的工具是有道笔记的markdown文档类型. 下面是根据大纲已经敲完的章节,可复制到有道笔记的查看,更美观. # 第一章 了解SQL## 什么是S ...

  9. python网络爬虫,知识储备,简单爬虫的必知必会,【核心】

    知识储备,简单爬虫的必知必会,[核心] 一.实验说明 1. 环境登录 无需密码自动登录,系统用户名shiyanlou 2. 环境介绍 本实验环境采用带桌面的Ubuntu Linux环境,实验中会用到桌 ...

  10. 《MySQL必知必会》整理

    目录 第1章 了解数据库 1.1 数据库基础 1.1.1 什么是数据库 1.1.2 表 1.1.3 列和数据类型 1.1.4 行 1.1.5 主键 1.2 什么是SQL 第2章 MySQL简介 2.1 ...

随机推荐

  1. 韦东山005_ARM裸机1期加强版

    005_ARM裸机1期加强版(又叫新1期,151节,23节免费,已完结)\新1期视频(151节,23节免费) 第006课开发板熟悉与体验(6节,免费) 第001节_开发板部件介绍与串口连接(免费) 如 ...

  2. 开源规则引擎——ice:致力于解决灵活繁复的硬编码问题

    背景介绍 业务中是否写了大量的 if-else?是否受够了这些 if-else 还要经常变动? 业务中是否做了大量抽象,发现新的业务场景还是用不上? 是否各种调研规则引擎,发现不是太重就是接入或维护太 ...

  3. CF1141 Div3 欢乐信心赛

    非常轻松的比赛,连我这样的菜鸡也感到充满力量. A 用类似于质因数分解的操作搞一搞即可. B 将环复制一遍. C 可以发现 \(q\) 就是差分数组.那么差分数组之和最大的地方就是原序列的最大值,为 ...

  4. 百度生成式AI产品文心一言邀你体验AI创作新奇迹:百度CEO李彦宏详细透露三大产业将会带来机遇(文末附文心一言个人用户体验测试邀请码获取方法,亲测有效)

    目录 中国版ChatGPT上线发布 强大中文理解能力 智能文学创作.商业文案创作 图片.视频智能生成 中国生成式AI三大产业机会 新型云计算公司 行业模型精调公司 应用服务提供商 总结 获取文心一言邀 ...

  5. 3分钟带你了解Hadoop是什么

    Hadoop是一种开源的分布式计算框架,它在Google的MapReduce论文发表后大受欢迎,并被广泛应用.Hadoop框架包括一个分布式文件系统(HDFS),它允许用户以分布式方式存储和管理大量数 ...

  6. Java 编程入门第一课:HelloWorld

    在之前的文章中,壹哥带大家搭建出了 Java 的开发环境,配置了 JDK 环境变量,并且我们也熟悉了 dos 命令行的操作.那么从这篇文章开始,壹哥就开始带各位真正地学习 Java 代码该怎么写. - ...

  7. python基础篇:Python基础知识,帮助初学者快速入门

    Python是一种高级编程语言,它易于学习和使用,因此成为了许多人的首选编程语言.本文将介绍Python的基础知识,以帮助初学者快速入门. 安装Python 在开始学习Python之前,您需要安装Py ...

  8. 配置 RSTP

    实验1-5-2 配置 RSTP [实验名称] 配置 RSTP. [实验目的] 理解快速生成树协议 RSTP 的配置及原理. [背景描述] 某学校为了开展计算机教学和网络办公,建立了一个计算机教室和一个 ...

  9. js函数防抖节流

    // 3.1 函数防抖: // 当持续触发事件时,一定时间段内没有再次触发事件,事件处理函数才会执行一次,如果设定时间到来之前,又触发了事件,就重新开始延时.// 也就是说当一个用户一直触发这个函数, ...

  10. 1.HVV介绍

    HVV介绍 1.护网职责划分 红队:打点人员.攻击人员.社工人员 蓝队:监控人员.研判人员.溯源人员 2.护网需要具备的技能 红队: 外围打点能力.漏洞挖掘能力.漏洞分析能力.权限提升能力.权限维持能 ...