『 MySQL数据库 』表的增删查改(CRUD)之表的数据插入及基本查询

文章目录

    • 📂 Create(创建/新增)
      • 📌全列插入与指定列插入📌
      • 📌单行数据插入与多行数据插入📌
      • 📌插入数据否则更新📌
      • 📌数据的替换📌
    • 📂 Retrieve(查询)
      • 📌SELECT语句📌
        • 全列查询 📨
        • 指定列查询 📨
        • 查询字段为表达式 📨
        • 查询结果取别名 📨
        • 去重 📨
      • 📌where条件📌
      • 📌比较运算符📌
      • 📌逻辑运算符📌
      • 📌结果排序📌
      • 📌筛选分页结果📌


📂 Create(创建/新增)

对于表内数据的创建无非就是对数据的插入;

INSERT [INTO] table_name
[(column [, column] ...)]
VALUES (value_list) [, (value_list)] ...
value_list: value, [, value] ...

存在一张表为:

mysql> create table if not exists stu(-> id int(2) unsigned zerofill primary key comment'id并设置主键约束',-> sn int(5) unsigned zerofill not null unique comment'学号',-> name varchar(20) not null comment'姓名',-> email varchar(32) null comment'邮箱'-> );
Query OK, 0 rows affected (0.00 sec)mysql> desc stu;
+-------+--------------------------+------+-----+---------+-------+
| Field | Type                     | Null | Key | Default | Extra |
+-------+--------------------------+------+-----+---------+-------+
| id    | int(2) unsigned zerofill | NO   | PRI | NULL    |       |
| sn    | int(5) unsigned zerofill | NO   | UNI | NULL    |       |
| name  | varchar(20)              | NO   |     | NULL    |       |
| email | varchar(32)              | YES  |     | NULL    |       |
+-------+--------------------------+------+-----+---------+-------+

📌全列插入与指定列插入📌

以该表为例,若是需要为该表插入数据,插入数据的方式分为全列插入指定列插入;

  • 全列插入

    全列插入指的是在插入数据时需要插入表中所有的字段;
    即表中有几个字段就需要根据字段个数与字段要求插入对应的数据;

    mysql> insert into stu values(1,1,'Lihua','123456@xx.com'); #全列插入
    Query OK, 1 row affected (0.00 sec)mysql> select * from stu;
    +----+-------+-------+---------------+
    | id | sn    | name  | email         |
    +----+-------+-------+---------------+
    | 01 | 00001 | Lihua | 123456@xx.com |
    +----+-------+-------+---------------+
    1 row in set (0.00 sec)
    

    在默认的插入中使用的即为全列插入,在全列插入时values前不需要使用()来指明需要插入 的字段,只需要在values后使用()按照字段顺序插入对应数据即可;
    语法:

    insert [into] table_name values (value_list) [, (value_list)] ...
    

    其中带[]的为可省略;

  • 指定列插入

    指定列插入,顾名思义是需要指定所插入的字段进行插入;

    mysql> insert into stu (id,name,sn)value(2,'Zhangqian',2);#指定列插入
    Query OK, 1 row affected (0.00 sec)mysql> select * from stu;
    +----+-------+-----------+---------------+
    | id | sn    | name      | email         |
    +----+-------+-----------+---------------+
    | 01 | 00001 | Lihua     | 123456@xx.com |
    | 02 | 00002 | Zhangqian | NULL          |
    +----+-------+-----------+---------------+
    2 rows in set (0.00 sec)
    

    如该段代码所示,这段代码演示了如何使用指定列插入,插入数据时在values前使用()指定了需要插入数据的字段,在插入数据时根据所指定字段的顺序以及对应的要求对表进行数据的插入;
    语法:

     insert [into] table_name [(column [, column] ...)/*指定列*/]values (value_list) [, (value_list)] ...
    

📌单行数据插入与多行数据插入📌

