欢迎来到《小5讲堂》,大家好,我是全栈小5。
这是《Sql Server》系列文章,每篇文章将以博主理解的角度展开讲解,
特别是针对知识点的概念进行叙说,大部分文章将会对这些概念进行实际例子验证,以此达到加深对知识点的理解和掌握。
温馨提示:博主能力有限,理解水平有限,若有不对之处望指正!
目录
- 前言
- 创建表
-
- 效果
- 代码
- 设置默认值
-
- 正确格式
- 错误格式
- 效果
- 代码
- 修改类型
-
- 格式
- 效果
- 代码
- 疑问解答
-
- 原因
- 文章推荐
前言
上篇文章已经讲解在已有表基础上新增表字段以及设置说明,
本篇文章将讲解,如何在已有表基础上给指定表修改默认值以及数据类型。
【Sql Server】新手一分钟看懂在已有表基础上增加字段和说明
创建表
效果
代码
假设我们增加如下表结构
-- 创建表
create table my_table_name
(
id int identity(1,1) primary key,
name_text varchar(50),
create_time datetime,
value_text nvarchar(50)
)
设置默认值
正确格式
在 SQL Server 2022 中,设置字段的默认值的确有了一种新的语法。
- 以下是正确的示例:
-- 添加字段的默认值
ALTER TABLE 表名
ADD CONSTRAINT 默认值约束名 DEFAULT 默认值 FOR 字段名 WITH VALUES;
请将 “表名” 替换为你要修改的表的实际名称,将 “字段名” 替换为你要设置默认值的字段的实际名称,将 “默认值” 替换为你想要设置的新默认值。
- 以下是一个具体的示例,将表 “xxx” 中的字段 “create_time” 的默认值设置为当前时间:
-- 添加字段的默认值
ALTER TABLE xxx
ADD CONSTRAINT DF_xxx_create_time DEFAULT GETDATE() FOR create_time WITH VALUES;
执行这段代码后,它将为表 “xxx” 中的字段 “create_time” 添加一个名为 “DF_xxx_create_time” 的默认值约束,并将默认值设置为当前时间。
同时,WITH VALUES 选项可以通过向现有数据行填充默认值来更新现有数据。
错误格式
网上有些提到的一些格式可能是错的,或者是旧的写法
alter table 表名
alter column 字段名 default 默认值;
效果
代码
-- 设置默认值
alter table my_table_name
add default (getdate()) for create_time with values
修改类型
格式
填写表名、字段名、数据类型,默认是null可空,在后面设置not null不可空
alter table 表名
alter column 字段名 数据类型 [not null]
效果
- 修改前
- 修改后
代码
-- 修改类型 - 设置数据类型以及不可为空值
alter table my_table_name
alter column name_text nvarchar(20) not null
-- 修改类型 - 设置数据类型
alter table my_table_name
alter column value_text varchar(20)
疑问解答
也许有同学会问,有可视化工具修改字段类型和默认值,为什么还要用sql语句来修改?
原因
使用 SQL 语句来修改字段类型和默认值是一种最常见和灵活的方法。
SQL 语句允许你对数据库进行高度自定义的操作,使你能够实现更复杂的修改和逻辑。
虽然现在有许多强大的可视化工具可以用来管理数据库,但是 SQL 语句仍然是数据库管理和维护的核心。
使用 SQL 语句可以确保准确性和一致性,并提供更详细的控制,适用于广泛的数据库管理任务。
1.灵活性
SQL 语句提供了更大的灵活性,可以满足各种复杂的需求。可以定义自定义规则和逻辑来处理字段类型和默认值的修改,与数据库设计和业务需求更加贴合。
2.批量操作
使用 SQL 语句,可以一次性对多个表、多个字段进行修改,以提高效率,并确保修改的一致性。
3.跨平台和可移植性
SQL 语句可以在不同的数据库系统中使用,使代码更具可移植性。这意味着,如果需要在不同的数据库系统之间进行迁移或使用多个数据库系统,可以更轻松地迁移和管理你的数据库结构。
4.版本控制和文档化
SQL 语句可以轻松地进行版本控制,能够记录和跟踪数据库结构的变化,从而方便团队合作和维护。此外,SQL 语句也可以作为文档,记录对数据库结构的修改和操作步骤,方便以后查阅和理解。
文章推荐
同类型文章,推荐大家阅读博主在csdn平台上写的其他关于sql server的文章
-
【数据库】Sql Server数据迁移,处理自增字段赋值
-
【数据类型】C#和Sql Server、Mysql、Oracle等常见数据库的数据类型对应关系
总结:温故而知新,不同阶段重温知识点,会有不一样的认识和理解,博主将巩固一遍知识点,并以实践方式和大家分享,若能有所帮助和收获,这将是博主最大的创作动力和荣幸。也期待认识更多优秀新老博主。