mysql字段名和關(guān)鍵字沖突的問題
mysql字段名和關(guān)鍵字沖突
1.用"(`)"將有沖突的字段框起來,鍵盤上1邊上那個(gè)鍵。
例:
SELECT * FROM yun_roleright WHERE right LIKE '%{13}%';
上面sql語(yǔ)句中right字段名與關(guān)鍵字沖突,會(huì)報(bào)錯(cuò),,,應(yīng)改成下面:
SELECT * FROM yun_roleright WHERE `right` LIKE '%{13}%';
mysql關(guān)鍵字沖突導(dǎo)致的sql執(zhí)行錯(cuò)誤
最近出現(xiàn)了一個(gè)很有意思的情況
我一共有三個(gè)數(shù)據(jù)庫(kù),開發(fā),測(cè)試,正式,
分別放置在不同的服務(wù)器上
都是mysql數(shù)據(jù)庫(kù)
這個(gè)時(shí)候出現(xiàn)了一個(gè)有意思的問題
我的sql如下
SELECT count(0) FROM sys_log WHERE system = 'system'
在開發(fā)和測(cè)試數(shù)據(jù)庫(kù)上執(zhí)行此sql,沒有問題
但是在正式環(huán)境的數(shù)據(jù)庫(kù)上執(zhí)行此sql,就會(huì)報(bào)如下錯(cuò)誤
納悶了半天,確定就是關(guān)鍵字的問題
但是比對(duì)了三個(gè)數(shù)據(jù)庫(kù),確實(shí)又沒找到不同點(diǎn),問大佬,大佬太忙,也沒細(xì)究
解決辦法
方案1:修改字段名(推薦)
注意:但是千萬(wàn)不要用sql語(yǔ)句去改,因?yàn)檎Z(yǔ)句中含有關(guān)鍵字,所以sql是不會(huì)執(zhí)行成功的,所以只能去數(shù)據(jù)庫(kù)管理工具中修改
ALTER table sys_log change system system1 varchar(255) CHARSET utf8 COLLATE utf8_general_ci NULL COMMENT '系統(tǒng)'
【修改字段的名稱】
語(yǔ)法: alter table <表名> change <字段名> <字段新名稱> <字段的類型>。
方案2:修改執(zhí)行sql
SELECT count(0) FROM sys_log s WHERE s.system = 'system'
或者
SELECT count(0) FROM sys_log WHERE `system` = 'system'
其他相關(guān)
注意:當(dāng)出現(xiàn)關(guān)鍵字的時(shí)候,然后業(yè)務(wù)層使用的sql借助了mybatis-plus框架寫的,如
public PageInfo<SysAuditLogDTO> selectAuditLog(ConditionDTO conditionDTO, Integer pageNum, Integer pageSize) { LambdaQueryWrapper<SysLogEntity> wrapper = Wrappers.<SysLogEntity>lambdaQuery() .orderByDesc(SysLogEntity::getCreateTime); if (StrUtil.isNotEmpty(conditionDTO.getSystem())) { wrapper.eq(SysLogEntity::getSystem, conditionDTO.getSystem()); } if (conditionDTO.getStart() != null) { wrapper.ge(SysLogEntity::getCreateTime, conditionDTO.getStart()); } if (conditionDTO.getFinish() != null) { Calendar calendar = Calendar.getInstance(); calendar.setTime(conditionDTO.getFinish()); calendar.add(Calendar.DATE, 1); wrapper.le(SysLogEntity::getCreateTime, calendar.getTime()); } Page<SysLogEntity> page = PageHelper.startPage(pageNum, pageSize).doSelectPage(() -> list(wrapper)); return auditLogMapper.toDto(page.toPageInfo()); } //注:PageHelper是內(nèi)部的一個(gè)工具類,對(duì)數(shù)據(jù)進(jìn)行分頁(yè)處理
有兩種辦法:
方案一:在xml文件中寫sql
業(yè)務(wù)層調(diào)用:(中間省略了dao)
public PageInfo<SysLogEntity > selectLog(ConditionDTO conditionDTO, Integer pageNum, Integer pageSize) { Page<SysLogEntity> page = PageHelper.startPage(pageNum, pageSize).doSelectPage(() -> sysLogDao.sysAuditLogListByQueryConditions(conditionDTO)); return auditLogMapper.toDto(page.toPageInfo()); }
mapper.xml文件
<insert id="addOne"> insert into sys_log (id, `system`) values (#{SysLogEntity.id},#{SysLogEntity.system}); </insert>
方案二:實(shí)體類@TableField中添加 ``(推薦)
這樣就支持mybatis-plus框架寫法
@Data @TableName("sys_log") public class SysLogEntity implements Serializable { private static final long serialVersionUID = 1L; /** * id */ @TableId private Long id; /** * 系統(tǒng) */ @TableField("`SYSTEM`") private String system; }
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
超詳細(xì)匯總21個(gè)值得收藏的mysql優(yōu)化實(shí)踐
這篇文章主要分享的是超詳細(xì)匯總21個(gè)值得收藏的mysql優(yōu)化實(shí)踐,對(duì)正在學(xué)習(xí)的同學(xué)有一定的參考價(jià)值,需要的同學(xué)可以參考一下2022-01-01在Windows環(huán)境下安裝MySQL 的教程圖解
這篇文章主要介紹了在Windows環(huán)境下安裝MySQL 的教程圖解,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-07-07MySQL詳細(xì)講解多表關(guān)聯(lián)查詢
在數(shù)據(jù)庫(kù)的設(shè)計(jì)中, 我們通常都是會(huì)有很多張表 , 通過表與表之間的關(guān)系建立我們想要的數(shù)據(jù)關(guān)系, 所以在多張表的前提下, 多表的關(guān)聯(lián)查詢就尤為重要2022-04-04