插入数据时有特殊字符&且后面有字符被误认为变量名(insert时提示:输入值于***)

当出现如下报错时请检查你的SQL,肯定是值里面有特殊字符&。如果是没有用的直接删除就可以了,如果有用那么就需要处理一下了(默认插入值中带&符号,且后面有字符串,就会被误认为变量名)。
处理方法(意思是要把&用单引号单独引起来,然后用拼接的方式来处理这一列)

将    &    替换为    ‘||‘&‘||‘

在plsql developer上回出现如下图提示

在sqlplus就是如下提示

SQL> insert into va values(‘T&K/泰恩康‘);
输入 k 的值:  只是个符号我不想要赋值。。。。
原值    1: insert into va values(‘T&K/泰恩康‘)
新值    1: insert into va values(‘T只是个符号我不想要赋值。。。。/泰恩康‘)
已创建 1 行。
SQL> select * from va;
FS_FAILOVER_OBSERVER_HOST
--------------------------------------------------------------------------------
T只是个符号我不想要赋值。。。。/泰恩康

使用单引号和拼接方法,将&和被误认为变量名的字符隔离开拼接处理。

SQL> insert into va values(‘T‘||‘&‘||‘K/泰恩康‘);
已创建 1 行。
SQL> select * from va;
FS_FAILOVER_OBSERVER_HOST
--------------------------------------------------------------------------------
T&K/泰恩康

其实后面跟的是空格就不会有影响,可以直接插入。

SQL> insert into va values(‘a7 & >d‘);
已创建 1 行。
SQL> select * from va;
FS_FAILOVER_OBSERVER_HOST
--------------------------------------------------------------------------------
a7 & >d

插入数据时有特殊字符&且后面有字符被误认为变量名(insert时提示:输入值于***)

原文地址:https://blog.51cto.com/zhanky/2462513

时间: 2024-10-10 23:49:04

插入数据时有特殊字符&且后面有字符被误认为变量名(insert时提示:输入值于***)的相关文章

MySQL 插入数据 通过命令提示窗口插入数据

MySQL 表中使用 INSERT INTO SQL语句来插入数据. 你可以通过 mysql> 命令提示窗口中向数据表中插入数据,或者通过PHP脚本来插入数据. 语法 以下为向MySQL数据表插入数据通用的 INSERT INTO SQL语法: INSERT INTO table_name ( field1, field2,...fieldN ) VALUES ( value1, value2,...valueN ); 如果数据是字符型,必须使用单引号或者双引号,如:"value"

MySQL 插入数据

MySQL 插入数据 MySQL 表中使用 INSERT INTO SQL语句来插入数据. 你可以通过 mysql> 命令提示窗口中向数据表中插入数据,或者通过PHP脚本来插入数据. 语法 以下为向MySQL数据表插入数据通用的 INSERT INTO SQL语法: INSERT INTO table_name ( field1, field2,...fieldN ) VALUES ( value1, value2,...valueN ); 如果数据是字符型,必须使用单引号或者双引号,如:"

c#Winform窗体 自动生成EXCEL并可以插入数据

using System;using System.Collections.Generic;using System.ComponentModel;using System.Data; using System.Windows.Forms; using System.Data.OleDb;using System.IO;using System.Drawing;using System.Linq;using System.Text; namespace EPAS.f06PreData//自己命名

关于SQL server 插入数据时语言和特殊字符的处理

问题描述: 当插入或者是修改数据时,当插入(修改)的字段中存在(韩文,日文)或者其他字符时,出现插入的字符变成了乱码或者是成堆的问号. 解决方法: 在 Microsoft SQL Server 中, 以下数据类型支持 Unicode 数据: nchar, nvarchar, ntext 使用SQL语句操作的时候应该注意以下问题: 原查询语句 Select * From TABLENAME Where field1 like '%xxx%' 使用 Unicode 数据类型的, 应该为: Selec

Mysql插入数据里有中文字符出现Incorrect string value的错误

问题:Mysql插入数据里有中文字符出现Incorrect string value的错误 描述:CMD里直接敲代码插入数据 提示的部分截取为:ERROR 1366 (HY000): Incorrect string value 一般都是编码问题,show variables like 'character%' 查看后,发现所有编码都为UTF8,并没有错. 也有一种可能是CMD黑窗口的文字编码问题,试着先设置客户端命令的编码,再插入果然正确!然后百度搜索客户端编码相关的问题也发现有和我出现过同样

向SqlServer数据库插入数据

Insert Values Insert Select Insert Exec Select Into Bulk Insert Insert Values是最常用的一种插入数据的方式,基本语法如下,表名之后可以指定目标列的名称,这种显式的指定目标列的名称是可选的,但是这种做法的好处是对语句的列值列名之间的关联关系进行控制,而不必单纯的依赖定义表时 各个列出现的顺序 INSERT INTO dbo.DimDate ( DataKey , Year , Qu , QuCN , Month , Mon

关于oracle批量插入数据遇到的问题

截取部分日志信息: 2015-09-01 14:48:47,132 INFO [org.springframework.beans.factory.xml.XmlBeanDefinitionReader] - Loading XML bean definitions from class path resource [org/springframework/jdbc/support/sql-error-codes.xml]2015-09-01 14:48:47,178 INFO [org.spr

mysql建立表及表的简单操作-插入数据-删除主键-删除表-修改表的数据-删除表的数据

-- 1.使用数据库 USE ren; -- 2.建立student表 CREATE TABLE student ( sid INT UNSIGNED PRIMARY KEY AUTO_INCREMENT,   -- UNSIGNED(无符号) AUTO_INCREMENT(自增) sname VARCHAR(10),    -- 只能保存10个字符 saddress VARCHAR(15)   -- 只能保存15个字符 )ENGINE=MYISAM DEFAULT CHARSET=utf8;

使用Python创建MySQL数据库实现字段动态增加以及动态的插入数据

应用场景: 我们需要设计一个数据库来保存多个文档中每个文档的关键字.假如我们每个文档字符都超过了1000,取其中出现频率最大的为我们的关键字. 假设每个文档的关键字都超过了300,每一个文件的0-299号存储的是我们的关键字.那我们要建这样一个数据库,手动输入这样的一个表是不现实的,我们只有通过程序来帮我实现这个重复枯燥的操作. 具体的示意图如下所示: 首先图1是我们的原始表格: 图1 这个时候我们需要程序来帮我们完成自动字段的创建和数据的插入. 图2 上图是我们整个表的概况.下面我们就用程序来