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)

)

用linux命令创建表主键,Linux系统下SQL Server数据库操作相关推荐

  1. sql创建表主键gui_在SQL Server中使用主数据服务快速创建最终用户可以维护的GUI

    sql创建表主键gui 介绍 ( Introduction ) Oft times we are forced into situations where we clearly need to thi ...

  2. mysql 创建表主键_MySQL创建表和主键约束

    1.创建表 在操作数据表之前,应该使用"USE 数据库名"指定操作是在哪个数据库中进行 主键约束(唯一标识) ****非空*** ****唯一*** ****被引用****(学习外 ...

  3. linux oracle 创建表空间2016,Linux下Oracle表空间及用户创建

    记录详细过程以备使用 Connected to Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 Connected as sys@i ...

  4. DBATools PowerShell SQL Server数据库备份命令

    In my earlier PowerShell SQL Server article, SQL Database Backups using PowerShell Module – DBATools ...

  5. python怎么导入sql数据库,##使用python将excel表中数据导入sql server数据库

    如何用python将excel数据导入到postgresql数据库中 把excel表格另存为csv文件 python将exce文件含有多个sheet同时l导入sqlserver数据库 需要使用xlrd ...

  6. Java案例:连接SQL Server数据库,显示学生表记录

    Java案例:连接SQL Server数据库,显示学生表记录 演示利用JDBC连接SQL Server数据库,在Java GUI窗口里显示表记录. 一.运行效果 二.实现步骤 1.项目结构图

  7. SQL语句(二)创建带主键和约束的数据表

    内容摘要 创建带主键和约束的表 创建带组合主键和外键的表 1. 创建带主键和约束的表 Student (学生表) CREATE TABLE Student ( sclass varchar(10) N ...

  8. 关于DM达梦数据库,获取用户表信息、数据表结构、数据表创建语句、主键等信息的sql

    1.获取数据表中的字段名.类型.长度.描述 select name,reftype,length,descrip from ( select distinct A.COLUMN_ID as id, A ...

  9. 通过SQL命令创建表、删除表(二)

    通过SQL命令创建表.删除表 创建表命令 --emp表(员工表) create table emp (empno int primary key,ename nvarchar(200),job nva ...

最新文章

  1. CG游戏道具全流程制作视频教程 Artstation – Stylized Game Asset
  2. 一个模型搞定图像标注、读图问答两件事,VQA准确率逼近人类水平 | Demo可玩...
  3. 一:Greenplum5.10.2 生产环境安装配置 (系统初始化、安装准备)
  4. GVA gin-vue-admin部署后端注意事项
  5. leetcode讲解--559. Maximum Depth of N-ary Tree
  6. 20170125小测
  7. Java与.NET的WebServices相互调用
  8. 银行营业网点管理系统——dao包(BranchesDao)
  9. NLP复习资料(4)-第八章 句法分析
  10. 进程间通讯-3(Manager)-实现数据的同时修改
  11. Python 异常处理——处理默认错误类型以外错误
  12. CentOS 6.2目录服务之LDAP(一)
  13. 服务台与事件管理解决方案
  14. linux出现bash: ./java: cannot execute binary file 问题的解决办法
  15. 支付宝支付出现 openssl_sign(): supplied key param cannot be coerced into a private key
  16. C语言———指针(1.3间接寻址运算符)
  17. HONOR Magicbook 进不了系统
  18. xinput1_3.dll丢失怎么修复win10_有什么好的修复方法推荐?
  19. HBase启动成功,但不能访问Web页面
  20. 软考是什么?---2023年软考最全解析

热门文章

  1. redis常用命令_Redis的简介以及基本常用命令
  2. 2019 年百度之星·程序设计大赛 - 初赛一Game HDU 6669 (实现,贪心)
  3. 软件开发---全套规范
  4. WampServer修改端口及菜单Localhost
  5. [BZOJ 1048] [HAOI2007] 分割矩阵 【记忆化搜索】
  6. Codeforces 313
  7. 手把手教你:亲手打造Silverlight的Win8外观(1) 前言
  8. poj 3261 Milk Patterns 后缀数组 最长重复子串
  9. Qt-在控件上绘图的方式
  10. qt 配置的相对路径写法