今天客户那边遇到了一个比较奇葩的问题跑来问我,这个问题比较冷门,所以特别记录下。

问题描述

数据库的字段存在斜杠或者空格的时候,怎么用sql进行insert或者select操作。

问题解答

对于这种特殊字符,我们一般想到的是用转义符进行处理,所以试了下"/"、引号、单引号等常见的转义符,发现依然语法错误,又查了下MySQL的官方说明:

特殊字符位于列名中时必须进行转义,如果列名中包含\t,(,),/,\,=,,+,-,*,^,",',[,],~,#,|,&,% 则必须用中括号括起来。eg:列名为Column#,应写为[Column#];列名包括中括号,必须使用斜杠进行转义,eg:列名为Column[]的列应写为[Column[\]](只有第二个中括号必须转义)。

以中括号的形式进行转义,然后又试了下中括号,发现依然还是不行。

通过搜索,最后找到需要以反引号“`”(一般键盘的左上角数字1左边的那个键)来处理。

其它反引号的用法

之前对反引号几乎没有使用过,所以借此机会搜索总结了下反引号相关的用法。

Linux反引号的作用

特殊的赋值

Shell中可以将数字或字符直接赋予变量,也可以将Linux命令的执行结果赋予变量,如下:

(1) $ count=9 #将数字赋予变量count

(2) $ name="ming" #将字符赋予变量name

(3) $ listc=`ls -la` #将Linux命令赋予listc,listc的值就是该命令的执行结果

反引号的作用

反引号的作用就是将反引号内的Linux命令先执行,然后将执行结果赋予变量。尽管可以通过输入字符或者字符串来创建变量值,也可以获取来自于其他Linux命令的值。为把Linux命令的结果赋予变量,实现需要执行这个命令。如果在命令行上把Linux命令放在反引号中,这个命令会首先被执行,其结果会成为命令行的一个参数。在赋值时,通过把命令放在反引号中,以便于首先执行,命令的执行结果会被赋予一个变量。反引号可以被视为由要执行命令组成的表达式,其结果会被赋予变量。组成命令的字符本身不会被赋予。在下面的范例中,命令ls .c被执行,其结果然后被赋予变量listc。ls .c会生成具有.c扩展名的所有文件列表。这个文件列表随后被赋予变量listc。

总结

反引号里面的字符串必须是能执行的命令,否则会出错;它的作用是命令替换,将其中的字符串当成Shell命令执行,返回命令的执行结果。

mysql中反引号的作用

为了区分MYSQL的保留字与普通字符而引入的符号

举个例子:SELECT `select` FROM `test` WHERE select='字段值'

在test表中,有个select字段,如果不用反引号,MYSQL将把select视为保留字而导致出错,所以,有MYSQL保留字作为字段的,必须加上反引号来区分。

引号一般用在字段的值,如果字段值是字符或字符串,则要加引号,如:select='字段值'

不加反引号建的表不能包含MYSQL保留字,否则出错

反引号`,数字1左边的符号

保留字不能用于表名,比如desc,此时需要加入反引号来区别,但使用表名时可忽略反引号。

create table desc报错

create table `desc`成功

create table `test`成功

drop table test成功

保留字不能用于字段名,比如desc,此时也需要加入反引号,并且insert等使用时也要加上反引号。

create table `test`(`desc` varchar(255))成功

insert into test(desc) values('fxf')失败

insert into test(`desc`) values('fxf')成功

