SQL Server column not allow Null,insert failed

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介:

这个是一个Vendor的应用程序报的错误。,单看这个错误原因很简单,尝试将NULL值插入到表,但是表不允许使用NULL值。

 

查到后面发现其实根本原因是字段的内容没有按照当时的规定。按照要求,用户输入的需要包含’-’,但是用户输入的数据没有这个字符,系统尝试用”-”分隔数据的时候出现问题。

 

其实这个是应用程序设计的问题,在用户输入的时候根据规则验证用户的输入,确保所有的数据都是合理的,这样可以避免后续的问题。(如果不做验证的话,除了业务逻辑的问题,还可能会导致SQL注入的问题)。

 

解决思路:除了在应用端做验证,也可以用SQLServer Constraint

 

下面举个例子:

 

createtable test(namevarchar(10))

 

altertable testaddconstraintck_nameCHECK(charindex('-',name)>0)

 

如果我尝试插入没有”-”字符的数据会出现下面的错误:

 

insertinto testvalues ('4')

 

Msg 547, Level16, State 0, Line 1

The INSERTstatement conflicted with the CHECK constraint "ck_name". Theconflict occurred in database "master", table "dbo.test",column 'name'.

The statement has beenterminated.



 

有一点要注意保持事物的完整性,如果一次插入多条记录,不用显示事物的话可能会出现有些插入成功,有些失败的情况。为了保持完整性,可以用显事物:

 

begintry

begintran

insertinto test values ('1-')

insertinto test values ('2-')

insertinto test values ('3-')

insertinto test values ('4')

insertinto test values ('5-')

committran

endtry

begincatch

rollbacktran

endcatch

 

这样如果有一条记录有问题就会回滚整个事务。Constraint还可以限制唯一值,外键,用正则表达式等,功能非常强大,数据输入的时候做好验证,可以避免后续很多的维护问题。

 


本文转自 lzf328 51CTO博客,原文链接:


http://blog.51cto.com/lzf328/1351662

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
20天前
|
SQL XML Java
mybatis :sqlmapconfig.xml配置 ++++Mapper XML 文件(sql/insert/delete/update/select)(增删改查)用法
当然,这些仅是MyBatis功能的初步介绍。MyBatis还提供了高级特性,如动态SQL、类型处理器、插件等,可以进一步提供对数据库交互的强大支持和灵活性。希望上述内容对您理解MyBatis的基本操作有所帮助。在实际使用中,您可能还需要根据具体的业务要求调整和优化SQL语句和配置。
26 1
|
1月前
|
SQL 关系型数据库 MySQL
INSERT INTO t_a.tableName SELECT * FROM t_b.tableName 如何通过定义一个list对象,包含多个tableName,循环执行前面的sql,用MySQL的语法写
【8月更文挑战第7天】INSERT INTO t_a.tableName SELECT * FROM t_b.tableName 如何通过定义一个list对象,包含多个tableName,循环执行前面的sql,用MySQL的语法写
24 5
|
1月前
|
SQL 关系型数据库 BI
关系型数据库SQL server INSERT 语句
【8月更文挑战第3天】
44 9
|
2月前
|
SQL
SQL NOT NULL 约束
【7月更文挑战第18天】SQL NOT NULL 约束。
35 6
|
2月前
|
SQL 数据库
SQL INSERT INTO 语句
【7月更文挑战第12天】SQL INSERT INTO 语句。
71 12
|
2月前
|
SQL
SQL NOT NULL 约束
【7月更文挑战第16天】SQL NOT NULL 约束。
29 3
|
2月前
|
SQL 数据库
SQL INSERT INTO 语句
【7月更文挑战第11天】SQL INSERT INTO 语句。
38 2
|
2月前
|
SQL 存储 索引
MySQL设计规约问题之为什么应该把字段定义为NOT NULL并且提供默认值
MySQL设计规约问题之为什么应该把字段定义为NOT NULL并且提供默认值
|
3月前
|
SQL
SQL NULL 值
SQL NULL 值
363 3
|
3月前
|
SQL Oracle 关系型数据库
SQL NULL 函数
SQL NULL 函数
38 1