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

mysql 进行update时,更新的字段中有单引号或者双引号导致不能批量生成sql的问题

前言 将数据从一张表迁移到另外一张表的过程中,通过mysql的concat方法批量生成sql时遇到了一个问题,即进行UPDATE更新操作时如果原表中的字段中包含单引号'或者双引号",那么就会生成不正确的...原因当然很简单因为update table set xxx = 'content'时content一般由英文单引号'或者双引号"包裹起来,使用单引号较多。...如果content中包含单引号'时我们需要对单引号'进行转义或者将content用双引号括起来,这样双引号"里面的单引号'就会被视为普通的字符,同理如果content中包含双引号"那么我们就可以换成单引号括起来...但是如果content中既包含单引号'又包含双引号",这时我们就不得不对content中的内容进行转义了。...id = ",id,";") from student where id = 3; 3、内容中包含双引号和单引号 需使用replace函数将content中的单引号和双引号替换为转义的形式。

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

    MySQL8.0大表秒字段,是真的吗?

    很早就听说 MySQL8.0 支持快速列,可以实现大表秒级字段。笔者自己本地也有8.0环境,但一直未进行测试。本篇文章我们就一起来看下 MySQL8.0 快速列到底如何操作。...MySQL 5.7 支持 Online DDL,大部分 DDL 不影响对表的读取和写入,但是依然会消耗非常多的时间,且占用额外的磁盘空间,并会造成主从延迟。...听闻 MySQL 8.0 解决了这件令 DBA 头痛的事,那让我们来详细了解下吧。想了解新功能,最简单的方法就是查阅官方文档。...查阅官方文档得知,快速列即 Instant Add Column ,该功能自 MySQL 8.0.12 版本引入,是由腾讯游戏DBA团队贡献。注意一下,此功能只适用于 InnoDB 表。...总结 虽然快速列存在一些限制, instant 算法也只适用于部分 DDL 操作,但 8.0 的这项新功能已经足以令人兴奋,很大程度上解决了大表字段的大难题。

    3.8K20

    MySQL8.0大表秒字段,是真的吗?

    前言: 很早就听说 MySQL8.0 支持快速列,可以实现大表秒级字段。笔者自己本地也有8.0环境,但一直未进行测试。本篇文章我们就一起来看下 MySQL8.0 快速列到底如何操作。...查阅官方文档得知,快速列即 Instant Add Column ,该功能自 MySQL 8.0.12 版本引入,是由腾讯游戏DBA团队贡献。注意一下,此功能只适用于 InnoDB 表。...2.快速列测试 快速列采用的是 instant 算法,使得添加列时不再需要 rebuild 整个表,只需要在表的 metadata 中记录新增列的基本信息即可。...对比看来 8.0 版本的快速列功能确实非常实用!...总结: 虽然快速列存在一些限制, instant 算法也只适用于部分 DDL 操作,但 8.0 的这项新功能已经足以令人兴奋,很大程度上解决了大表字段的大难题。

    2.9K70

    IFS变量对引号和不加双引号变量的区别对待

    IFS 环境变量定义了 bash shell 用作字段分隔符的一系列字符。如果 bash shell 在数据中看到了这些字符中的任意一个,它就会假定这表明了列表中一个新数据字段的开始。...IFS对待未加双引号的变量 比如在 bash shell 中输入以下代码: IFS=: _str_="hello:world" for i in $_str_; do echo $i; done 会得到以下结果...: hello world 原因是引用字符串变量 _str_ 没有加双引号时,Shell 在 for 语句中根据 IFS 变量将字符串 _str_ 进行切割,切割成很多个字符串,然后逐个 echo 3...IFS对待引号的变量 在 Shell 中输入以下代码: IFS=: _str_="hello:world" for i in "$_str_"; do echo $i; done 会得到以下结果:...hello world 原因是引用字符串变量 _str_ 加了双引号时,表示将其当作一个整体来处理,IFS 不会起作用,所以上述 for 循环只会循环一次。

    3.4K20

    MySQL实战第十一讲-怎么给字符串字段索引?

    现在,几乎所有的系统都支持邮箱登录,如何在邮箱这样的字段上建立合理的索引,是我们今天讨论的问题。...同时,MySQL 是支持前缀索引的,也就是说,你可以定义字符串的一部分作为索引。默认地,如果你创建索引的语句不指定前缀长度,那么索引就会包含整个字符串。...其他方式 对于类似于邮箱这样的字段来说,使用前缀索引的效果可能还不错。但是,遇到前缀的区分度不够好的情况时,我们怎么办呢?...由于校验码可能存在冲突,也就是说两个不同的身份证号通过 crc32() 函数得到的结果可能是相同的,所以你的查询语句 where 部分判断 id_card 的值是否精确相同。...因为维护的只是一个学校的,因此前面 6 位(其中,前三位是所在城市编号、第四到第六位是学校编号)其实是固定的,邮箱后缀都是 @gamil.com,因此可以只存入学年份顺序编号,它们的长度是 9 位。

    2.3K30

    mysql varchar类型字段为数字时,不带引号查询时查询结果与事实不符

    select * from order_main where order_no='16541913435669023' 仔细观察后发现,得到正确结果的Sql,是加了引号的,代码中的sql是没有加引号的数字类型...根源 mysql5.7 查询varchar类型的数据时,不加引号,触发隐式转换导致的查询结果错误。...dev.mysql.com/doc/refman/… 源码解释 堆栈调用关系如下所示: 其中JOIN::exec()是执行的入口,Arg_comparator::compare_real()是进行等值判断的函数...这里经过测试,当数字超过16位以后,转成double类型就已经不准确了,例如20402702611292711会表示成20402702611292712(如图中val1) MySQL string转成...、in参数包含多个类型、字符集类型或校对规则不一致等 隐式类型转换可能导致无法使用索引、查询结果不准确等,因此在使用时必须仔细甄别 数字类型的建议在字段定义时就定义为int或者bigint,表关联时关联字段必须保持类型

    1.5K10

    order by 字段到底要不要索引?

    猜测:由于数据量较大,在执行索引操作时,进程正在进行索引操作,此时刷新造成查询时不走任何索引,导致所有索引失效,或者前期进程有阻塞,造成索引操作未完成那么条件是根据用户来查询的,极端情况下理应查出最多数据在几百条...by 索引,索引命中,物理扫描行数急剧减少图片https://blog.csdn.net/asdasdasd123123123/article/details/106783196/order by 字段到底要不要索引...在这里作一个简单的分析,首先索引和数据不同,是按照有序的排列存储的,当结果集要求按照顺序取得一部分数据时,索引的功效会体现的非常明显,本次查询就是取得object_id最小的10条记录。...从这个实验看,在order by字段建索引是非常划算的,而且order by字段并不一定非要加入到where条件中也可以生效。...,如果最终的结果集是以order by字段为条件筛选的,将order by字段加入索引,并放在索引中正确的位置,会有明显的性能提升。

    11K20

    代码之间为什么空格?

    据我观察,大多数人写代码喜欢在符号两侧空格,而且还会嘲讽不加空格的人。这些支持者认为,空格可以让代码美观,增强代码的可读性。但是我不喜欢空格,因为这么写对代码含义没有影响,浪费空间还很麻烦。...在我写代码的前一两年里,写代码也不习惯空格,觉得很麻烦,并且不加空格,真的不影响代码的运行效果。...// 空格的写法 int a = 5; int b = 3; a = a + b; // 不加空格的写法 int a=5; int b=3; a=a+b; 想知道为什么后来我开始刷牙了呢?...但我就特别讨厌一些题目,让标点符号断句的那些,很无聊。 所以,别任性,该加空格就空格,你写的代码可不只是给你一个人看的,负责任点。 换句话说,我也可以写文章不换行,对吧?...不过,需要注意一点的是,我看有些视频课里,有些讲课人习惯什么地方都空格,我也是有点受不了的,比如说方法名和小括号之间——public void print (),这就有点不合时宜了。

    1.2K20
    领券