mysql储存字符串斜杠_MySQL列名中包含斜杠或者空格的处理方法相关推荐

  1. Visual Studio 2013或2015工程属性中包含目录和库目录的添加方法,附加依赖项,相对路径

    参考文章:包含目录.库目录.附加包含目录.附加库目录.附加依赖项之详解 https://blog.csdn.net/u012043391/article/details/54972127 参考文章:V ...

  2. java.net.url 中文乱码_asp.net URL中包含中文参数造成乱码的解决方法

    asp.net URL中包含中文参数造成乱码的解决方法 更新时间:2010年03月08日 21:44:27   作者: 中文乱码一直以来是WEB开发中比较常见的问题之一,对于初学者来说,各种各样的编码 ...

  3. mysql查找字符串最后位置_mysql查找字符串出现位置

    标签: MySQL中的LOCATE和POSITION函数使用方法 FIND_IN_SET(str,strlist) 假如字符串str 在由N 子链组成的字符串列表strlist 中,则返回值的范围在 ...

  4. python斜杠作用_Python中正反斜杠(‘/’和‘\’)的意义与用法

    刚刚在学习些测试报告的时候,出现一个路径的问题,找了很久的原因,竟然是少了一个反斜杠引起的,在此顺便记录一下正反斜杠的作用. 在Python中,记录路径时有以下几种写法,如:(大家都知道\n是换行的意 ...

  5. python斜杠用法_Python中正反斜杠(‘/’和‘\’)的意义与用法

    刚刚在学习些测试报告的时候,出现一个路径的问题,找了很久的原因,竟然是少了一个反斜杠引起的,在此顺便记录一下正反斜杠的作用. 在Python中,记录路径时有以下几种写法,如:(大家都知道\n是换行的意 ...

  6. mysql 处理字符串 减断_Mysql处理字符串函数(转)

    标签:http://www.jb51.net/article/27458.htm 感觉上MySQL的字符串函数截取字符,比用程序截取(如PHP或JAVA)来得强大,所以在这里做一个记录,希望对大家有用 ...

  7. mysql之设置字段分隔符_mysql字段中使用逗号分隔符

    被分割的字段一定是有限而且数量较少的,我们不可能在一个字符串中存储无限多个字符 这个字段所属的表与这个字段关联的表,一定是一对多的关系 比如下面这个表结构所代表的content与tag这两个对象 代码 ...

  8. mysql 储存过程放到哪_MySQL储存过程详解

    我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的 ...

  9. mysql 从库数据损坏_MySQL数据库中数据损坏恢复全过程

    MySQL数据库中数据损坏恢复全过程 前几天因为MySQL数据库部分数据损坏原因,我尝试了下恢复数据,之后整理以下文档,供各位参考,以备各位同事以后如有类似问题,可以少走些弯路,尽快解决问题. 环境: ...

最新文章

  1. 数据库的查询,添加,修改,删除
  2. 织梦多个栏目arclist调用副栏目不显示的解决办法
  3. 程序员看片必备神器!包邮送一台!!
  4. UVA 10635 王子和公主
  5. 《明日方舟》的塔防元素:是鸡肋还是精髓?
  6. leetcode面试题 17.08. 马戏团人塔(二分法)
  7. 软件技术架构:通过限流与熔断,打造一个“靠谱”的系统
  8. matlab 矩阵动态,matlab – 如何以块为单位动态重塑矩阵?
  9. CentOS 7各版本镜像合集下载
  10. 电脑浏览器安全获取京东cookie
  11. ABC164 E - Two Currencies(二维最短路)
  12. 网站URL如何SEO优化
  13. 函数的调用(传值调用和传址调用)
  14. 7. 【可编程定时器8253】:外部引脚、内部结构特点、计数启动方式、6种工作方式、控制字格式、应用
  15. [JavaSE] 认识String类(StringBuffer和StringBuilder)
  16. infrastructure as a service
  17. Netconf配置及其RPC和Notification下发流程解析
  18. 如何将PDF文件转换为PNG图片?
  19. MATLAB 求圆形面积
  20. HTML5 App的代码注入攻击

热门文章

  1. 机器学习非监督机器学习算法有哪些
  2. Java HashMap遍历删除
  3. 仿58同城本地生活服务平台系统源码 完整代码包+搭建教程
  4. java基本算术训练
  5. 关于调试 MPU6050 DMP初始化过不去 总是显示mpu_set_sensor complete 的解决办法
  6. set pythonpath=%pythonpath%_在vscode中设置PYTHONPATH
  7. JAVA实现微信跳一跳辅助(手动)
  8. 世界杯用python画足球
  9. SpringCloud 学习笔记(3 / 3)
  10. 毕业论文中会出现的问题