无论是全列插入还是指定列插入都能进行对应的单行数据与多行数据插入;
这表示在MySQL中对于各种条件的混用是十分灵活的;

  • 单行数据插入

    单行数据插入即在解释全列插入与指定列插入所使用的数据插入;
    mysql> insert into stu values(1,1,'Lihua','123456@xx.com'); #单行数据插入
    这个代码中为什么叫做单行数据插入?
    在MySQL中我们将字段称之为列,对应的行即为对应的一组数据;
    这里的values(1,1,'Lihua','123456@xx.com')即为插入一行数据,该行数据根据对应的字段如上;

  • 多行数据插入

    而要进行多行数据插入则可以直接使用,(value_list)来对数据进行追加;
    示例:(这里以全列插入为例,指定列插入不再作示范)

    mysql> insert into stu values(3,3,'Liqiang','112233'),(4,4,'Zhangwu','223344'),(5,5,'Liuba','445566');
    Query OK, 3 rows affected (0.00 sec)
    Records: 3  Duplicates: 0  Warnings: 0mysql> select * from stu;
    +----+-------+-----------+---------------+
    | id | sn    | name      | email         |
    +----+-------+-----------+---------------+
    | 01 | 00001 | Lihua     | 123456@xx.com |
    | 02 | 00002 | Zhangqian | NULL          |
    | 03 | 00003 | Liqiang   | 112233        |
    | 04 | 00004 | Zhangwu   | 223344        |
    | 05 | 00005 | Liuba     | 445566        |
    +----+-------+-----------+---------------+
    5 rows in set (0.00 sec)
    

📌插入数据否则更新📌

INSERT ... ON DUPLICATE KEY UPDATE
column = value [, column = value] ...

插入数据否则更新这个是为了应对当在插入数据时发生的主键冲突或者唯一键冲突
当插入数据时发生主键冲突或者唯一键冲突时使用这个语法时将会将原本的数据删除并以新的数据进行插入并替换该数据;
以该表为例:

