Table of ASCII Characters

放这备查

 

 

Char  Dec  Oct  Hex | Char  Dec  Oct  Hex
------------------------------------------
(nul)   0 0000 0x00 | (sp)   32 0040 0x20
(soh)   1 0001 0x01 | !      33 0041 0x21
(stx)   2 0002 0x02 | "      34 0042 0x22
(etx)   3 0003 0x03 | #      35 0043 0x23
(eot)   4 0004 0x04 | $      36 0044 0x24
(enq)   5 0005 0x05 | %      37 0045 0x25
(ack)   6 0006 0x06 | &      38 0046 0x26
(bel)   7 0007 0x07 | '      39 0047 0x27
(bs)    8 0010 0x08 | (      40 0050 0x28
(ht)    9 0011 0x09 | )      41 0051 0x29
(nl)   10 0012 0x0a | *      42 0052 0x2a
(vt)   11 0013 0x0b | +      43 0053 0x2b
(np)   12 0014 0x0c | ,      44 0054 0x2c
(cr)   13 0015 0x0d | -      45 0055 0x2d
(so)   14 0016 0x0e | .      46 0056 0x2e
(si)   15 0017 0x0f | /      47 0057 0x2f
(dle)  16 0020 0x10 | 0      48 0060 0x30
(dc1)  17 0021 0x11 | 1      49 0061 0x31
(dc2)  18 0022 0x12 | 2      50 0062 0x32
(dc3)  19 0023 0x13 | 3      51 0063 0x33
(dc4)  20 0024 0x14 | 4      52 0064 0x34
(nak)  21 0025 0x15 | 5      53 0065 0x35
(syn)  22 0026 0x16 | 6      54 0066 0x36
(etb)  23 0027 0x17 | 7      55 0067 0x37
(can)  24 0030 0x18 | 8      56 0070 0x38
(em)   25 0031 0x19 | 9      57 0071 0x39
(sub)  26 0032 0x1a | :      58 0072 0x3a
(esc)  27 0033 0x1b | ;      59 0073 0x3b
(fs)   28 0034 0x1c | <      60 0074 0x3c
(gs)   29 0035 0x1d | =      61 0075 0x3d
(rs)   30 0036 0x1e | >      62 0076 0x3e
(us)   31 0037 0x1f | ?      63 0077 0x3f
Char  Dec  Oct  Hex | Char Dec  Oct   Hex
-----------------------------------------
@      64 0100 0x40 | `      96 0140 0x60
A      65 0101 0x41 | a      97 0141 0x61
B      66 0102 0x42 | b      98 0142 0x62
C      67 0103 0x43 | c      99 0143 0x63
D      68 0104 0x44 | d     100 0144 0x64
E      69 0105 0x45 | e     101 0145 0x65
F      70 0106 0x46 | f     102 0146 0x66
G      71 0107 0x47 | g     103 0147 0x67
H      72 0110 0x48 | h     104 0150 0x68
I      73 0111 0x49 | i     105 0151 0x69
J      74 0112 0x4a | j     106 0152 0x6a
K      75 0113 0x4b | k     107 0153 0x6b
L      76 0114 0x4c | l     108 0154 0x6c
M      77 0115 0x4d | m     109 0155 0x6d
N      78 0116 0x4e | n     110 0156 0x6e
O      79 0117 0x4f | o     111 0157 0x6f
P      80 0120 0x50 | p     112 0160 0x70
Q      81 0121 0x51 | q     113 0161 0x71
R      82 0122 0x52 | r     114 0162 0x72
S      83 0123 0x53 | s     115 0163 0x73
T      84 0124 0x54 | t     116 0164 0x74
U      85 0125 0x55 | u     117 0165 0x75
V      86 0126 0x56 | v     118 0166 0x76
W      87 0127 0x57 | w     119 0167 0x77
X      88 0130 0x58 | x     120 0170 0x78
Y      89 0131 0x59 | y     121 0171 0x79
Z      90 0132 0x5a | z     122 0172 0x7a
[      91 0133 0x5b | {     123 0173 0x7b
/      92 0134 0x5c | |     124 0174 0x7c
]      93 0135 0x5d | }     125 0175 0x7d
^      94 0136 0x5e | ~     126 0176 0x7e
_      95 0137 0x5f | (del) 127 0177 0x7f
	
ASCII NameDescription C Escape Sequence
nul null byte /0
bel bell character /a
bs backspace /b
ht horizontal tab /t
np formfeed /f
nl newline /n
cr carriage return /r
vt vertical tab  
esc escape  
sp space
<think>好的,我现在需要帮助用户解决SQL中出现“contains non ASCII characters”报错的问题。首先,我需要回忆用户提供的引用内容,看看有没有相关的解决方案。 用户提到了四个引用,其中引用[1]提到使用SQL Server的CHAR和ASCII函数来检测和替换控制字符。引用[2]和引用[3]则指出路径或标识符中包含非ASCII字符会导致问题,需要将路径改为全ASCII字符。引用[4]提到在UTF-8数据库中插入非ASCII字符时,如果编码不正确会导致错误,需要确保CLP正确转换编码。 接下来,我需要综合这些信息,给出解决方案。首先,用户的问题可能出现在几个地方:数据内容中的非ASCII字符、数据库连接或路径中的非ASCII字符、或者字符编码设置不正确。 根据引用[2],如果报错是关于路径包含非ASCII字符,比如MySQL Workbench无法从含非ASCII的路径运行,那么用户需要检查应用的安装路径或执行路径,确保全是ASCII字符。这可能是一个常见原因,尤其是当用户的工作目录包含中文或其他非英文字符时。 然后,如果是数据中存在非ASCII字符,引用[1]和引用[3]提到的处理方法。例如,使用REPLACE函数结合CHAR和ASCII来清理数据中的特殊字符。例如,检测ASCII值小于32或大于127的字符并替换掉。此外,引用[3]中的Debezium报错可能涉及标识符使用非ASCII字符,需要检查表名、列名等是否合规。 另外,编码问题也是一个重点。引用[4]指出在UTF-8数据库中插入非ASCII字符时,如果客户端没有正确设置编码,可能导致字符被错误转换。因此,需要确认数据库、连接客户端(如CLP)的编码设置是否正确,是否都使用UTF-8,并且数据在插入时以正确的编码传输。 可能的步骤包括:检查路径中的非ASCII字符,清理数据中的非ASCII字符,验证数据库和客户端的编码设置,使用正确的函数处理字符替换,以及确保标识符符合ASCII规范。 现在需要将这些步骤整理成清晰的解决方案,分点说明,并给出具体的SQL示例,比如如何用REPLACE和ASCII函数过滤非ASCII字符。同时,提醒用户检查路径和编码设置,这些都是常见的错误来源。 还要注意用户是否在之前的交流中提到过其他信息,但根据当前提供的引用,主要围绕这几个方面。需要确保回答覆盖所有可能的场景,帮助用户系统地排查问题。</think>### SQL中"contains non ASCII characters"错误解决方案 出现该错误通常与**路径命名、字符编码配置、数据清洗**相关,以下是分步骤解决方案: --- #### 一、路径命名检查(适用于数据库工具报错) 当使用MySQL Workbench、SQL Server Management Studio等工具时: 1. **检查安装路径**:确保软件安装路径**不包含中文/特殊字符** ```txt 错误示例:D:\数据库工具\mysql-workbench ❌ 正确示例:D:\database_tools\mysql-workbench ✅ ``` 2. **临时文件路径**:检查系统环境变量`TEMP`和`TMP`路径是否含非ASCII字符[^2] --- #### 二、数据清洗(适用于表内数据报错) 通过SQL函数过滤非ASCII字符: 1. **检测非ASCII字符**(SQL Server示例) ```sql SELECT column_name, CHAR(ASCII(SUBSTRING(column_name, n, 1))) AS char_value FROM table_name WHERE ASCII(SUBSTRING(column_name, n, 1)) > 127 ``` *说明:`n`为字符位置,遍历字符串时可结合循环* 2. **清理特定范围字符** ```sql -- 清理ASCII码>127的字符(如中文) UPDATE table_name SET column_name = REPLACE(column_name, CHAR(ASCII_value), '') WHERE ASCII(SUBSTRING(column_name, pos, 1)) > 127 ``` 3. **批量替换非ASCII字符**(通用方法) ```sql CREATE FUNCTION dbo.RemoveNonASCII (@input NVARCHAR(MAX)) RETURNS NVARCHAR(MAX) AS BEGIN DECLARE @output NVARCHAR(MAX) = '' DECLARE @i INT = 1 WHILE @i <= LEN(@input) BEGIN IF ASCII(SUBSTRING(@input, @i, 1)) BETWEEN 32 AND 127 SET @output = @output + SUBSTRING(@input, @i, 1) SET @i = @i + 1 END RETURN @output END ``` *调用示例:`SELECT dbo.RemoveNonASCII('Açcèñtéd')` → 输出`Accentd*`[^1][^3] --- #### 三、字符编码验证(适用于数据插入异常) 当使用CLP连接数据库时: 1. **强制指定编码** ```bash db2cli execsql -connString "DATABASE=dbname;UID=user;PWD=pass;CHARSET=UTF8" ``` 2. **验证字符字节长度** 使用`HEX()`函数检查字段编码: ```sql SELECT HEX(column_name) FROM table_name WHERE id=123 ``` *正常UTF-8字符应为2-4字节组合(如`E4B8AD`表示汉字"中")[^4]* --- #### 四、标识符规范(适用于DDL语句报错) 若创建表/列时出现错误: 1. **避免非ASCII命名** ```sql -- 错误示例 CREATE TABLE 用户表 (ID INT); ❌ -- 正确示例 CREATE TABLE user_table (ID INT); ✅ ``` 2. **使用下划线替代特殊符号** ```sql -- 错误示例 CREATE TABLE order-details (...) ❌ -- 正确示例 CREATE TABLE order_details (...) ✅ ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值