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

在bash中:-(冒号破折号)的用法

问: 在bash中,这种风格的含义是什么? ${PUBLIC_INTERFACE:-eth0} :- 的用途是什么?...如果 parameter 未设置或为 null,则 word 的扩展将被替换。否则,parameter 的值将被替换。 ${parameter:=word} 分配默认值。...如果 parameter 未设置或为 null,则 word 的扩展被分配给 parameter。然后 parameter 的值被替换。位置参数和特殊参数不能以这种方式分配。...如果 parameter 为 null 或未设置,则 word 的扩展(如果 word 不存在,则为此显示一条消息)将写入标准错误,并且 shell(如果它不是交互式的)将退出。...否则,parameter 的值将被替换。 ${parameter:+word} 使用替代值。如果 parameter 为 null 或未设置,则不替换任何内容,否则 word 的扩展将被替换。

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

    JSoupNSoup对CSS类名称中含空格的处理

    在爬虫过程中,经常需要对网页内容进行信息提取。 而在这处理过程中,JSoup是经常常用的库。(Nsoup是Jsoup的.net开发版本) 从JSOUP的官网例子中,可以处理几乎任何节点数据。...但是在查找某个类别的CSS名称过程中,由于名称存在空格,导致其提取内容问题返回为空。 相信这个问题大家经常遇到,于是在此将过程记录一下。...                            摘要:                                                 在考虑咽喉区进路交叉和到发线技术作业安全的前提下...即出现空格的情况下,程序中会默认进行截断,只返回row的CSS类,而这导致不匹配而返回空。 最终查看代码,终于搞定,即要对CSS中的空格进行处"理。即用"."代替空格。            ...var abs = abstractS.Select("div.row.clear.zh"); 用这种方式,就可以提取到相关的信息.

    1.1K20

    MySQL中的json字段

    // MySQL中的json字段 // MySQL5.7.8中引入了json字段,这种类型的字段使用的频率比较低,但是在实际操作中,有些业务仍然在用,我们以此为例,介绍下json字段的操作方法...json中的内容。...其中: 1、$符号代表的是json的根目录, 2、我们使用$.age相当于取出来了json中的age字段, 3、当然,在函数最前面,应该写上字段名字info 下面来看json中常用的函数: a、json_valid...,如果传入了字符串2,那么,返回结果是1 b、json_keys传回执行json字段最上一层的key值 mysql> select json_keys('{"name":"yeyz","score":100...,形如{'aa':1}这种形式的json,其深度是2 e、json_contains_path函数检索json中是否有一个或者多个成员。

    9.1K20

    MySQL允许在唯一索引字段中添加多个NULL值

    今天正在吃饭,一个朋友提出了一个他面试中遇到的问题,MySQL允许在唯一索引字段中添加多个NULL值。...ENGINE = InnoDB CHARACTER SET = latin1 COLLATE = latin1_swedish_ci ROW_FORMAT = Dynamic; 然后,我们给name字段添加一个唯一索引...); INSERT INTO `test` VALUES (2, NULL); 并没有报错,说明MySQL允许在唯一索引字段中添加多个NULL值。...网友给出的解释为: 在sql server中,唯一索引字段不能出现多个null值 在mysql 的innodb引擎中,是允许在唯一索引的字段中出现多个null值的。...**根据这个定义,多个NULL值的存在应该不违反唯一约束,所以是合理的,在oracel也是如此。 这个解释很形象,既不相等,也不不等,所以结果未知。

    10K30

    MySQL中explain中的结果字段介绍(三)

    MySQL中explain中的结果字段介绍(三) 之前的文章中对于explain的数据结果中的字段已经进行了一部分介绍了,今天来说一说剩下的几个字段,为了防止忘记,先看看这个表结构: mysql...1个字节 3、对于varchar这种变长字段,需要有额外的2个字节来保存长度 有了这三条规则,就能比较容易理解key_len的值了,例如上面的例子中,key_len的值是4,它的原因是int类型是固定长度...,与条件匹配的值是一个常数还是一个变量之类的,我们可以看到,上面的结果中,ref字段的值都是const,是因为我们使用常量a或者常量2和索引字段进行匹配,如果我们使用某个字段进行匹配,来看下面: mysql...Using where 表示Mysql将对storage engine提取的结果进行过滤,过滤条件字段无索引; Using temporary 要解决查询,MySQL需要创建一个临时表来保存结果。...中包含 ORDER BY 操作,而且无法利用索引完成排序操作的时候,MySQL Query Optimizer 不得不选择相应的排序算法来实现。

    2.1K10

    MySQL中explain的结果​字段介绍

    MySQL中explain的结果字段介绍(二) 昨天说完了执行计划的前四个字段,今天说说后面几个字段吧。...子查询中使用了test_explain表中的普通索引字段a_key_var和test_explain表中的主键id字段进行等值匹配,外层的where条件中我们使用的是test_explain的主键id值进行...index_subquery 这个和上面一样,但是in条件中的子查询使用的是a_key_var普通索引字段,而不是id字段: mysql:yeyztest 18:53:30>>explain select...+树中包含的索引字段和聚集索引字段,如果一个二级索引是包含多个字段的联合索引,当我们使用联合索引的某些列来匹配查询其他联合索引列的时候,或者匹配聚集索引类的时候,这种情况下将会用到"索引覆盖"功能,在发生索引覆盖的时候...这篇内容有点多,其他的字段后续在写吧。

    8.5K10

    MySQL中InnoDB支持的四种事务隔离级别名称,以及逐级之间的区别?

    Read Uncommitted(读取未提交内容) >> 在该隔离级别,所有事务都可以看到其他未提交事务的执行结果。本隔离级别很少用于实际应用,因为它的性能也不比其他级别好多少。...读取未提交的数据,也被称之为脏读(Dirty Read)。 Read Committed(读取提交内容) >> 这是大多数数据库系统的默认隔离级别(但不是MySQL默认的)。...这种隔离级别也支持所谓的不可重复读(Nonrepeatable Read),因为同一事务的其他实例在该实例处理其间可能会有新的commit,所以同一select可能返回不同结果。...Repeatable Read(可重读) >> 这是MySQL的默认事务隔离级别,它确保同一事务的多个实例在并发读取数据时,会看到同样的数据行。...Serializable(可串行化) >> 这是最高的隔离级别,它通过强制事务排序,使之不可能相互冲突,从而解决幻读问题。简言之,它是在每个读的数据行上加上共享锁。

    2K30

    ​MySQL中explain的结果字段介绍(1)

    MySQL中explain的结果字段介绍 我们在使用MySQL的时候,用的最多的情况可能就是select语句了,当我们在一个表查找数据的时候,经常会遇到查找的速度比较慢的情况,作为一名DBA,我也会经常遇见业务方写的...而判断一条SQL语句是否会变慢的最主要依据还是"执行计划"。 MySQL中,可以通过explain的语句来查看一个SQL的执行计划。...01 id值 在一个大的select语句中,每一个语句都对应一个id值,例如上面的例子中,这个select 1就对应了一个id值,再来看下面这个SQL: mysql:(none) 21:49:37...,将会出现2个一样的id值 02 Select_type值 select关键字对应的是查询的类型,如果查询的类型是一般的select,那么select_type字段的值是simple,在上面的几个例子中...,选择将子查询物化之后与外层查询进行连接查询时,该子查询对应的select_type属性就是MATERIALIZED 03 table 表的名称,这个比较容易理解。

    2.8K20

    MySQL列名中包含斜杠或者空格的处理方法

    今天客户那边遇到了一个比较奇葩的问题跑来问我,这个问题比较冷门,所以特别记录下。 问题描述 数据库的字段存在斜杠或者空格的时候,怎么用sql进行insert或者select操作。...如果在命令行上把Linux命令放在反引号中,这个命令会首先被执行,其结果会成为命令行的一个参数。在赋值时,通过把命令放在反引号中,以便于首先执行,命令的执行结果会被赋予一个变量。...mysql中反引号的作用 为了区分MYSQL的保留字与普通字符而引入的符号 举个例子:SELECT `select` FROM `test` WHERE select='字段值' 在test表中,有个select...字段,如果不用反引号,MYSQL将把select视为保留字而导致出错,所以,有MYSQL保留字作为字段的,必须加上反引号来区分。...引号一般用在字段的值,如果字段值是字符或字符串,则要加引号,如:select='字段值' 不加反引号建的表不能包含MYSQL保留字,否则出错 反引号`,数字1左边的符号  保留字不能用于表名,比如desc

    4K20

    MySQL 中定义数据字段的类型

    MySQL中定义数据字段的类型对你数据库的优化是非常重要的。 MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。...关键字INT是INTEGER的同义词,关键字DEC是DECIMAL的同义词。 BIT数据类型保存位字段值,并且支持MyISAM、MEMORY、InnoDB和BDB表。...作为SQL标准的扩展,MySQL也支持整数类型TINYINT、MEDIUMINT和BIGINT。下面的表显示了需要的每个整数类型的存储和范围。...LONGTEXT 0-4 294 967 295 bytes 极大文本数据 注意:char(n) 和 varchar(n) 中括号中 n 代表字符的个数,并不代表字节个数,比如 CHAR(30)...CHAR 和 VARCHAR 类型类似,但它们保存和检索的方式不同。它们的最大长度和是否尾部空格被保留等方面也不同。在存储或检索过程中不进行大小写转换。

    2.4K00

    MySQL中更新时间字段的更新时点问题

    我们在设计表时,通常为了记录数据插入和更新的时间,会定义两个字段,create_time/insert_time和update_time,按照需求,记录插入的时间,会存储到create_time/insert_time...字段中,记录更新的时间,会存储到update_time字段中,当创建记录时,会同步更新create_time/insert_time和update_time,然而,当更新记录时,只会更新update_time...虽然我们的工程中设置了这两个字段,但是更新记录时,很可能就发现create_time/insert_time和update_time都做了更新,和实际是相反的。...原因可能就是在代码中没有对时间进行显性地设置,而且对时间的维护是MySQL自身进行管理的,例如, create table test (   id bigint not null auto_increment...MySQL中的CURRENT_TIMESTAMP: 在创建时间字段的时候, (1) DEFAULT CURRENT_TIMESTAMP 表示当插入数据的时候,该字段默认值为当前时间。

    5.2K20

    MySql中的longtext字段的返回问题「建议收藏」

    大家好,又见面了,我是你们的朋友全栈君。 最近开发中用到了longtext这种字段。在mysql中该字段的最大长度为4G 如下图所示 开发中遇到的一个问题就是。...例如有个article表,然后我们的页面要将数据以列表的形式展示到前端(只显示几个字段,如作者,标题等等,例如放到table中显示多条记录),但是是将该表中的所有信息都查出来,然后当用户点击某条记录的时候...,会跳到详情页,在显示出详细的信息。...解决方法: 当然是sql语句的问题了,当像上面这样查询整个列表的时候,可以不查询longtext这个字段,将其他的字段查询出来。...说到这里,还要说一种情况,就是有时候从数据库中查到的数据封装到实体类中,怎么也取不到某个字段的值,就是null。这个时候要看看sql语句,返回的结果集中是否将该字段封装并且映射到该类对应的字段上。

    1.7K30

    MySQL和Java中的货币字段类型选择

    引言 在互联网应用中,处理货币是一项常见的任务。为了确保准确性和精度,我们需要选择适当的字段类型来存储货币数据。本文将讨论在MySQL和Java中记录货币时应选择的字段类型,并提供相应的代码示例。...MySQL中的货币字段类型 在MySQL中,我们可以使用DECIMAL数据类型来存储货币数据。DECIMAL提供了固定精度和小数位数的数字存储,非常适合处理货币金额。...Java中的货币字段类型 在Java中,我们可以使用java.math.BigDecimal类来表示和处理货币数据。BigDecimal提供了高精度的十进制计算,适合处理货币金额。...结论 在MySQL和Java中记录货币时,我们需要选择适当的字段类型来确保准确性和精度。在MySQL中,使用DECIMAL类型存储货币金额是一种常见的做法。...而在Java中,使用BigDecimal类来表示和处理货币数据是推荐的方式。本文详细介绍了在MySQL和Java中记录货币时的字段类型选择,并提供了相应的代码示例

    67620

    DRF中多对多ManytoMany字段的更新和添加

    )就这样给自己挖了坑因为想要在添加订单的同时也要添加对应菜品的数量于是自定义了中间表并且添加了数量字段(噩梦开始~~~)首先是定义模型类models.py# models.pyimport django.utils.timezone...') # 获取传入过来的多对多信息格式为[{},{}] # 我的方法比较笨,理论上是可以传入多个的就是在实例化的时候添加many = True 来标识,但是实在是没心思搞了...# 在传入对多对多字段的时候同步传入需要更新的中间表id obj = OrderCenterThough(pk=i.get('id')) #...,在写的时候又发现了代码中的几个bug1、可以更新不是订单人的菜品2、更新的时候只能更新已经生成的菜品内容,因为无法为订单添加新的菜品,这个涉及到中间表中的对应关系已经确定了。...主要是一个思路,drf 的ModelSerializer 和 ModelViewSet 封装的太严实了,通过这样的方法来更新和添加多对多字段实属自己技术不成熟。

    97120
    领券