打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Linux系统下SQL Server数据库操作
userphoto

2023.10.07 河北

关注

Linux系统SQL Server数据库操作命令


    • 连接数据库 sqlcmd命令

    • 创建数据库:

    • 查看所有数据库:

    • 创建表

    • 添加主键约束

    • 外部关键字

    • 怎么添加唯一约束

    • 怎么添加非空约束

    • 怎么使用默认约束

    • 设置表的属性值自动增加


连接数据库 sqlcmd命令

SQLServer 提供了 sqlcmd 命令,来让我们操作 SQLServer 数据库。接下来我们连接它,并在其中创建一个名为 TestDb 的数据库。

连接 SQLServer :sqlcmd -S localhost -U sa -P '<123123Aa!@>'


如果连接失败原因是服务还未开启,等待几秒重试即可,上述语句各参数解释如下:

sqlcmd 是连接数据库必要的语句, localhost 代表从本地连接,sa 是用户名, '<123123Aa!@>’ 是密码。

创建数据库:

create database TestDb

查看所有数据库:

select name from sys.databases。


操作完毕之后退出: exit 。

创建表

我们先来了解一下,在数据库中创建表的规则:

CREATE TABLE 表名( 字段名,数据类型, 字段名,数据类型, .....)

例如:


添加了数据的表格,示例如下:

首先,创建数据库(在 SQLServer 数据库中是不区分大小写的,不过数据库的名字是区分大小写的),如下:

CREATE DATABASE MyDb

然后,选择数据库:

USE MyDb

最后,创建t_user表:

CREATE TABLE t_user(
    id INT,
    username VARCHAR(32),
    password VARCHAR(32),
    phone VARCHAR(11))

表创建好之后,可以使用如下语句查看表的基本结构,用来验证是否创建成功。

语法如下:

sp_help 表名

添加主键约束

有两种方式可以添加主键约束:1.在定义列的同时指定主键,2.在定义完字段之后,再指定主键。

(1) 在定义列的同时指定主键:


(2) 在定义完所有列之后,指定主键。

多字段联合主键

在开发中,还有一种情况很常见,就是将几个字段联合在一起作为主键,那这个在代码中怎么实现呢?
举个例子,我们将员工的名字和部门 ID 联合起来作为主键:

CREATE TABLE t_emp2(
    name VARCHAR(32),
    deptId INT,
    salary FLOAT,
    PRIMARY KEY(name,deptId))

语句执行后,会将 name 和 deptId 字段组合成为表 t_emp2 的多字段组合主键。

外部关键字

外部关键字叫做外键,外键就是另一张表中的主键。

:外键有啥用啊?
:外键的主要作用就是保持数据的一致性,完整性。

再问:怎么保证的呢?
:看图。


如图有两张表,classId 是 T_Student 的外键,同时是 T_class 表的主键。如果我们要删除 T_class 表中 classId 为 1 的字段,程序是会报错的。因为 T_Student 表中有数据和 classId 为 1 的字段关联了,是不能删除的,这样子就保证了数据的一致性和完整性。

继续问:那怎么才能删除呢?
接着答:需要先删除 T_Student 表中 classId 为 1 的两个字段。

如何给表添加外部关键字
在 SQLServer 中,给表中字段添加外键约束的语法规则如下:

CONSTRAINT 外键名 FOREIGN KEY 字段名 REFERENCES 主表名(主键名)

举个例子:现在有两张表, t_emp , t_dept 如下:


我们来创建两张表,并给员工表( t_emp )添加外键:

CREATE TABLE t_dept(
    deptId INT PRIMARY KEY,
    name VARCHAR(22),
    location VARCHAR(50));CREATE TABLE t_emp(
    id INT PRIMARY KEY,
    name VARCHAR(22),
    deptId INT,
    CONSTRAINT fk_emp_dept1 FOREIGN KEY(deptId) REFERENCES t_dept(deptId));

实际操作如图:


另外一种设置外键的方式:

CREATE TABLE t_dept( deptId INT PRIMARY KEY, name VARCHAR(22), location VARCHAR(50));CREATE TABLE t_emp( id INT PRIMARY KEY, name VARCHAR(22), deptId INT FOREIGN KEY REFERENCES t_dept(deptId));

在定义字段的时候,也可以定义外部关键字,格式: FOREIGN KEY REFERENCES 关联的表名(字段名) ,这种方式比较简洁,不过这种方式不能指定外键名,即外键名是随机的。

怎么添加唯一约束

唯一约束( Unique Constraint )要求该列唯一,允许为空,但是只能有一个空值。唯一约束可以确保一列或者几列不出现重复值。

定义部门表的部门名称唯一,使用关键词 UNIQUE ,SQL 语句如下:

CREATE TABLE t_dept(
    id INT PRIMARY KEY,
    name VARCHAR(22) UNIQUE,
    location VARCHAR(50))

怎么添加非空约束

关键词: NOT NULL 。

例如:

CREATE TABLE t_dept( id INT PRIMARY KEY, name VARCHAR(22) NOT NULL, location VARCHAR(50))

怎么使用默认约束

默认约束:即给字段一个默认值。
关键词: DEFAULT 。

例如:

CREATE TABLE t_emp(
    id INT PRIMARY KEY,
    name VARCHAR(22),
    sex VARCHAR(2) DEFAULT '男')

注意:如果是添加字符串型,认值要使用单引号;如果是整型,则不需要加任何符号。

设置表的属性值自动增加

在数据库应用中,经常需要在每次插入新纪录时,系统自动生成字段的主键值,即:


关键词: IDENTITY(1,1) 表示自动增长,初始值为 1 ,增量为 1 。
例如:

CREATE TABLE t_tmp( id int PRIMARY KEY IDENTITY(1,1), name VARCHAR(32))
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
MySQL: MySQL约束(详细、全)
数据库部分(MySql)_4
mysql[0x01]--基础知识
2009-12-08传智播客 数据库——Oracle触发器/存储过程/视图等 - 充满生活的味道! - BlogJava
MySQL基础入门
MySQL8.0数据库基础教程(二)-理解"关系"
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服