SQL Server全套教程(基于SQL语句----续更中)

news2025/3/1 11:48:10

SQL Server全套教程全程干货

  • 1. 数据库的基础操作
    • 1.1.0 创建数据库
    • 1.1.1 查看及修改数据库
    • 1.1.3 分离、附加和删除数据库
  • 2.数据库表的相关操作
    • 2.1.0 常用数据类型
    • 2.1.1 表结构的创建
    • 2.1.2 表结构的查看及修改

1. 数据库的基础操作

1.1.0 创建数据库

数据库创建语法

-- 创建数据库
1. create database 数据库名字 

2. on primary(
 	name='数据文件名',
 	filename='完整路径\数据文件名.mdf',
 	size=初始大小,maxsize=最大大小,
 	filegrowth=文件增长比
 	)
 	
 	--创建日志文件
3.log on (
	name='日志文件名',
	filename='完整路径\日志文件名.ldf',
	size=初始大小,
	maxsize=最大大小,
	filegrowth=文件增长比
)

数据库创建实例示范

在这里插入图片描述
解说:
按上图SQL语法即可以创建名为Mi的数据库,数据主文件Mi_data.mdf,以及数据日志文件Mi_log.ldf
拓展(三种文件类型):.mdf主数据文件 .ndf次数据文件 .ndf日志文件

1.1.1 查看及修改数据库

数据库查看语法

 --查看数据库
1. exec sp_helpdb 数据库名​

在这里插入图片描述
数据库修改语法

--修改数据库
2. alter database 数据库名
   add file/add log file /modify filefile为数据库mdf文件名)

在这里插入图片描述
解说:
查看数据库可以看到当前数据库的一些基本信息,数据库名、文件大小、存放位置等;修改数据库,上图操作将初始日志文件2048KB大小Mi_log.ldf文件,增加至了3072KB。

1.1.3 分离、附加和删除数据库

数据库分离语法
目的:分离数据库是为了能够手动找到数据数据文件,将其物理拷贝到其他地方,进行备份。

-- 分离数据库
1.exec  sp_detach_db ' 数据库名'

数据库附加语法
目的:能够使用其他数据库文件,导入他人的数据库。

-- 附加数据库
2.exec sp_attach_db '数据库名','完整路径\数据文件名.mdf'

数据库删除语法

-- 删除数据库(注意哦,删除不可逆哦,当前使用库删除操作不能完成)
3.drop database 数据库名

数据库分离、附加及删除实例演示

1. 分离数据库
 exec sp_detach_db Mi
2.附加数据库
 exec sp_attach_db 'Mi','E:\SqlServerDate\OthersData\Mi_data.dmf'3.删除数据库
 drop database Mi​-- 
4.判断加删除数据库
 if exists (select * from sys.databases where name = 'Mi')    drop database Mi

2.数据库表的相关操作

2.1.0 常用数据类型

  1. 整数型 (int)

    userId int primary key identity(1.1)
    
  2. 定长字符(char)

    userName char(10) not null
    -- char(10) 即使存入'ab'两个字节,但它仍然占用10个字节
    
  3. 变长字符(varchar)

    userName varchar(10) not mull
    -- varchar(10) 存入多少占用多少字节 最大为10个字节
    
  4. 长文本类型(text)

    address text not null
    -- text是长文本类型,可以无限制写入,但是执行效率比较低
    
  5. char、varchar、text前加n

    userName nvarchar(100) not null
    -- nvarchar(100) 存储unicode码 
    varchar(100) 存储100个字母,存储50汉字
    nvarchar(100) 存储100个字母,存储100汉字
    
  6. 时间(date、datetime)

    -- datetime可以存储年月日时分秒,当前时间前后都可以
    userBirth datetime not null,
    -- date存储年月日
    userBirth date not null
    
    -- smalldatetime 表示在当前时间之前的时间
    userBirth smalldatetime not null
    
  7. 小数(float,decimal,bit)

    salary decimal(12,2) check(salary >=1000 and salary <= 1000000) not null,-- 薪水
    decimal(总长度,小数位数)	
    bit类型放01
    

2.1.1 表结构的创建

数据表的创建语法

1.建表
-- 切换到目标数据库
use 目标数据库名
create table 表名(
	字段1  数据类型 ,
	字段2  数据类型 
)

数据表的创建实例
在这里插入图片描述
说明:
数据库表,也称二维关系表,对应具体的一个实体。针对于上文,数据库的切换,可以采用图形化界面操作,也可以使用SQL语句的方式切换,如何查看数据库是否已经切换为当期数据库。查看MSMS图形化管理工具的左上角一个下拉框。当数据表字段存在关键字时,可以采用[ ] 将字段名括起来,避免语法错误。

