引言:本文整理自vbaexpress.com论坛,供有兴趣的朋友学习参考。 Q:我有多个工作表,每个工作表中都有一个Date列,但其位置都不相同,如下图1至图3所示。 ? 图1 ? 图2 ?...图3 我想在该列右侧插入4列,将该列日期拆分成Month、Day、Year和New Date列。例如,对上图1所示的工作表,拆分成如下图4所示。 ?...图4 如何定位到Date列,然后在其右侧插入4列,并使用公式在各列输入相应的内容?...代码使用Find方法在工作表中查找内容为“Date”的单元格。 2. 在该单元格右侧插入4列。 3. 使用Array函数分别在每列的开头输入相应的内容。 4. 使用RC样式输入公式。 5....初学者注意体会Resize属性、Offset属性的使用。
学习Excel技术,关注微信公众号: excelperfect 这里的应用场景如下: “在工作表Sheet1中存储着数据,现在想要在该工作表的第O列至第T列中搜索指定的数据,如果发现,则将该数据所在行复制到工作表...用户在一个对话框中输入要搜索的数据值,然后自动将满足前面条件的所有行复制到工作表Sheet2中。” 首先,使用用户窗体设计输入对话框,如下图1所示。 ?...("O2:T"& lngRow) '查找的数据文本值 '由用户在文本框中输入 FindWhat = "*" &Me.txtSearch.Text & "*...SendInfo End If '清空工作表Sheet2 Sheets("Sheet2").Cells.Clear '获取数据单元格所在的行并复制到工作表...End If Loop End If Set FindAll = ResultRange End Function 这是一个通用函数,直接拿来使用就行了,可用来在指定的区域查找并返回满足条件的所有单元格
sql对大小写不敏感 SQL SELECT语句 SELECT语句用于从一个表中选取数据,结果被存储在一个结果表中 语法: select 列名称 from 表名称 从表名称对应的数据库表中取出列名称所对应的列的内容...从一个表中选取数据,然后把数据插入另一个表中 语法 将所有列插入新表 SELECT * INTO new_table_name [IN externaldatabase] FROM old_tablename...DEFAULT 用于向列中插入默认值,如果没有规定其他的值,就添加默认值。 SQL CREATE INDEX语句 用于在表中创建索引,在不读取整个表的情况下,使用索引可以更快的查找数据。...SQL Date函数 处理日期时,为了确保所插入的日期的格式,也就是与数据库中日期格式相匹配。...MAX()和MIN() 返回一列中的最大值和最小值,NULL值不包括在计算中,可以用于文本列,获得按照字母顺序排列的最高或最低值。 SUM()函数 返回数值列的总数。
SQL 面向数据库执行查询 SQL 可从数据库取回数据 SQL 可在数据库中插入新的记录 SQL 可更新数据库中的数据 SQL 可从数据库删除记录 SQL 可创建新数据库 SQL 可在数据库中创建新表...INSERT – 插入数据 INSERT INTO 语句用于向表格中插入新的行。...VIEW – 视图 在 SQL 中,视图是基于 SQL 语句的结果集的可视化的表。 视图包含行和列,就像一个真实的表。视图中的字段就是来自一个或多个数据库中的真实的表中的字段。...MIN – 最小值 MIN 函数返回一列中的最小值。NULL 值不包括在计算中。...注意: 如果您在使用 Sql Server 数据库,请使用 getdate() 函数来获得当前的日期时间。
INTO 语句 SELECT INTO 语句从一个表中选取数据,然后把数据插入另一个表中。...FOREIGN KEY 约束也能防止非法数据插入外键列,因为它必须是它指向的那个表中的值之一。...SQL DEFAULT 约束 DEFAULT 约束用于向列中插入默认值。 如果没有规定其他的值,那么会将默认值添加到所有的新记录。...如果您希望使查询简单且更易维护,那么请不要在日期中使用时间部分! 19.SQL NULL 值 如果表中的某个列是可选的,那么我们可以在不向该列添加值的情况下插入新记录或更新已有的记录。...6.MIN() 函数 MIN 函数返回一列中的最小值。NULL 值不包括在计算中。
SQL 面向数据库执行查询 SQL 可从数据库取回数据 SQL 可在数据库中插入新的记录 SQL 可更新数据库中的数据 SQL 可从数据库删除记录 SQL 可创建新数据库 SQL 可在数据库中创建新表...、数字以及特殊字符)、在括号中规定字符串的长度 varchar(size) 容纳可变长度的字符串(可容纳字母、数字以及特殊的字符)、在括号中规定字符串的最大长度 date(yyyymmdd) 容纳日期...INSERT – 插入数据 INSERT INTO 语句用于向表格中插入新的行。...VIEW – 视图 在 SQL 中,视图是基于 SQL 语句的结果集的可视化的表。 视图包含行和列,就像一个真实的表。视图中的字段就是来自一个或多个数据库中的真实的表中的字段。...实例: select max(orderno) from orders; MIN – 最小值 MIN 函数返回一列中的最小值。NULL 值不包括在计算中。
这个1位,表示只能存1位的二进制值。这里(M)是表示二进制的位数,位数最小值为1,最大值为64。 注意:在向BIT类型的字段中插入数据时,一定要确保插入的数据在BIT类型支持的范围内。...当取值为01到69时,表示2001到2069; 当取值为70到99时,表示1970到1999; 当取值整数的0或00添加的话,那么是0000年; 当取值是日期/字符串的'0'添加的话,是2000年。...以 YY-MM-DD HH:MM:SS 格式或者 YYMMDDHHMMSS 格式的字符串插入DATETIME类型的字段时,两位数的年份规则符合YEAR类型的规则,00到69表示2000到2069;70到...否则,你可能毫无目的地在网络上传输大量的值。 ③ 把BLOB或TEXT列 分离到单独的表 中。...在某些环境中,如果把这些数据列移动到第二张数据表中,可以让你把原数据表中的数据列转换为固定长度的数据行格式,那么它就是有意义的。这会 减少主表中的碎片 ,使你得到固定长度数据行的性能优势。
大致分为两类:SQL Aggregate 函数计算从列中取得的值,返回一个单一的值。SQL Scalar 函数基于输入值,返回一个单一的值。...一、SQL Aggregate 函数SQL Aggregate 函数计算从列中取得的值,返回一个单一的值。...从 "Websites" 表的 "alexa" 列获取最大值:SELECT MAX(alexa) AS max_alexa FROM Websites;4、MIN() 函数MIN() 函数返回指定列的最小值...从 "Websites" 表的 "alexa" 列获取最小值:SELECT MIN(alexa) AS min_alexa FROM Websites;5、SUM() 函数SUM() 函数返回数值列的总数...从 "Websites" 表中选取 name,url,及当天日期:SELECT name, url, Now() AS dateFROM Websites;7、SQL FORMAT() 函数FORMAT
参考资料: 《SQL基础教程》 ? 基础查询 数据准备 在查询数据之前,需要往数据库里插入需要用到的数据。...FROM 包含了两个子句: SELECT子句:列出了希望从表中查询出的列的名称; FROM子句:指定了选取出数据的表的名称。...查询全部的列 SELECT * FROM ; 输出Product表中全部的列 SELECT * FROM Product; 和以上代码具有相同意义的语句: SELECT product_id...选出登记日期在2009年9月27日之前的记录 小于某个日期就是在该日期之前的意思。...对字符串使用不等式时的注意事项 创建Chars表并插入数据 -- DDL:创建表 CREATE TABLE Chars (chr CHAR(3) NOT NULL, PRIMARY KEY (chr))
例如在FLOAT(5,2)列内插入999.009,近似结果是999.01。 若四舍五入后,整数部分超出范围,则MySQL报错,并拒绝处理。...以 YY-MM-DD 格式或者 YYMMDD 格式表示的字符串日期,此格式中,年份为两位数值或字符串满足YEAR类型的格式条件为:当年份取值为00到69时,会被转化为2000到2069;当年份取值为70...(2)可以使用不带有冒号的字符串或者数字,格式为’ HHMMSS ‘或者 HHMMSS 。如果插入一个不合法的字符串或者数字,MySQL在存储数据时,会将其自动转化为00:00:00进行存储。...因为这个数据类型包括了完整的日期和时间信息,取值范围也最大,使用起来比较方便。毕竟,如果日期时间信息分散在好几个字段,很不容易记,而且查询的时候,SQL 语句也会更加复杂。...否则,你可能毫无目的地在网络上传输大量的值。 ③ 把BLOB或TEXT列 分离到单独的表 中。
offset 这里比较难想的就是天数计算起始日期,不过想明白后,其实也好算,从excel中我们可以直接将日期天数转成短日期,等式已经有了,只有一个未知数x,我们只需列一个一元一次方程即可解出未知数x...我的想法是,首先调用pandas的sort_values函数将所有数据根据日期列进行升序排序,然后,调用drop_duplicates函数指定按SOID列进行去重,并指定keep值为last,表示重复数据中保留最后一行数据...” 可以写一个字典,来存储数据库表和对应Excel数据名称,然后一个个存储到对应的数据库表中即可(或者提前处理好数据后,再合并)。...charset=GBK") # 存储数据 def data_to_sql(data, table_naem, columns): # 再对数据进行一点处理,选取指定列存入数据库 data1...'testa': ['test1.xls', 'test2.xls'], 'testb': ['test3.xls'], 'testc': ['test4.xls'] } # 选取附件中的指定列
在用 UNION 组合查询时,只能使用一条ORDER BY 子句,它必须出现在最后一条SELECT语句之后 SELECT INTO 语句 我们可以复制所有的列插入到新表中: SELECT * INTO...newtable [IN externaldb] FROM table1; 或者只复制希望的列插入到新表中: SELECT column_name(s) INTO newtable [IN externaldb...,然后把数据插入到一个已存在的表中。...我们可以从一个表中复制所有的列插入到另一个已存在的表中: INSERT INTO table2 SELECT * FROM table1; 或者我们可以只复制希望的列插入到另一个已存在的表中: INSERT...SQL NULL 值 NULL 值代表遗漏的未知数据。默认地,表的列可以存放 NULL 值。 如果表中的某个列是可选的,那么我们可以在不向该列添加值的情况下插入新记录或更新已有的记录。
sql_mode常用值如下: ONLY_FULL_GROUP_BY: 对于GROUP BY聚合操作,如果在SELECT中的列,没有在GROUP BY中出现,那么这个SQL是不合法的,因为列不在GROUP...STRICT_TRANS_TABLES: 在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做限制 NO_ZERO_IN_DATE: 在严格模式下,不允许日期和月份为零 NO_ZERO_DATE...改为严格模式后可能会存在的问题: 若设置模式中包含了NO_ZERO_DATE,那么MySQL数据库不允许插入零日期,插入零日期会抛出错误而不是警告。...例如表中含字段TIMESTAMP列(如果未声明为NULL或显示DEFAULT子句)将自动分配DEFAULT '0000-00-00 00:00:00'(零时间戳),也或者是本测试的表day列默认允许插入零日期...'0000-00-00' COMMENT '日期';这些显然是不满足sql_mode中的NO_ZERO_DATE而报错。
例如在 FLOAT (5,2) 列内插入 999.009,近似结果是 999.01。 若四舍五入后,整数部分超出范围,则 MySQL 报错,并拒绝处理。...以 YY-MM-DD 格式或者 YYMMDD 格式表示的字符串日期,此格式中,年份为两位数值或字符串满足 YEAR 类型的格式条件为:当年份取值为 00 到 69 时,会被转化为 2000 到 2069...因为这个数据类型包括了完整的日期和时间信息,取值范围也最大,使用起来比较方便。毕竟,如果日期时间信息分散在好几个字段,很不容易记,而且查询的时候,SQL 语句也会更加复杂。...否则,你可能毫无目的地在网络上传输大量的值。 ③ 把 BLOB 或 TEXT 列 分离到单独的表 中。...在某些环境中,如果把这些数据列移动到第二张数据表中,可以让你把原数据表中的数据列转换为固定长度的数据行格式,那么它就是有意义的。这会 减少主表中的碎片 ,使你得到固定长度数据行的性能优势。
,对于 group by 的这种聚合操作,如果在select 中的列,没有在group by 中出现,那么这个SQL是不合法的,因为列不在group by的从句中,所以对于设置了这个mode的数据库,在使用...sql_mode常用值: ONLY_FULL_GROUP_BY: 对于GROUP BY聚合操作,如果在SELECT中的列,没有在GROUP BY中出现,那么这个SQL是不合法的,因为列不在GROUP BY...默认设置下,插入0或NULL代表生成下一个自增长值。如果用户 希望插入的值为0,而该列又是自增长的,那么这个选项就有用了。 ...STRICT_TRANS_TABLES: 在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做限制 NO_ZERO_IN_DATE: 在严格模式下,不允许日期和月份为零 NO_ZERO_DATE...: 设置该值,mysql数据库不允许插入零日期,插入零日期会抛出错误而不是警告。
它不适用TIMESTAMP列,这总是需要一个有效的日期。 服务器要求月份和日期值是合法的,而不是分别在1到12和1到31的范围内。...如果启用此模式,则将零件的日期插入'0000-00-00'并产生警告。 如果启用了此模式和严格模式,则不允许包含零件的日期,插入会产生错误,除非IGNORE给出。...下表列出了默认情况下产生错误与警告时语句行为的总结比较。默认情况下产生错误的一个例子是插入NULL到NOT NULL列中。...默认情况下产生警告的一个示例是将错误数据类型的值插入到列中(例如将字符串插入 'abc'到整数列中)。...对于这种模式设置,请在执行语句时期望这些差异: 在5.6中,服务器插入零部件的日期 '0000-00-00'并产生一个警告。
; 以下 SQL 语句列出了不同(不同)客户国家/地区的数量: SELECT COUNT(DISTINCT Country) FROM Customers; 练习: 1-从表中的Country列中选择所有不同的值...VALUES (value1, value2, value3, ...); 2-如果要为表的所有列添加值,则无需在 SQL 查询中指定列名。但是,请确保值的顺序与表中的列顺序相同。...CustomerID 列是一个自动递增字段,将在新记录插入表中时自动生成。...仅在指定列中插入数据 下面的 SQL 语句将插入一条新记录,但只在“CustomerName”、“City”和“Country”列中插入数据(CustomerID 会自动更新): INSERT INTO...FIRST 3 ROWS ONLY; MIN() 和 MAX()函数求最大最小值 MIN()函数返回所选列的最小值。
被标记字段的表称为子表,另外一张表叫父表 删除数据,先删除子表,再删除父表 插入数据,先插入父表,再插入子表 语法格式: ```sql foreign key(列名) references 父表表名(父表中要被添加的列名...创建表设置了默认值的列除外) 插入日期 mySQL的日期格式: %Y年 %m 月 %d 日 %h 时 %m 分 %s 秒 str_to_date('日期字符串','日期格式') 比如数据表中员工的入职日期字段...也可以给列名加别名,像下面这样 select 表名的别名.列名1 列名1的别名,表名的别名.列名2 列名2的别名 from 表名 表名的别名; 去重查询 // 查询表中某列数据,并去掉重复值...) from 表名; // 求最小值 select min(要求最小值的列名) from 列名; // 统计数量 只统计不为null的记录条数 select count(表中任意不存在Null...// 比如:查询商品表中,按照商品编号分组显示每组的平均价格,并查询平均价格大于 60元的所有商品。
那么在统计2005年的数据时就应该将该员工定位到A部门;而在统计 2006年数据时就应该定位到B部门,然后再有新的数据插入时,将按照新部门(B部门)进行处理,这样我们的做法是将该维度成员列表加入标识列,...在数据仓库构建中,ETL关系到整个项目的数据质量,所以马虎不得,必须将其摆到重要位置,将ETL这一 大厦根基筑牢。 五、ETL和SQL的区别与联系 如果ETL和SQL来说,肯定是SQL效率高的多。...(新增和修改),用它们将目标表中属性发生修改的开链数据(有效数据)进行关链操作(即END_DT关闭到当前业务日期),然后再将最新的增量数据作为开链数据插入到目标表即可。...、修改)和删除增量数据放入VT_INC_编号,注意将其中的删除增量数据的END_DT置以最小日期(借用);最后再将最终目标表的开链数据中PK出现再VT_INC_编号或VT_DEL_编号中的进行关链处理,...然后将VT_INC_编号中所有的END_DT不等于最小日期数据(非删除数据)作为开链数据插入最终目标表即可。
二、SQL BETWEEN 用法 BETWEEN 操作符用于选取介于两个值之间的数据范围内的值。 这些值可以是数值、文本或日期。...二)SQL NOT BETWEEN 实例 SELECT * FROM score WHERE score NOT BETWEEN 60 AND 80; 以上 SQL 语句选取 score 不在 60 到...SQL 语句选取 score 在 60 到 80之间,但 name不是 "阿花" 和 "酸菜"的学生记录。...在某些数据库中,BETWEEN 选取介于两个值之间但不包括两个值的字段; 在某些数据库中,BETWEEN 选取介于两个值之间且包括两个值的字段; 在某些数据库中,BETWEEN 选取介于两个值之间且包括第一个值但不包括第二个值的字段...请注意,下面这几种情况使用别名很有用: 1)在查询中涉及超过了一张表 2)在查询中使用到了函数 3)列名称很长或者可读性较差 4)需要把两个列或者多个列结合在一起 至此,数据库SQL高级用法的第二章节就讲完啦
领取专属 10元无门槛券
手把手带您无忧上云