需求 在发布系统中所有前置任务里面增加一些内容,发布系统中大约有200+的项目,手动是不可能手动的,只有在数据库中操作了。 思路 思路?既然操作数据库哪肯定得去看MySQL手册喽。...在Mysql手册中查找String相关资料,找到并进入String Functions,可以找到CONCAT和CONCAT_WS两个关于字符串拼接的函数文档链接。 ? ?...函数格式:CONCAT(str1,str2,...) mysql> select concat('lian','st'); +---------------------+ | concat('lian'...CONCAT_WS的第一个参数是分隔符: char(10):换行符 char(13):回车符 mysql> select concat_ws(',','lian','st'); # 第一个参数是分隔符...-----------+ | lian,st | +----------------------------+ 1 row in set (0.00 sec) mysql
values('莫邪'); insert into tb_sword(c_name)values('鱼肠'); insert into tb_sword(c_name)values('纯钧'); 两张表内容如下...即得到如下结果 拆解需求: 1) 先将tb_user表中的c_no按逗号拆分 2)将拆分后c_no中的各个id与tb_sword中的id关联,获取剑名 3) 最后将每一个user对应的剑名合并成一个字段...分段SQL如下: 步骤1: 每一个user的c_no按逗号拆分为对应的c_id,此方法需借助于mysql.help_topic表 SELECT a.id,a.name,a.c_no, SUBSTRING_INDEX...( SUBSTRING_INDEX( a.c_no, ',', b.help_topic_id + 1 ), ',',- 1 ) c_id FROM tb_user a JOIN mysql.help_topic...a2表即步骤1中拆分的结果 tb_sword b2 WHERE a2.c_id =b2.id -- 关联,相当于inner join(或者join) 结果如下 步骤3: 将每个人的剑名合并为1个字段显示
[mysql]replace的用法(替换某字段部分内容) [mysql]replace的用法 1.replace into replace into table (id,name) values('1'...object中出现search的全部替换为replace select replace('www.163.com','w','Ww')--->WwWwWw.163.com 例:把表table中的name字段中的...aa替换为bb update table set name=replace(name,'aa','bb') 3.UPDATE更新一个字段中的的部分内容 现在有一条记录的字段是“abcdefg",现在我只想将该字段中的...c改为C,update语句应该怎么写 update 表名 set 字段1 = replace(字段1,'c','C') 本文由 小马哥 创作,采用 知识共享署名4.0 国际许可协议进行许可
目录 前言 oracle脚本: 建表语句 插入默认值语句 删除某个字段 增加某个字段 有数据情况下修改某个字段为另外的名称 mysql: 建表语句 插入默认值 删除某个字段 增加某个字段 表有数据情况下将某个字段修改为另外的名称...,我们需要对一些sql语句实现可重复执行的操作。...比如甲方A的进展已经到3.0阶段了,表需要加A字段,修改B字段为字符串;甲方B进展到2.0字段,只需要表加A字段,这时候如果你的表不是可重复执行的,你越到后面你就维护不清楚到底这张表哪些字段甲方A有,哪些甲方...B有,但是当你的脚本是可重复执行的时候,你只需要将2.0的脚本都执行一遍,然后如果是3.0版本的就将3.0的所有脚本都执行一遍就都可以解决了 下面将介绍oracle和mysql的可重复执行脚本 oracle...比如不需要phone这个字段 -- 删除phone字段 drop procedure if exists sq_db_mysql; delimiter $$ create procedure sq_db_mysql
背景 pg单字段排序,排序字段中可能会出现重复,这样就会导致我们在进行分页查询时会出现一些和预期不相符的现象,如这个数据在第一页出现了,然后再第二页又出现。...name age 2222 aa 12 6666 aa 12 7777 aa 12 可以明显看到,两次分页查询出现了同一条id为2222的记录,但实际上数据库里只有一条2222,查询结果莫名出现了重复数据...具体解决方式就是,补充一个有唯一约束或者大概率唯一的字段作为次级排序条件。...from test_select_order_page_duplicate tsopd order by tsopd.age, tsopd.id desc 预防 n对1关系的连表查询时,如果根据1端表的字段排序就肯定要加一个
在实践中,会出现某些字段中的内容变了,比如三方提供的图标地址变了,那么或许对字段中存储的图片域名进行更新,此时就需要用到mysql更新字段中的部分内容的功能。...基本更新语句如下: update table set icon = REPLACE(icon,'http://a.com','http://b.com'); 其中table便为对应的表明,icon为要更新的字段...,REPLACE中第二个参数为将要被替换的内容,第三个字段为替换成的新内容。
do /* 对满足i<=10000的值进行while循环 */ insert into t1(a,b) values(i,i); /* 写入表t1中a、b两个字段...insert_t1(); /* 运行存储过程insert_t1 */ update t1 set c = '2019-05-22 00:00:00'; /* 更新表t1的c字段...2019-05-22 00:00:00' */ update t1 set c = '2019-05-21 00:00:00' where id=10000; /* 将id为10000的行的c字段改为与其它行都不一样的数据...隐式转换 2.1 不走索引的原SQL: select user_name,tele_phone from user_info where tele_phone =11111111111; /* SQL...模糊查询 3.1 不走索引的原SQL: select * from t1 where a like '%1111%'; 3.2 优化后走索引的SQL(结果不一定准确): select * from t1
Mysql插入中文的字段内容时乱码的解决方法 1.我们在往数据库插入数据的时候,当遇到中文字符的插入时会发现插入的数据会变为?号,也就是乱码,如下所示: ?...(image-33d826-1556266481174)] 3.这里我们可以看到有些字符编码集不是utf8的,为了让这里所有的字符集都设置为utf8, 我们需要更改改动mysql配置文件/etc/...=utf8 在window环境下在 MySQL 的安装目录下有一个 my.ini 配置文件, [mysql] default-character-set=utf8 [mysqld] character-set-server...=utf8 4.当然你也可以在配置数据库的url的时候加上useUnicode=true&characterEncoding=UTF-8&useSSL=false jdbc.url=jdbc:mysql...useUnicode=true&characterEncoding=UTF-8&useSSL=false 修改后重新启动 MySQL 服务即可
举例说明 有数据表person,结构如下 id name urls 1 张三 xh.jpg 2 李四 xh.jpg 3 王五 3.jpg 需求:将urls字段中的xh替换为id字段的值 语句: UPDATE...jpg 2 李四 2.jpg 3 王五 3.jpg 本文采用 「CC BY-NC-SA 4.0」创作共享协议,转载请标注以下信息: 原文出处:Yiiven https://www.yiiven.cn/mysql-replace-assign-field.html
先来一个简单的例子,比如给了我们db table中的几个字段,我们需要拼写sql语句去重复插入。 给这样一个demo.txt的文本 ?
我们同步过来的数据内容如下。 最可怕就是在类型的前面多了一些数字加顿号。这些内容对于我来讲是完全没有意义的,我需要的只是顿号后面的内容。那么我应该怎么处理得到后面的内容呢。最先想到的是split....但是后来查了一下,mysql居然不支持split函数。真是让我大失所望。后来只能去找相近的函数,发现有一个INSTR() 函数,可以用来判断时段中是否包含某个字符串 ,并返回包含字符串对应的索引。...同时还要注意,最好做下判断,只有当字段中包含这个字符串时才进行截取,不包含则不截取。
我们同步过来的数据内容如下。 image.png 最可怕就是在类型的前面多了一些数字加顿号。这些内容对于我来讲是完全没有意义的,我需要的只是顿号后面的内容。那么我应该怎么处理得到后面的内容呢。...但是后来查了一下,mysql居然不支持split函数。真是让我大失所望。后来只能去找相近的函数,发现有一个INSTR() 函数,可以用来判断时段中是否包含某个字符串 ,并返回包含字符串对应的索引。...同时还要注意,最好做下判断,只有当字段中包含这个字符串时才进行截取,不包含则不截取。
00 简单回顾 之前写过一篇关于mysql 对表大小写敏感的问题(你有遇到过MySQL因大小写敏感导致的问题吗),其实在mysql中字段存储的内容是不区分大小写的,本篇进行简单的总结。...; 4、字段内容默认情况下是大小写不敏感的。...02 解决方案 因为默认情况下字段内容是不区分大小写的,也即大小写不敏感。所以解决方案就是要新增字段内容的校验规则。 使用mysql 的BINARY 关键字使搜索区分大小写。...这两种查看表的详情,本质上都是 在字段上 加上了 COLLATE utf8_bin。 03 总结 字段值的大小写由mysql的校对规则来控制。提到校对规则,就不得不说字符集。...通过上一篇和这一篇的内容,详细大家对mysql对大小写敏感的问题也有一定的认识了,在实际的开发中,库和表名最好使用小写字母,注意字段存储内容的大写问题。
我们在使用pymysql执行mysql语句的时候,可以使用批量插入的功能,例如我要插入如下三条内容到表test中: name: kingname, salary:99999, phone_number...但是,如果字段 phone_number是一个 unique字段,这样插入就会导致报错。现在的需求是,如果phone_number重复,那么就直接覆盖 name和 salary字段。...于是,你可能会想着把MySQL写成这样: with connection.cursor() as cursor: sql = 'insert into test (`name`, `salary
本文将详细介绍索引的概览和分类,并讨论使用索引时应该权衡的要素,关于索引底层实现的内容将在下一篇文章 MySQL 索引结构 中介绍。...因为更新表时,MySQL不仅要保存数据,还要保存索引文件。因此,对应更新非常频繁的字段,通常不建议使用索引。 建立索引会占用磁盘空间。...如果某个数据列包含许多重复的内容,为它建立索引效果就很差,这个性质称为索引的选择性:不重复的索引值和数据表中的记录总数的比值。索引的选择性越高则查询效率越高。...非聚集索引(non-clustered index) 非聚集索引虽然索引项是顺序存储的,但是索引项对应的内容是随机存储的,系统会维护单独的索引表来存储索引。...不推荐使用或索引失效情况 数据量很小的表 有大量重复数据的字段 频繁更新的字段 如果对索引字段使用了函数或者表达式计算,索引失效 innodb OR 条件没有对所有条件创建索引,索引失效 大于小于条件
像是MySql 关系型数据库和非关系型数据库 关系型: 采用关系模型(二维表)来组织数据结构的数据库 ,如Oracle 、SQL_Server、 MySQL 非关系型: 不采用关系模型组织数据结构的数据库...不要使用特殊字符和mysql关键字 数据表管理 基本思考过程: 确定存储内容 明确字段构成 确定字段数据类型 ⭐️基础数据类型 ✨数字类型 整数类型:INT,SMALLINT,TINYINT,MEDIUMINT...by分组的字段和聚合函数,不能包含其他内容。...(UNI):字段值不允许重复,但可为 NULL,KEY标志为 UNI 主键索引(PRI):一个表中只能有一个主键字段, 主键字段不允许重复,且不能为NULL,KEY标志为PRI。...select 字段列表 from 表1 inner join 表2 on 表1.字段 = 表2.字段; 左连接 左表全部显示,显示右表中与左表匹配的项 select 字段列表 from 表1
:select distinct 字段名 from 表名; 聚合:把很多行的同一个字段进行一些统计,最终的到一个结果 count(字段):统计这个字段有多少项 统计表有多少项:select count...分组聚合:总是根据会重复的项来进行分组,分组总是和聚合函数一起用 求部门的最高薪资或者求公司的最高薪资都可以通过聚合函数取到 但是要得到对应的人,就必须通过多表查询 求最晚入职的员工,实际上是最大的入职日期...by 排序 limit 前n条 3.3 多表查询 两张表连在一起:select * from emp,department; 连表查询:把两张表连在一起查 内连接:inner join 两张表条件不匹配的项不会出现再结果中...4.2 索引不生效的原因 要查询的数据的范围大,索引不生效 比较运算符:> = <= !...如果 abc% 索引生效,%abc索引就不生效 如果索引列内容的区分度不高,索引不生效 索引列在条件中参与计算,索引不生效 select * from s1 where id*10 = 1000000
text:当一个字段是要被全文搜索的,比如Email内容、产品描述,这些字段应该使用text类型。设置text类型以后,字段内容会被分析,在生成倒排索 引以前,字符串会被分析器分成一个一个词项。...通过观察不难发现,无论任何一个Term,无外乎由26个英文字母组成,这也就意味越多的词项就会造成的越多的数据“重复”。...这里所说的重复指的是词项之间会有很多个公共部分,如“abandon”和“abandonment”就共享了公共前缀“abandont”。...我们是否可以像Java开发过程中对代码的封装那样,重复利用这一部分公共内容呢?答案是肯定的!...版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
,因此在DML中,插入等操作不再是普通的插入,MySQL将它封装成了一个事务,连着索引项的排序表一起操作 因此,我们应当严格控制表上的索引数量,否则容易影响数据库的性能 总结索引维护如下: 1、索引维护由数据库自动完成...by a; idx_c_a(c,a) ->正确 七、到底哪些字段适合创建索引? 1、字段值的重复程度,如图: ?...身份证号码由于基本上不可能重复,因此选择性非常好,而人的名字重复性较低,选择性也不错, 性别选择性较差,重复度非常高 2、选择性很差的字段通常不适合创建索引,但也有例外 如:男女比例相仿的表中,性别不适合创建单列索引...首先,在较长的字段上建立索引是非常影响性能的,比如文章等超大varchar或者text字段,如果不是非建不可,一般不推荐,另外对InnoDB索引单字段(utf8)只能取前767bytes 那么如何处理长字段索引...MySQL中自带命令行工具 explain 来查看一个sql语句是否了索引 使用方式: explain select * from tb_test; 关注的项: 1、type : 查询access的方式
KEY) 作用 某一个属性或属性的组合能唯一标识一条记录 特点 最常见的索引类型 确保数据记录的唯一性 确定特定数据记录在数据库中的位置 唯一索引(UNIQUE) 作用 避免同一个表中某数据列中的值重复...导出表的SELECT(FROM子句的子查询) 3、table:显示这一行的数据是关于哪张表的 4、type:这列最重要,显示了连接使用了哪种类别,有无使用索引,是使用Explain命令分析性能瓶颈的关键项之一...在不损失精确性的情况下,长度越短越好 8、ref:显示使用哪个列或常数与key一起从表中选择行。 9、rows:显示MySQL认为它执行查询时必须检查的行数。...10、Extra:包含MySQL解决查询的详细信息,也是关键参考项之一。...添加正确的索引 在WHERE、ORDER BY 子句中经常使用的字段 字段的值是多个(例如性别字段则不适合) 字段内容不是经常变化的 经常变化的字段,添加索引反而降低性能 不宜过多添加索引 每添加一条索引都会占用磁盘空间
领取专属 10元无门槛券
手把手带您无忧上云