DB2 表字段大小写问题
2014-06-11 16:56
274 查看
在DB2中,默认情况下所有的名称都可包含一下字符:
A-Z(大写)
0到9
@、#、$和_(下划线)
名称不能以数字和下划线开头。
数据库对象的表,其命名遵循以上规则,所以即使利用命令创建表时,使用的是小写,DB2仍会将其转换为大写。
但需要注意的是,并非db client软件也会自动转换,我在使用ibm data studio4 时,发现统计studio 提供的图形界面创建,并不能自动转换为大写,比如使用studio创建表时将字段定义为小写的name,这样再使用普通的SQL语句操作,例如:
insert into mytable(id,name) values(2,'kk')
这样就会出现错误:"NAME" 在使用它的上下文中无效。. SQLCODE=-206, SQLSTATE=42703, DRIVER=3.67.28
错误原因:因为查询是DB2自动将name字段转换为NAME去匹配,但数据表中的字段是小写的name,所以匹配不到 报错
解决办法:将上面sql改为insert into mytable(id,“name”) values(2,'kk'),即给小写name 加上“”
A-Z(大写)
0到9
@、#、$和_(下划线)
名称不能以数字和下划线开头。
数据库对象的表,其命名遵循以上规则,所以即使利用命令创建表时,使用的是小写,DB2仍会将其转换为大写。
但需要注意的是,并非db client软件也会自动转换,我在使用ibm data studio4 时,发现统计studio 提供的图形界面创建,并不能自动转换为大写,比如使用studio创建表时将字段定义为小写的name,这样再使用普通的SQL语句操作,例如:
insert into mytable(id,name) values(2,'kk')
这样就会出现错误:"NAME" 在使用它的上下文中无效。. SQLCODE=-206, SQLSTATE=42703, DRIVER=3.67.28
错误原因:因为查询是DB2自动将name字段转换为NAME去匹配,但数据表中的字段是小写的name,所以匹配不到 报错
解决办法:将上面sql改为insert into mytable(id,“name”) values(2,'kk'),即给小写name 加上“”
相关文章推荐
- FireBird里定义字段的大小写问题
- db2表名大小写问题
- Javaweb开发中,mysql数据库字段默认不区分大小写问题
- SQL语句大小写是否区分的问题,批量修改整个数据库所有表所有字段大小写
- Mysql中字段大小写敏感问题
- CLOB 字段的大小写字符敏感的问题
- postgresql 字段属性值大小写的问题
- PostgreSQL中表名、字段名大小写问题
- 对话屏幕Dynpro(SE51) 屏幕元素 屏幕属性 PAI事件的触发、屏幕元素Function Code设置 屏幕流逻辑Screen Flow Logic 对话屏幕中的字段命名大小写问题
- PostgreSQL中表名、字段名大小写问题
- java 数据库名、数据表名和字段名大小写问题
- DB2 字符串的字段转为整形时的问题
- Mysql数据库查询字段值区分大小写问题
- SQL Server 2008 中SQL查询语句中字段值不区分大小写问题处理
- JPA对应的数据库字段大小写问题
- 数据库字段区分大小写问题解决
- PostgreSQL中表名、字段名大小写问题
- MYSQL字段,表名大小写的问题 CASE IN-SENSITIVE MYSQL ON LINUX
- fastjson序列化(对象转字符串)时字段的大小写问题与我自己的使用方案
- MySQL表名、字段、查询大小写问题