首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Excel应用实践16:搜索工作表指定列范围中的数据并将其复制到另一个工作表中

学习Excel技术,关注微信公众号: excelperfect 这里的应用场景如下: “在工作表Sheet1中存储着数据,现在想要在该工作表的第O列至第T列中搜索指定的数据,如果发现,则将该数据所在行复制到工作表...Sheet2中。...用户在一个对话框中输入要搜索的数据值,然后自动将满足前面条件的所有行复制到工作表Sheet2中。” 首先,使用用户窗体设计输入对话框,如下图1所示。 ?...Set wks = Worksheets("Sheet1") With wks '工作表中的最后一个数据行 lngRow = .Range("A" &Rows.Count...Sheets("Sheet2").Cells.Clear '获取数据单元格所在的行并复制到工作表Sheet2 For Each rngFoundCell

6.1K20

Django 外键引用另一个表中的多个字段

在 Django 中,外键(ForeignKey)通常只引用另一张表的一个字段,比如一个主键或一个唯一标识字段。然而,如果我们需要让一个外键引用另一张表中的多个字段,通常有以下几种方法来实现这种关系。...1、问题背景在 Django 中,模型之间的关系通常使用外键(ForeignKey)来建立。外键允许一个模型中的字段引用另一个模型中的主键。然而,有时我们需要在一个模型中引用另一个模型中的多个字段。...我们还有另一个 sales_process 表,其中包含销售过程的信息,如潜在客户、员工、首次联系时间等。...2、解决方案为了在 sales_process 表中引用 product_models 表中的多个字段,我们可以使用复合主键(Composite Key)的方式。复合主键是指由多个字段组成的主键。...以下是如何在 Django 中使用复合主键来实现外键引用另一个表中的多个字段:在 product_models 模型中,添加一个 id 字段作为主键:class product_models(models.Model

10410
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    数据库SQL语言从入门到精通--Part 4--SQL语言中的模式、基本表、视图

    ** 4.FOREGIN KEY(外键)约束:** 定义了一个表中数据与另一个表中的数据的联系。...FOREGIN KEY约束指定某一个列或一组列作为外部键,其中包含外部键的表称为子表,包含外部键所引用的主键的表称为父表。...系统保证,表在外部键上的取值要么是父表中某一主键,要么取空值,以此保证两个表之间的连接,确保了实体的参照完整性。 通俗的说,外键是对另一个表中主键的引用。...如果公共关键字在一个关系中是主关键字,那么这个公共关键字被称为另一个关系的外键(FK)。即,当一张二维表(如表A)的主关键字被包含在另一张二维表(如表B)中时,A表中的主关键字便成为B表的外关键字。...DROP COLUMN 子句用于删除表中的列如果指定了CASCADE短语,则自动删除引用了该列的其他对象如果指定了RESTRICT短语,则如果该列被其他对象引用,关系数据库管理系统将拒绝删除该列 DROP

    2.2K10

    (超级详细的SQL基础,你还不会的话就别学数据库了)

    ** 4.FOREGIN KEY(外键)约束:** 定义了一个表中数据与另一个表中的数据的联系。...FOREGIN KEY约束指定某一个列或一组列作为外部键,其中包含外部键的表称为子表,包含外部键所引用的主键的表称为父表。...系统保证,表在外部键上的取值要么是父表中某一主键,要么取空值,以此保证两个表之间的连接,确保了实体的参照完整性。 通俗的说,外键是对另一个表中主键的引用。...如果公共关键字在一个关系中是主关键字,那么这个公共关键字被称为另一个关系的外键(FK)。即,当一张二维表(如表A)的主关键字被包含在另一张二维表(如表B)中时,A表中的主关键字便成为B表的外关键字。...DROP COLUMN 子句用于删除表中的列如果指定了CASCADE短语,则自动删除引用了该列的其他对象如果指定了RESTRICT短语,则如果该列被其他对象引用,关系数据库管理系统将拒绝删除该列 DROP

    72930

    数据定义: CREATE、DROP、ALTER

    122 123 在 MySQL 4.1 中你可以使用 LIKE 来基于一个表定义创建另一个表。...另一方面,为了使 MySQL 客户端更容易地使用 TIMESTAMP 列,服务器报告这样的列被赋值为 NULL 值(这是真的),即使 TIMESTAMP 实际上决不会包含一个 NULL 值。...另一方面,如果所有的键都是不同的,你将在每个键上损失 1 字节,如果该键不是一个可以有 NULL 值的键。(在这种情况下,压缩后键的长度将存储在用于键是否为 NULL 的位元组中。)...这在任何方面都不影响你如何使用该列;在 MySQL 中,VARCHAR 只是存储字符的另一个不同的方法。MySQL 执行这个转换,是因为它节省空间,并且使表操作更快。...如果组成一个索引的所有列均被移除了,那么,该索引也将被移除。 341 342 如果一个表只包含一个列,那么该列不能被移除。如果你本就打算移除该表,请使用 DROP TABLE 代替。

    1.6K20

    MariaDB 创建索引

    索引是一个单独的、存储在磁盘上的数据库结构,它们包含着对数据表里所有记录的引用指针.使用索引用于快速找出在某个或多个列中有一特定值的行,所有MySQL列类型都可以被索引,对相关列使用索引是提高查询操作速度的最佳途径...1.普通索引:MySQL中的基本索引类型,允许在定义索引的列中插入重复值和空值. 2.唯一索引:索引列的值必须唯一,但允许有空值.如果是组合索引,则列值的组合必须唯一. 3.主键索引:一种特殊的唯一索引...,不允许有空值. 4.单列索引:即一个索引只包含单个列,一个表可以有多个单列索引. 5.组合索引:指在表的多个字段组合上创建的索引,使用组合索引时遵循最左前缀集合. 6.全文索引:允许在这些索引列中插入重复值和空值...● ref:行给出了关联关系中另一个数据表里的数据列的名字 ● rows:行是MySQL在执行这个查询时预计会从这个数据表里读出的数据行的个数 ● extra:行提供了与关联操作有关的信息...字段长度为30,在组合索引中序列为1该字段不许为空NULL,info字段长度为50,在组合索引中的序号为2,该字段可以为空值NULL.

    3.3K10

    《Oracle性能优化求生指南》-第四章:数据库逻辑设计和物理设计-学习小结-1

    是由实体中具有唯一性的自然属性构成的。 如果自然键被更新,则引用它的外键也需要更新,这将显著增加IO开销和锁争用。...位图索引和(部分列为NULL的)多列组合索引就能存储NULL值。 采用NULL可以降低行的平均长度,从而一定程度上提高全表扫描的性能。...如果该列的数值大部分是NULL,并且查询仅需检索非NULL的值,则该列上的索引会比较紧凑并很高效。 因此,决定一列是否可以为NULL的时候,要考虑在该列上是否有使用B*树索引查询NULL的需求。...如果有,则不能指定该列为NULL,取而代之的是定义该列为NOT NULL(非空),并指定一个默认值。 如果要查询那些未知的值,则不能定义列为空,相反,要定义列为非空并指定一个默认值。...物化视图本质是一个物理表,它包含了将会由视图的定义返回的记录。如果将普通的视图看做存储在数据库中的查询语句,物化视图就可以被看作是数据库中存储的查询结果。

    1.7K40

    SQL的几种连接:内连接、左联接、右连接、全连接、交叉连接

    其查询结果中列出被连接表中的所有列,包括其中的重复列。...1.3.自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询结果集合中所包括的列,并删除连接表中的重复列。...2.外连接 2.1.左联接:是以左表为基准,将a.stuid = b.stuid的数据进行连接,然后将左表没有的对应项显示,右表的列为NULL select * from book as a left...join stu as b on a.sutid = b.stuid 2.2.右连接:是以右表为基准,将a.stuid = b.stuid的数据进行连接,然以将右表没有的对应项显示,左表的列为NULL...当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。

    3.3K40

    MySQL 的约束和索引专题

    ❑ 每行都具有一个主键值(即列中不允许NULL值)。 ❑ 包含主键值的列从不修改或更新。(大多数 DBMS 不允许这么做,但如果你使用的 DBMS 允许这样做,好吧,千万别!)...如果从表中删除某一行,其主键值不分配给新行。 外键约束 外键是表中的一列,其值必须列在另一表的主键中。外键是保证引用完整性的极其重要部分。...提示:外键有助防止意外删除,除帮助保证引用完整性外,外键还有另一个重要作用。在定义外键后,DBMS 不允许删除在另一个表中具有关联行的行。例如,不能删除关联订单的顾客。...❑ 表可包含多个唯一约束,但每个表只允许一个主键。 ❑ 唯一约束列可包含 NULL 值。 ❑ 唯一约束列可修改或更新。 ❑ 唯一约束列的值可重复使用。...普通索引 创建索引的基本方式 CREATE INDEX indexName ON table_name (column_name) ON 用来指定被索引的表,而索引中包含的列(此例中仅有一列)在表名后的圆括号中给出

    1.6K30

    PostgreSQL中的查询简介

    有几种方法可以从数据库中检索信息,但最常用的方法之一是通过命令行提交查询来执行。 在关系数据库管理系统中,查询是用于从表中检索数据的任何命令。...除了FROM和WHERE之外,最常用的查询子句之一是GROUP BY子句。它通常在您对一列执行聚合函数时使用,但与另一列中的匹配值相关。 例如,假设您想知道有多少朋友更喜欢您制作的三个主菜中的每一个。...为了说明这个想法,让我们在每个表中添加一个新行,而另一个表中没有相应的条目: INSERT INTO tourneys (name, wins, best, size) VALUES ('Bettye...查询多个表的另一种方法是使用子查询。子查询(也称为内部或嵌套查询)是包含在另一个查询中的查询。这些在您尝试根据单独的聚合函数的结果过滤查询结果的情况下非常有用。...,还包含该子查询中的子查询。

    12.4K52

    数据库之数据表控制语句

    3、设置值的唯一性(不允许重复数据,可以为空,但只能有一个空,否则就会被视为重复) mysql> create table tab4( -> id int not null unique,...可以看到其被标识为了主键,但是在创建时并没有指定它是主键,而是这一列的属性基本满足了主键的要求,如唯一、不可以为空。...4、设置列的默认值(如果该列为空,则写入默认值) mysql> create table tab5( -> id int(2) not null, -> name varchar(20)...+-------+ 从表(sub)的某列引用(ref)主表(main)的某列的值。...比方学生表有个学生编号(sid),分数表中的学生列(stu)引用学生表的学 生编号,此时对于分数表的 stu 来说。学生表的 sid 就是外键。 从表也叫外键表,主表也叫主键表、外表,列也叫字段。

    1.1K40

    MySQL 约束

    外键约束 外键约束用于建立表与表之间的关系,确保引用另一个表中的值时的完整性。 外键约束经常和主键约束一起使用,用来确保数据的完整性,即保证该字段的值必须来自于主表的关联列的值。...在从表添加外键约束,用于引用主表中某列的值。 例如,在员工信息表中,员工所属部门是一个外键,因为该字段是部门表的主键。...如果某个数据列的类型是整型,而且该列作为主键列,则可指定该列为具有自增长功能。指定自增长功能通常用于逻辑主键列,该列没有任何物理意义,仅仅为了标识每一行。...CHECK (c1 c2) 是表约束:它出现在任何列定义之外,因此它可以(并且确实)引用多个表列。 此约束包含对尚未定义的列的前向引用。没有指定约束名称,因此 MySQL 生成一个名称。...MySQL 为另一个生成一个名称。 创建默认值约束 建表时在字段后使用 DEFAULT 添加默认值可创建默认值约束。

    23110

    Springboot2.0教程(12)

    另一个很好的例子就是测试库。我们通常使用Spring Test,JUnit,Hamcrest和Mockito库。在Spring项目中,我们应该将所有这些库添加为依赖项。...它用在一个索引的所有部分被联接使用并且索引是UNIQUE或PRIMARY KEY。eq_ref可以用于使用= 操作符比较的带索引的列。比较值可以为常量或一个使用在该表前面所读取的表的列的表达式。...ref可以用于使用=或操作符的带索引的列。 ref_or_null:该联接类型如同ref,但是添加了MySQL可以专门搜索包含NULL值的行。在解决子查询中经常使用该联接类型的优化。...key列显示使用了哪个索引。key_len包含所使用索引的最长关键元素。在该类型中ref列为NULL。...通常可以增加更多的索引而不要使用ALL,使得行能基于前面的表中的常数值或列值被检索出。 possible_keys:possible_keys列指出MySQL能使用哪个索引在该表中找到行。

    68100

    YashanDB数据完整性

    如果表中已包含数据,不能再添加一个具有NOT NULL约束的列,除非对应列还带有DEFAULT值定义。# 唯一约束唯一约束规定了在指定列或列集中的每个值都是唯一的。...通常,外键约束要求约束列或列集中的每个值都必须与另一个表的指定列中的值相匹配,例如教师所带的班级必须是班级信息表中存在(教师信息表到班级信息表的外键约束)。...术语定义外键/复合外键约束定义中包含的列称为外键,一个外键由多个列组成时称为复合外键。外键会引用另一个表的主键或唯一键,复合外键则需引用相同数量和数据类型列的复合主键或复合唯一键。...外键的值,要么匹配被引用主键或唯一键的值,要么为空。如果复合外键中存在空值列,该键的非空列不再强制要求匹配父项中的对应列。被引用键被外键所引用的表中的唯一键或主键。...依赖表又称“子表”,外键约束所在的表。被引用表又称“父表”,被子表的外键引用的表。该表中的被引用值决定了在子表中特定的插入或更新是否可被允许。

    5900

    《深入浅出SQL》问答录

    而且它也不等于另一个NULL,事实上,两个NULL根本不能放在一起比较。值可以是NULL,但是它不会等于NULL,因为NULL代表未定义的值!...TABLE your_table CHANGE your_id your_id INT(11) NOT NULL; 有一点要记住:每个表中只有一列可以加上AUTO_INCREMENT,该列必须为整形而且不能包含...A:外键为NULL,表示在父表中没有相符的主键。但我们可以确认外键包含有意义、已经存储在父表中的值,请通过约束实现。 不能单纯的使用另一张表的键,称之为外键,而不加上约束吗?...A:外键约束能确保引用完整性(换句话说,如果表中的某行有外键,约束能确保该行通过外键与另一张表中的某一行一一对应)。...创建别名真的很简单,在查询软件中首次使用原始列名的地方后接一个AS并设定要采用的别名,告诉软件现在开始要以另一个名称引用my_contacs表的profession列,这样可以让查询更容易被我们理解。

    2.9K50

    应用示例荟萃 | 全方位认识 information_schema

    对于外键约束,它表示被外键引用列在其所在表中的索引中的位置顺序 REFERENCED_TABLE_SCHEMA:约束引用表所在的数据库名称,这里指外键所引用的表所在的数据库名 REFERENCED_TABLE_NAME...如果没有STARTS子句,则此列为NULL ENDS:对于其定义中包含ENDS子句的重复事件,此列包含相应的DATETIME值。...如果没有ENDS子句,则此列为NULL STATUS:该列包含三个有效值,ENABLED、DISABLED、SLAVESIDE_DISABLED * SLAVESIDE_DISABLED:表示事件是通过主备复制中的...索引名称可以在创建时指定,如果不指定InnoDB将隐含地创建名称与列名一致的索引,但索引名称在整个实例中不一定是唯一的(但在每个表中需要唯一)。...当一个列被删除时,剩下的列被重新排序,以便该序列无间隙 2.2.

    67020

    第8章_索引的创建与设计原则

    最后, 对用于连接的字段创建索引 ,并且该字段在多张表中的 类型必须一致 。...比如 course_id 在 student_info 表和 course 表中都为 int (11) 类型,而不能一个为 int 另一个为 varchar 类型。...个字符的选择度 from shop; 越接近于 1 越好,说明越有区分度 引申另一个问题:索引列前缀对排序的影响 如果使用了索引列前缀,比方说前边只把 address 列的 前12个字符 放到了二级索引中...区分度高 (散列性高) 的列适合作为索引 列的基数 指的是某一列中不重复数据的个数,比方说某个列包含值 2, 5, 8, 2, 5, 8, 2, 5, 8 ,虽然有 9 条记录,但该列的基数却是...也就是说 ** 在记录行数一定的情况下,列的基数越大,该列中的值越分散;列的基数越小,该列中的值越集中。** 这个列的基数指标非常重要,直接影响我们是否能有效的利用索引。

    32330

    python【第十二篇】Mysql基础

    数据表: 表是数据的矩阵。在一个数据库中的表看起来像一个简单的电子表格。 列: 一列(数据元素) 包含了相同的数据, 例如邮政编码的数据。...主键:主键是唯一的。一个数据表中只能包含一个主键。你可以使用主键来查询数据。 外键:外键用于关联两个表。 索引:使用索引可快速访问数据库表中的特定信息。...索引是对数据库表中一列或多列的值进行排序的一种结构。类似于书籍的目录。 复合键:复合键(组合键)将多个列作为一个索引键,一般用于复合索引。 参照完整性: 参照的完整性要求关系中不允许引用不存在的实体。...该节描述了这些类型如何工作以及如何在查询中使用这些类型。 ? CHAR和VARCHAR类型类似,但它们保存和检索的方式不同。它们的最大长度和是否尾部空格被保留等方面也不同。...单列索引,即一个索引只包含单个列,一个表可以有多个单列索引,但这不是组合索引。组合索引,即一个索包含多个列。

    94320

    【MySQL 系列】MySQL 语句篇_DDL 语句

    在 MySQL 中,主键需要遵循以下规则: 主键是定义在表上的。一个表不强制定义主键,但最多只能定义一个主键。 主键可以包含一个列或者多个列。 主键列的值必须是唯一的。...如果主键包含多个列,则这些列的值组合起来必须是唯一的。 主键列中不能包含 NULL 值。 3.1.1、创建主键 我们可以在创建表时定义主键。...我们可以使用以下 3 个策略中的一个: CASCADE:如果被引用的表中的一行被删除或更新,该表中匹配行的值会自动删除或更新。...SET NULL:如果被引用的表中的一行被删除或更新,该表中匹配行的值设置为 NULL。...RESTRICT: 如果被引用的表中的一行在该表中有匹配的行,试图删除或更新被引用的表中行时会引发 MySQL 错误。这是默认的策略。

    32210
    领券