在这里插入图片描述

2.1.2 表结构的查看及修改

查看表结构:

-- 语法:
exec sp_help 表名

在这里插入图片描述
表结构的修改:

  1. 添加列

    -- 语法:alter table 表名 add 新列名 数据类型
    alter table userInfo add email nvarchar(20)
    
  2. 删除列

    -- 语法:alter table 表名 drop column 列名
    alter table userInfo drop email 
    
  3. 修改列

    -- 语法:alter table 表名 alter column 列名 数据类型
    alter table userInfo alter coulumn phone nvarchar(13)
    -- 注意:如果该表数据,phone字段数据长度假设添加的是20位的,现在修改位13是会报错的
    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/18844.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MicroPython-On-ESP8266——8x8LED点阵模块(2)使用74HC595驱动

MicroPython-On-ESP8266——8x8LED点阵模块&#xff08;2&#xff09;使用74HC595驱动 1. 使用74HC595驱动的原理 1.1. 基础回顾 上篇我们学习了8x8LED点阵屏的电路基础知识和驱动的原理&#xff0c;见 8x8LED点阵模块&#xff08;1&#xff09;驱动原理 里面也提到了&…

基于ssm+Javaweb的OA小型企业资源管理系统-计算机毕业设计

小型OA企业资源管理系统基于SSM(SpringSpringMVCMyBatis)框架,适用于毕业设计&#xff0c;采用javaweb,基于B/S模式,Myeclipse或者eclipse idea为开发工具,mysql数据库,主要包括登录模块、人事管理模块、公告管理模块、产品管理模块、和退出模块等多个模块。 本系统主要包含了…

MySQL高级篇知识点——主从复制

目录1.主从复制概述1.1.如何提升数据库并发能力1.2.主从复制的作用2.主从复制的原理2.1.原理剖析2.2.复制的基本原则3.一主一从架构搭建3.1.准备工作3.2.主机配置文件3.3.从机配置文件3.4.主机&#xff1a;建立账户并授权3.5.从机&#xff1a;配置需要复制的主机3.6.测试3.7.停…

tensorflow2.x --------------------DenseNet-----------------------------

用tensorflow2.4实现了DenseNet-121,训练基于ImageNet图像数据集&#xff0c;图片输入大小为 224x224 。网络结构采用包含4个DenseBlock的DenseNet-BC&#xff0c;每个DenseNet-BC由若干个 BNReLU1x1 ConvBNReLU3x3 Conv&#xff08;Dense_layer)且每个DenseBlock的特征图大小分…

听我劝,自学游戏建模真的很难

我的个人建议一直是偏向不要自学建模的&#xff08;特别是零基础&#x1f923;&#xff09;&#xff0c;学习3D游戏建模除了单纯需要为爱发电还需要能够自行✅掌握软件操作技巧和✅纠错改正&#xff0c;后者都是自学非常❌难做到的&#x1f62d; 除此之外&#xff0c;还有以下…

详解Unity中的Nav Mesh新特性|导航寻路系统 (二)

前言 第一篇我们简要概述了新版NavMesh的一些新增功能&#xff0c;以及旧版的对比。本篇我们来讲一讲NavMeshSurface、NavMeshLink这两个组件的参数以及如何应用&#xff0c;接下来就进入正题吧。 本系列提要 Unity新版NavMesh专题博客共分成三篇来讲解&#xff1a; 【本篇为…

Golang入门笔记(最后一章 17 封版)—— 映射map

映射 (map) 作为一个常用的类型&#xff0c;Go语言已为我们开发者内置了map类型。 基本语法&#xff1a; var 变量名 map [keyT类型] valueT类型 这里T就是一个类型代表&#xff08;我这么写&#xff0c;有点受到了Java的泛型影响&#xff09;&#xff0c;key的类型通常为str…

【20-业务开发-基础业务-商品模块-分类管理-前端展示后端具有层级关系的目录数据-商品系统三级分类的逻辑删除前后端代码实现】

一.知识回顾 【0.三高商城系统的专题专栏都帮你整理好了&#xff0c;请点击这里&#xff01;】 【1-系统架构演进过程】 【2-微服务系统架构需求】 【3-高性能、高并发、高可用的三高商城系统项目介绍】 【4-Linux云服务器上安装Docker】 【5-Docker安装部署MySQL和Redis服务】…

JUC线程池——newSingleThreadExecutor源码解析JDK提供线程池ThreadPoolExecutor执行任务流程解析

