有的朋友在做用户维护字段的界面时,肯定发现一个问题,当用脚本: ALTER TABLE 表名 DROP COLUMN 字段名 进行删除字段的操作时,会出现“服务器: 消息 5074,级别 16,状态 1,行 1 ”的错误,这是因为字段有了默认值,不过可以通过清除掉默认值的存储过程来进行这个操作,但如果在删除字段前,强行运行 sp_unbindefault '表名.字段名' 这样的操作,如果字段没有默认值,却会产生一个异常,虽然不会影响操作的结果,但这样会让用户摸不着头脑。 为了解决这个矛盾的问题,有一个办法:先检查字段是否绑定有默认值,如果有的话才运行sp_unbindefault '表名.字段名',否则不运行,这样就不会出现错误提示的尴尬局面。 检查的方法是: SELECT syscolumns.cdefault FROM sysobjects LEFT OUTER JOIN syscolumns ON syscolumns.id = sysobjects.id WHERE (sysobjects.name = '表名') AND (syscolumns.name = '字段名') 如果cdefault<>0则表示没有默认值,需要运行sp_unbindefault '表名.字段名',反之则不需要。