+----+-------+-----------+---------------+
| id | sn    | name      | email         |
+----+-------+-----------+---------------+
| 01 | 00001 | Lihua     | 123456@xx.com | 
| 02 | 00002 | Zhangqian | NULL          |
| 03 | 00003 | Liqiang   | 112233        |
| 04 | 00004 | Zhangwu   | 223344        |
| 05 | 00005 | Liuba     | 445566        |
+----+-------+-----------+---------------+
mysql> show create table stu\G
*************************** 1. row ***************************Table: stu
Create Table: CREATE TABLE `stu` (`id` int(2) unsigned zerofill NOT NULL COMMENT 'id并设置主键约束',`sn` int(5) unsigned zerofill NOT NULL COMMENT '学号',`name` varchar(20) NOT NULL COMMENT '姓名',`email` varchar(32) DEFAULT NULL COMMENT '邮箱',PRIMARY KEY (`id`),UNIQUE KEY `sn` (`sn`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8

从上面的代码可以看出其中id字段设有主键约束,sn字段设有唯一键约束;
在不使用替换的语法前对其进行插入数据,且人为的触发其中一个约束冲突;

#主键冲突
mysql> insert into stu values(5,6,'Lianhua','22222');
ERROR 1062 (23000): Duplicate entry '05' for key 'PRIMARY'#唯一键冲突
mysql> insert into stu values(6,5,'Lianhua','22222');
ERROR 1062 (23000): Duplicate entry '00005' for key 'sn'

当发生冲突时使用语法使其完成当发生键值冲突进行替换;

mysql> insert into stu values(5,6,'Lianhua','22222') -> on duplicate key update id = 6,sn = 6,name ='LIANHUA',email='22222';
Query OK, 2 rows affected (0.00 sec)mysql> select * from stu;
+----+-------+-----------+---------------+
| id | sn    | name      | email         |
+----+-------+-----------+---------------+
| 01 | 00001 | Lihua     | 123456@xx.com |
| 02 | 00002 | Zhangqian | NULL          |
| 03 | 00003 | Liqiang   | 112233        |
| 04 | 00004 | Zhangwu   | 223344        |
| 06 | 00006 | LIANHUA   | 22222         | #->已经发生了替换
+----+-------+-----------+---------------+

从上面的操作可以看出原来的其中一个字段为:
| 05 | 00005 | Liuba | 445566 |
在这次插入失败后进行了替换,替换为了:
| 06 | 00006 | LIANHUA | 22222 |
不仅如此,在替换成功时也有对应的提示:
Query OK, 2 rows affected (0.00 sec)
在MySQL中以该方式进行数据插入时,会有对应提示:

-- 0 row affected: 表中有冲突数据,但冲突数据的值和 update 的值相等
-- 1 row affected: 表中没有冲突数据,数据被插入
-- 2 row affected: 表中有冲突数据,并且数据已经被更新

📌数据的替换📌

数据的替换类比于上一个插入数据否则更新;
数据的替换真正的意义上是:

  • 若是发生主键冲突或者唯一键冲突,则删除原数据再进行插入;
  • 若是未发生主键冲突也未发生唯一键冲突,则直接插入数据;
    对应的语法即为INSERT INTO变为REPLACE INTO;
mysql> replace into stu values(5,6,'Lianhua','22222');
Query OK, 2 rows affected (0.00 sec)

📂 Retrieve(查询)

在数据库中查询是一个非常频繁的工作,需要根据不同的场合以及不同的条件进行查找;

+----+---------+---------+------+---------+
| id | name    | chinese | math | english |
+----+---------+---------+------+---------+
|  1 | Lihua   |      67 |   88 |      90 |
|  2 | Liming  |      57 |   58 |      70 |
|  3 | Zhaolao |      66 |   80 |      47 |
|  4 | Wu      |      76 |   70 |      47 |
|  5 | Wuqi    |      88 |   43 |      80 |
|  6 | Liqiang |      89 |   92 |      90 |
|  7 | Qinsu   |      90 |   74 |      67 |
|  8 | Zhaoli  |      54 |   74 |     100 |
+----+---------+---------+------+---------+

📌SELECT语句📌

在MySQL中SELECT语句是一个高频语句;
其功能可以根据条件对表数据进行查询;
其查询不单单能对数据,还能对表达式、函数等等…

mysql> select 1+1;
+-----+
| 1+1 |
+-----+
|   2 |
+-----+
1 row in set (0.00 sec)

全列查询 📨

在MySQL中*符号代表通配符;
SELECT * FROM table_name;
该句指令即表示查询表中所有字段(列);
以该中方式即可以打印出表中的所有字段的数据;

mysql> select * from Point;
+----+---------+---------+------+---------+
| id | name    | chinese | math | english |
+----+---------+---------+------+---------+
|  1 | Lihua   |      67 |   88 |      90 |
|  2 | Liming  |      57 |   58 |      70 |
|  3 | Zhaolao |      66 |   80 |      47 |
|  4 | Wu      |      76 |   70 |      47 |
|  5 | Wuqi    |      88 |   43 |      80 |
|  6 | Liqiang |      89 |   92 |      90 |
|  7 | Qinsu   |      90 |   74 |      67 |
|  8 | Zhaoli  |      54 |   74 |     100 |
+----+---------+---------+------+---------+

指定列查询 📨

指定列查询,顾名思义就是指定对应的字段进行查询;
语句:SELECT 字段1,字段2... FROM table_name;
示例:

mysql> select name,chinese from Point;
+---------+---------+
| name    | chinese |
+---------+---------+
| Lihua   |      67 |
| Liming  |      57 |
| Zhaolao |      66 |
| Wu      |      76 |
| Wuqi    |      88 |
| Liqiang |      89 |
| Qinsu   |      90 |
| Zhaoli  |      54 |
+---------+---------+

查询字段为表达式 📨

SELECT不仅能查询表中的字段,也能查询表达式;
示例:

mysql> select name,chinese,6 from Point;
+---------+---------+---+
| name    | chinese | 6 |
+---------+---------+---+
| Lihua   |      67 | 6 |
| Liming  |      57 | 6 |
| Zhaolao |      66 | 6 |
| Wu      |      76 | 6 |
| Wuqi    |      88 | 6 |
| Liqiang |      89 | 6 |
| Qinsu   |      90 | 6 |
| Zhaoli  |      54 | 6 |
+---------+---------+---+

在该次查询中查询的除了字段以外还查询了一个常量表达式;


查询结果取别名 📨

当一个查询的字段由一个较为复杂的表达式合成时,可以将该表达式使用as将其改名;
需要注意的是,在SELECT查询为结果的字段进行改名时,这个操作一般是靠后的,即将数据处理完后将其打印时才能将其进行改名,所以不能先进行改名再将其进行其他操作;
示例:

mysql> select name,chinese+math+english as '总分' from Point;
+---------+--------+
| name    | 总分   |
+---------+--------+
| Lihua   |    245 |
| Liming  |    185 |
| Zhaolao |    193 |
| Wu      |    193 |
| Wuqi    |    211 |
| Liqiang |    271 |
| Qinsu   |    231 |
| Zhaoli  |    228 |
+---------+--------+

其中这里的as可以省略不写;


去重 📨

这里的去重指的是对最终的结果在显示前进行去重;
其语法即为SELECT DISTINCT 字段 FROM table_name;

mysql> select math from Point; # 未使用去重
+------+
| math |
+------+
|   88 |
|   58 |
|   80 |
|   70 |
|   43 |
|   92 |
|   74 |
|   74 |
+------+mysql> select distinct math from Point; # 结果去重
+------+
| math |
+------+
|   88 |
|   58 |
|   80 |
|   70 |
|   43 |
|   92 |
|   74 |
+------+

📌where条件📌

在大部分的情况下,SELECT在查询数据时应该配合着行的限制与列的限制从而达到筛选数据的效果;
若是不对数据进行筛选而是无脑选择SELECT * FROM table_name;来将数据进行全部显示的话可能会因为数据量过于庞大不便于观察且并没有筛选出需要条件的数据而做出的无用查看;
在MySQL中可以使用where条件来为SELECT查看的数据做出对应的条件限制从而达到能够查看到对应的数据;
同样的接下来的操作将基于上表进行;


📌比较运算符📌

  • > , >= , < , <=
    若是满足条件则显示1,否则显示0;

    mysql> select 1>2;
    +-----+
    | 1>2 |
    +-----+
    |   0 |
    +-----+
    1 row in set (0.00 sec)mysql> select 1<2;
    +-----+
    | 1<2 |
    +-----+
    |   1 |
    +-----+
    1 row in set (0.00 sec)
    

    示例:
    显示出math大于90的人的名字与成绩

    mysql> select name,math from Point where math>90;
    +---------+------+
    | name    | math |
    +---------+------+
    | Liqiang |   92 |
    +---------+------+
    

  • =<=>

    在MySQL中的等于有两种,分别为以上两种;
    两种的等于在实质性的使用层面并没有太多的区别;
    唯一的区别只是对NULL进行判断;

    #--------------------------------------
    mysql> select 1 = 1;
    +-------+
    | 1 = 1 |
    +-------+
    |     1 |
    +-------+mysql> select 1 = 2;
    +-------+
    | 1 = 2 |
    +-------+
    |     0 |
    +-------+mysql> select NULL = NULL;
    +-------------+
    | NULL = NULL |
    +-------------+
    |        NULL |
    +-------------+
    #--------------------------------------
    mysql> select 1<=>1;
    +-------+
    | 1<=>1 |
    +-------+
    |     1 |
    +-------+mysql> select 1<=>2;
    +-------+
    | 1<=>2 |
    +-------+
    |     0 |
    +-------+mysql> select NULL<=>NULL;
    +-------------+
    | NULL<=>NULL |
    +-------------+
    |           1 |
    +-------------+
    #--------------------------------------
    

  • 不等于 !=<>

    在MySQL中的不等于为以上两种,但是无论哪种不等于都无法对NULL做比较;

    mysql> select NULL <> NULL;
    +--------------+
    | NULL <> NULL |
    +--------------+
    |         NULL |
    +--------------+
    1 row in set (0.00 sec)mysql> select NULL = NULL;
    +-------------+
    | NULL = NULL |
    +-------------+
    |        NULL |
    +-------------+
    1 row in set (0.00 sec)
    

  • 范围匹配BETWEEN a0 AND a1

    范围匹配一般用来判断一个数是否属于该范围内,且该范围属于左闭右闭区间([a0,a1]);

    mysql> select 5 between 0 and 10;
    +--------------------+
    | 5 between 0 and 10 |
    +--------------------+
    |                  1 |
    +--------------------+
    1 row in set (0.00 sec)
    

    示例:找出math区间为[70,75]的数据:

    mysql> select name,math from Point where math between 70 and 75;
    +--------+------+
    | name   | math |
    +--------+------+
    | Wu     |   70 |
    | Qinsu  |   74 |
    | Zhaoli |   74 |
    +--------+------+
    

  • 该数据是否为一组数据中的其中一个IN (option,...)

    该运算符一般判断一个数据是否存在于一组数据中;

    mysql> select 12 in (10,12,14);
    +------------------+
    | 12 in (10,12,14) |
    +------------------+
    |                1 |
    +------------------+
    1 row in set (0.00 sec)
    

    示例:分别找出english为(70,80,90,100)的数据;

    mysql> select name,english from Point where english in (70,80,90,100);
    +---------+---------+
    | name    | english |
    +---------+---------+
    | Lihua   |      90 |
    | Liming  |      70 |
    | Wuqi    |      80 |
    | Liqiang |      90 |
    | Zhaoli  |     100 |
    +---------+---------+
    5 rows in set (0.00 sec)
    

  • 是NULL IS NULL 与 非NULL IS NOT NULL

    该运算符一般用来判断一个字段是否为NULL;

    mysql> select NULL IS NULL;
    +--------------+
    | NULL IS NULL |
    +--------------+
    |            1 |
    +--------------+
    1 row in set (0.00 sec)mysql> select NULL IS NOT  NULL;
    +-------------------+
    | NULL IS NOT  NULL |
    +-------------------+
    |                 0 |
    +-------------------+
    1 row in set (0.00 sec)
    

  • 模糊匹配LIKE

    该运算符一般用来模糊匹配,其中%表示多个(包括0)个任意字符,_表示任意一个字符;
    示例:分别找出name为W的字段与W_ 的字段;

    mysql> select * from Point where name like 'W%';
    +----+------+---------+------+---------+
    | id | name | chinese | math | english |
    +----+------+---------+------+---------+
    |  4 | Wu   |      76 |   70 |      47 |
    |  5 | Wuqi |      88 |   43 |      80 |
    +----+------+---------+------+---------+mysql> select * from Point where name like 'W_';
    +----+------+---------+------+---------+
    | id | name | chinese | math | english |
    +----+------+---------+------+---------+
    |  4 | Wu   |      76 |   70 |      47 |
    +----+------+---------+------+---------+
    

📌逻辑运算符📌

运算符说明
AND多个条件为TRUE(1)时结果为TRUE(1);
OR任意一个条件为TRUE(1)时结果为TRUE(1);
NOT条件为TRUE(1)时结果为FALSE(0);

📌结果排序📌

结果排序可以将数据再处理完时对其进行排序处理(一般该操作的顺序为最后的操作);
且没有进行ORDER BY子句的查询所返回的结果顺序一般都是未定义的,即不可靠的;
语法:

SELECT ... FROM table_name [ WHERE ... ]ORDER BY column [ASC|DESC],[...];#其中:#ASC为升序,DESC为降序;#默认为ASC升序;

示例:
显示namemath的字段且math为升序的条件显示;

mysql> select name,math from Point order by math ASC;
+---------+------+
| name    | math |
+---------+------+
| Wuqi    |   43 |
| Liming  |   58 |
| Wu      |   70 |
| Qinsu   |   74 |
| Zhaoli  |   74 |
| Zhaolao |   80 |
| Lihua   |   88 |
| Liqiang |   92 |
+---------+------+
8 rows in set (0.00 sec)

📌筛选分页结果📌

在MySQL中经常会因为数据量过大而导致不便于数据的观察;
而在MySQL中有这么一条语句可以便于结果的观察,即为筛选分页结果;
语法:

#分页时的起始下标为0;SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n;
-- 从起始下标开始筛选n条结果;SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT s,n;
-- 从s开始,筛选n条结果SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n OFFSET s;
-- 从s开始,筛选n条结果(该方法的表达更为明确)

示例:
查看namemath字段并使用order by以降序的方式进行排序最终结果每页显示3条;

mysql> SELECT name,math from Point order by math desc limit 3 offset 0;
+---------+------+
| name    | math |
+---------+------+
| Liqiang |   92 |
| Lihua   |   88 |
| Zhaolao |   80 |
+---------+------+
3 rows in set (0.01 sec)mysql> SELECT name,math from Point order by math desc limit 3 offset 3;
+--------+------+
| name   | math |
+--------+------+
| Qinsu  |   74 |
| Zhaoli |   74 |
| Wu     |   70 |
+--------+------+
3 rows in set (0.00 sec)mysql> SELECT name,math from Point order by math desc limit 3 offset 6;
+--------+------+
| name   | math |
+--------+------+
| Liming |   58 |
| Wuqi   |   43 |
+--------+------+
2 rows in set (0.00 sec)

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

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

相关文章

华为ospf路由协议防环和次优路径中一些难点问题分析

第一种情况是ar3的/0/0/2口和ar4的0/0/2口发布在区域1时&#xff0c;当ar1连接ar2的线断了以后&#xff0c;骨干区域就断了&#xff0c;1.1.1.1到2.2.2.2就断了&#xff0c;ping不通了。但ar5和ar6可以ping通2.2.2.2和1.1.1.1&#xff0c;ar3和ar4不可以ping通2.2.2.2和1.1.1.1…

部分移动端独有的JS事件

手机移动端独有的JS事件通常包括触摸事件、重力感应事件和设备旋转事件等。这些事件使得我们能够在移动设备上创建更加丰富和交互性更强的应用程序。 以下是一些手机移动端独有的JS事件的说明和代码示例&#xff1a; 触摸事件&#xff1a; 触摸事件包括touchstart、touchmov…

Python基础入门例程70-NP70 首都(字典)

最近的博文: Python基础入门例程69-NP69 姓名与学号(字典)-CSDN博客 Python基础入门例程68-NP68 毕业生就业调查(字典)-CSDN博客 Python基础入门例程67-NP67 遍历字典(字典)-CSDN博客 目录 最近的博文: 描述

软件测试 | MySQL 主键自增详解:实现高效标识与数据管理

&#x1f4e2;专注于分享软件测试干货内容&#xff0c;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01;&#x1f4e2;交流讨论&#xff1a;欢迎加入我们一起学习&#xff01;&#x1f4e2;资源分享&#xff1a;耗时200小时精选的「软件测试」资…

The Bridge:从临床数据到临床应用(预测模型总结)

The Bridge:从临床数据到临床应用&#xff08;预测模型总结&#xff09; 如果说把临床预测模型比作临床数据和临床应用之间的一座“桥梁”&#xff0c;那它应该包括这样几个环节&#xff1a;模型的构建和评价、模型的概率矫正、模型决策阈值的确定和模型的局部再评价。 模型的构…

数据库实验7

实验报告&#xff08;七&#xff09;数据更新 1、实验目的 &#xff08;1&#xff09; 掌握插入、更新和删除表数据的方法 &#xff08;2&#xff09; 掌握更新操作与子查询结合的用法 2、实验预习与准备 &#xff08;1&#xff09; Update&#xff0c;Delete&am…

【LeetCode】每日一题 2023_11_24 统计和小于目标的下标对数目(暴力/双指针)

文章目录 刷题前唠嗑题目&#xff1a;统计和小于目标的下标对数目题目描述代码与解题思路 结语 刷题前唠嗑 LeetCode&#xff1f;启动&#xff01;&#xff01;&#xff01; 题目&#xff1a;统计和小于目标的下标对数目 题目链接&#xff1a;2824. 统计和小于目标的下标对数…

解决ssh -T git@github.com报错connection closed问题

解决ssh -T gitgithub.com报错connection closed问题 问题解决 问题 $ ssh -T gitgithub.com kex_exchange_identification: Connection closed by remote host Connection closed by 20.205.243.166 port 22解决 参考链接 $ ssh -T -p 443 gitssh.github.com

C/C++ 运用Npcap发送UDP数据包

Npcap 是一个功能强大的开源网络抓包库&#xff0c;它是 WinPcap 的一个分支&#xff0c;并提供了一些增强和改进。特别适用于在 Windows 环境下进行网络流量捕获和分析。除了支持通常的网络抓包功能外&#xff0c;Npcap 还提供了对数据包的拼合与构造&#xff0c;使其成为实现…

Java面试题09

1.什么是反射&#xff1f; 反射是Java中的一种机制&#xff0c;允许在运行时获取类的信息、访问对象的属性和方法&#xff0c;以及调用 对象的方法&#xff0c;使得编程更加灵活&#xff0c;但也需要注意性能和安全问题。 在Java中&#xff0c;反射&#xff08;Reflection&…

conda: error: argument COMMAND: invalid choice

简介 使用conda activate 时&#xff0c;可能会报&#xff1a;conda: error: argument COMMAND: invalid choice: ‘activate’ (choose from ‘clean’, ‘compare’, ‘config’, ‘create’, ‘info’, ‘init’, ‘install’, ‘list’, ‘notices’, ‘package’, ‘remo…

Node.js 处理Mysql包含单引号字符字段

一、异步处理的方式 // 引入mysql模块const mysql require(mysql); // 创建数据库连接const connection mysql.createConnection({ host: localhost, user: your_username, password: your_password, database: your_database }); // 连接到数据库connection.conn…

【迅搜03】全文检索、文档、倒排索引与分词

全文检索、文档、倒排索引与分词 今天还是概念性的内容&#xff0c;但是这些概念却是整个搜索引擎中最重要的概念。可以说&#xff0c;所有的搜索引擎就是实现了类似的概念才能称之为搜索引擎。而且今天的内容其实都是相关联的&#xff0c;所以不要以为标题上有四个名词就感觉好…

【探索Linux】—— 强大的命令行工具 P.16(进程信号 —— 信号产生 | 信号发送 | 核心转储)

阅读导航 引言一、概念&#xff08;1&#xff09;基本概念&#xff08;2&#xff09;kill -l命令&#xff08;察看系统定义的信号列表&#xff09; 二、产生信号&#xff08;1&#xff09;通过终端按键产生信号-- 信号产生-- Core Dump&#xff08;核心转储&#xff09; &#…

ZC-OFDM模糊函数原理及仿真

文章目录 前言一、ZC 序列二、ZC-OFDM 信号1、OFDM 信号表达式2、模糊函数表达式三、MATLAB 仿真1、MATLAB 核心源码2、仿真结果①、ZC-OFDM 模糊函数②、ZC-OFDM 距离分辨率③、ZC-OFDM 速度分辨率前言 本文进行 ZC-OFDM 的原理讲解及仿真,首先看一下 ZC-OFDM 的模糊函数仿真…

【持续更新】汇总了一份前端领域必看面试题

文章目录 1. 写在前面2. 前端面试汇总2.0.1. 如何提⾼webpack的打包速度2.0.2. 数组去重2.0.3. 前端有几种缓存方式&#xff1f;2.0.4. nextTick描述一下&#xff1f;2.0.5. Webpack层面的优化&#xff1f;2.0.6. 代码层面的优化&#xff1f;2.0.7. Web 技术的优化&#xff1f;…

【C++】PACS医学图像存储和传输系统源码带三维重建

PACS&#xff08;Picture Archiving and Communication System&#xff09;系统作为医学图像的存储和传输平台&#xff0c;为医生和患者提供了便捷高效的诊疗服务支持。近年来&#xff0c;三维重建技术在PACS系统中的应用越来越广泛。 三维后处理功能是临床数字技术中的重要组成…

【Linux】Linux权限管理

目录 一、Linux中权限的概念 二、 Linux下的用户 2.1 用户的类型 2.2 用户创建、切换和删除 2.2.1 useradd或adduser命令创建用户 2.2.2 passwd命令设置用户密码 2.2.3 userdel命令删除用户 2.2.4 su命令切换用户身份等来管理和操作用户 2.3 注意事项 三、权限的管理…

浅析基于物联网的远程抄表系统的设计及应用

安科瑞 华楠 摘 要&#xff1a;本文基于物联网的概念&#xff0c;使用 ZigBee、通用分组无线服务技术两种无线通信技术相结合的方式实现远程抄表并对数据进行存储和管理。此系统设计主要分为硬件方面的设计和软件方面的设计&#xff0c;硬件方面的设计需要完成三个部分的硬件制…

redis运维(二十)redis 的扩展应用 lua(二)

一 redis 的扩展应用 lua redis lua脚本语法 ① 什么是脚本缓存 redis 缓存lua脚本 说明&#xff1a; 重启redis,脚本缓存会丢失 下面讲解 SCRIPT ... 系列 SCRIPT ② LOAD 语法&#xff1a;SCRIPT LOAD lua代码 -->载入一个脚本,只是预加载,不执行思考1&#xff1…