newSingleThreadExecutor源码解析&&JDK提供线程池ThreadPoolExecutor执行任务流程解析测试代码核心代码解析ThreadPoolExecutor内部类&#xff1a;Worker解析调试台线程切换到执行异步任务的线程ThreadPoolExecutor&#xff1a;getTask()LinkedBlockingQueue&#xff1…

shell-函数

函数介绍 shell中有系统函数&#xff0c;也可以自定义函数 系统函数 basename basename [pathname] [suffix] 返回完整路径最后的/的部分&#xff0c;常用于获取文件名 basename命令会删掉所有的前缀包括最后一个/字符&#xff0c;然后将字符串显示出来 suffix为后缀&#…

java计算机毕业设计专业招聘网站(附源码、数据库)

java计算机毕业设计专业招聘网站&#xff08;附源码、数据库&#xff09; 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat8.5 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技…

从零搭建个人博客项目并通过github部署上线

文章目录一、环境准备二、创建hexo博客项目1.全局安装hexo-cil工具2.新建hexo项目3.启动项目三、部署上线1.新建github仓库2.修改配置项3.部署项目一、环境准备 1.Node.js (版本需不低于 10.13) 2.Git https://hexo.io/zh-cn/ hexo博客官方文档 二、创建hexo博客项目 1.全局安…

dhtmlx甘特图marker不随小时移动

dhtmlx甘特图marker是什么&#xff1f; 就是一个跟着日期变化的标记&#xff0c;如下图所示 这段代码是用来调整标记的样式&#xff0c;展示文本的关键代码&#xff0c;如要配置今日标记&#xff0c;需在plugins添加maker后加上这段代码 start_date是用来获得日期的&#xf…

Ubuntu20单机搭建MongoDB4.2集群详细

文章目录 MongoDB文件下载选择你的服务器的安装路径配置文件启动服务集群配置MongoDB文件下载 curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-ubuntu1604-4.2.23.tgz # 直接将版本号4.2.23换成自己需要的版本号即可 将文件下载到你的服务路径选择你的服务器…

《士兵突击》哪些最精彩的话语

目录 1、人不能过得太舒服&#xff0c;太舒服了容易出问题 2、别混日子了&#xff0c;小心日子把你给混了 3、想到和得到&#xff0c;中间还有两个字&#xff0c;那就是要做到 4、每做对一件小事&#xff0c;就被他像救命稻草一样抓着 5、我会带着问题生活&#xff0c;因为…

Qt 事件处理机制简介

1.Qt中事件的来源&#xff0c;谁接收处理。 Qt中事件的来源有两个&#xff1a;程序外部和内部&#xff0c;多数情况下来自操作系统&#xff0c;可以通过bool QEvent::spontaneous() const函数来获知&#xff0c;返回true&#xff0c;事件发生在应用程序之外(系统事件)&#xf…

SAP S4 FI后台详细配置教程- PART1 (通用配置及基础架构篇)

目录 一 、基础配置 3、设置国家区域 4、货币设置 二 、企业结构 1、定义公司 2、定义公司代码 3、维护成本控制范围 4、给公司分配公司代码 5、把公司代码分配给控制范围 本文是会是一篇比较详细文章&#xff0c;也是本人的学习记录。介绍如何在SAP从 0 到 1配置 一家公司 PAR…

虚拟机的 Ubuntu 没有 /dev/fb0 的解决办法

目录 一、概述 二、没有/dev/fb0的可能原因 三、解决过程 四、vesafb:mtrr,ywrap vga0x315的解释 一、概述 近期在学习FrameBuffer相关内容&#xff0c;想在Vmware虚拟机打开Ubuntu 12.04的系统使用一下&#xff0c;发现没有/dev/fb0的文件&#xff0c;于是上网搜索解决办法&…

数据结构之链表(带头双向循环链表)

文章目录前言一、带头双向循环链表二、双向链表的实现1.双向链表的定义2.双向链表的接口3.接口的实现创建返回链表的头结点创建一个新节点打印链表链表的销毁尾插尾删头插头删在链表中进行查找在pos前面插入数据链表删除pos位置处的节点4.主函数&#xff08;测试&#xff09;总…

vue-vuetify-admin案例讲解

vue-vuetify-admin案例讲解1. Introduction1.1 directory structure1.2 vue-cli1.3 vuex1.3.1 在store目录创建index.js1.3.2 在main.js中引入1.3.2 操作数据1.3.4 获取store中的值1.4 vue-router1.5 axios1.6 vuetify2. Code2.1 入门2.2 入门2.3 入门3. xxxvue-vuetify-admin:…