如何用SQL语句修改一个表的字段,让它不能为空

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何用SQL语句修改一个表的字段,让它不能为空相关的知识,希望对你有一定的参考价值。

ALTER TABLE 表 ALTER COLUMN [字段名] 字段类型 NOT NULL

SQL语句

1、基本介绍:

sql 语句是对数据库进行操作的一种语言。

结构化查询语言(Structured Query Language)简称SQL,结构化查询语言是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统。

2、简单基本的sql语句:

更新:update table1 set field1=value1 where 范围

查找:select * from table1 where field1 like ’%value1%’ (所有包含‘value1’这个模式的字符串)

排序:select * from table1 order by field1,field2 [desc]

求和:select sum(field1) as sumvalue from table1

平均:select avg(field1) as avgvalue from table1

最大:select max(field1) as maxvalue from table1

最小:select min(field1) as minvalue from table1[separator]

参考技术A 那你得修改表结构, 给这个字段一个非空约束 参考技术B 1

alter table 表名 alter column 列名 类型长度 null

中文处替换一下就行
比如原来类型是varchar(10)

1

alter table 表名 alter column 列名 varchar(10) null
参考技术C ALTER TABLE 表 ALTER COLUMN [字段名] 字段类型 NOT NULL;

本回答被提问者采纳

微软的sql2005中如何用SQL语句查询出将一个表的字段的说明

查询列信息的
--isnull函数:需要个参数,如果第一个参数为空,则赋值第二个参数。
SELECT
--空格代表as关键字
(case when a.colorder=1 then d.name else '' end) 表名,a.colorder 字段序号,a.name 字段名,
(case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then '√'else '' end) 标识,
(case when (SELECT count(*) FROM sysobjects WHERE (name in
(SELECT name FROM sysindexes WHERE (id = a.id) AND (indid in
(SELECT indid FROM sysindexkeys WHERE (id = a.id) AND (colid in
(SELECT colid FROM syscolumns WHERE (id = a.id) AND (name = a.name))))))) AND
(xtype = 'PK'))>0 then 'true' else 'false' end) 主键,b.name 类型,
a.length 占用字节数, COLUMNPROPERTY(a.id,a.name,'PRECISION') as 长度,
isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0) as 小数位数,
(case when a.isnullable=1 then 'true'else 'false' end) 允许空,
isnull(e.text,'') 默认值, isnull(g.[value],'') AS 字段说明
--a代表列集合表:为每个表和视图中的每列返回一行,并为数据库中的存储过程的每个参数返回一行
--b代表列类型表:为数据库中定义的每种系统提供的数据类型和每种用户定义的数据类型返回一行。
FROM syscolumns a left join systypes b
on a.xtype=b.xusertype
--d代表对象表:在数据库中创建的每个对象(例如约束、默认值、日志、规则以及存储过程)都对应一行
inner join sysobjects d
on a.id=d.id and d.xtype='U' and d.name<>'dtproperties'
--e代表e.text是默认值:包含数据库中每个视图、规则、默认值、触发器、CHECK 约束、DEFAULT 约束和存储过程的项
left join syscomments e
on a.cdefault=e.id
--g代表g.[value]是字段说明:针对当前数据库中的每个扩展属性返回一行。
left join sys.extended_properties g
on a.id=g.major_id AND a.colid = g.major_id
order by a.id,a.colorder
参考技术A sp_help 表名追问

这个不行,没有说明的这个字段显示

追答

SELECT
a.colorder AS 字段序号, a.name AS 字段名, ISNULL(c.[value], '') AS 字段说明
FROM dbo.syscolumns a LEFT OUTER JOIN
dbo.sysobjects b ON a.id = b.id AND b.xtype = 'U' AND
b.status >= 0 LEFT OUTER JOIN
sys.extended_properties c ON a.id = c.major_id AND a.colid = c.minor_id AND
c.name = 'MS_Description'
WHERE b.name=N'表名'

以上是关于如何用SQL语句修改一个表的字段,让它不能为空的主要内容,如果未能解决你的问题,请参考以下文章

微软的sql2005中如何用SQL语句查询出将一个表的字段的说明

MYSQL如何用语句给某字段的空字符串附一个值?

怎样用SQL语句修改字段名

sql语句 如何创建一个表啊?

如何用标准SQL语句给一张表中添加多个字段

如何用SQL语句删除两个表中相同的记录?