文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

使用SQL语句创建数据库与创建表

2023-09-29 14:52

关注

在这里插入图片描述

前言

🎈个人主页:🎈 :✨✨✨初阶牛✨✨✨
🐻推荐专栏: 🍔🍟🌯 c语言初阶
🔑个人信条: 🌵知行合一
🍉本篇简介:>:
本篇记录一下牛牛在学校学习的sql serve数据库知识,内容比较基础适合,适合数据库初学者学习,希望对大家有些帮助,一起加油吧!

目录

一、通过sql语句实现

🐮1.1 创建数据库

创建数据库模板:

create database 数据库名称--创建数据库on primary(name--数据库的逻辑名称filename--物理存放位置及物理文件名称(Student_info.mdf就是在磁盘上显示的名称)size--设置数据文件初始大小maxsize--设置最大限制filegrowth--设置主数据文件增长幅度)log on--定义事务日志文件(name --逻辑名称filename--物理存放位置及物理文件名称size=--设置事务日志文件初始大小maxsize--设置最大限制为filegrowth--设置事务日志增长幅度)

还是范例看的更清楚,那就上栗子吧!

🌰栗子:
按要求创建一个数据库

具体参数如下表:

参数名称参考参数
数据库名称Student_info1
数据库逻辑文件名称Student_info1_data
数据库物理文件名称Stduent_info1_data.mdf
数据库文件初始大小20MB
数据文件大小最大值300MB
数据文件增长增量5MB
日志逻辑文件名称Student_info_log1
日志物理文件名称Student_info_log1.ldf
日志文件初始大小5Mb
日志文件大小最大值50MB
日志文件增长量1MB

代码:

create database Student_info1--创建数据库on primary(name= Student_info1,--数据库的逻辑名称filename='E:\大2上学期\数据库原理\sql serve\Student_info1.mdf',--物理存放位置及物理文件名称(Student_info.mdf就是在磁盘上显示的名称)size=20,--初始大小maxsize=300,--最大限制filegrowth=5--主数据文件增长幅度为5MB)log on--定义事务日志文件(name =Student_info_log1,--逻辑名称filename='E:\大2上学期\数据库原理\sql serve\Student_info1.ldf',--物理存放位置及物理文件名称size=5,--初始大小为5mbmaxsize=50,--最大限制为50mbfilegrowth=1--事务日志增长幅度为1mb)

🐶1.2 查看、验证创建的数据库。

数据库创建好了以后,我们可以查看数据库的属性是否符合要求.

执行sp_helpdb系统存储过程查看Student_info数据库的信息。
步骤如下:

输入sql语句

sp_helpdb Student_info1

最后单击"执行"按钮就OK了.

👾1.3 修改数据库的属性

当我们发现数据库的属性,创建的时候不小心写错了,或者别的原因需要修改数据属性的时候应该怎么办呢?😥

例如:
将刚刚创建的数据库Student_info 数据文件的初始值大小 改为30MB, 最大值 改为500MB, 数据增长量 改为5%, 日志文件初始值 改为20MB, 最大值 改为60MB, 数据增长量 为6%.

代码:

--修改数据文件属性ALTER DATABASE  Student_info1MODIFY FILE(NAME = Student_info1,--要修改属性的文件名称SIZE = 30,--修改初始大小为30mbmaxsize=300,--修改最大限制为300mbfilegrowth=5%--修改事务日志增长幅度为5%)--修改事务日志文件属性ALTER DATABASE  Student_info1MODIFY FILE(NAME =Student_info_log1,size=20,--修改初始大小为20mbmaxsize=60,--修改最大限制为60mbfilegrowth=6%--修改事务日志增长幅度为6%)

修改前后通过语句sp_helpdb Student_info1观察数据库属性的变化
修改前:

修改后:

🐻1.4 数据库的分离与附加。

数据库分离:数据库分离是指将数据库文件从数据库服务器实例中分离出来,相当于关闭了数据库。数据库分离后,应用程序不能连接到该数据库,数据库文件可以被其它进程访问。通常分离数据库用于快速地将数据库迁移到另一个SQLSERVER实例中.

从创建数据库的语句中我们不难知道,我们创建的数据库是一个存放在我们电脑硬盘上的一个文件,受DBMS(数据库管理系统)管理,如果我们想要自己创建的数据库在别的客户端,或者说是让别人在它的电脑上也能使用,我们就需要对数据库分离,然后找到被分离的数据库文件.mdf(数据文件),和.ldf(日志文件)
模板:

--分离execute sys.sp_detach_db @dbname=数据库名
execute sp_attach_db Student_info1 ,filenme

范例:将数据库Student_info1分离后又附加
代码:

----将数据库Student_info1分离execute sys.sp_detach_db @dbname='Student_info1'
execute sp_attach_db Student_info1 ,'E:\大2上学期\数据库原理\sql serve\Student_info1.mdf',--filename每个人的不一样,与当时创建的数据库存放的地址有关'E:\大2上学期\数据库原理\sql serve\本Student_info1.ldf'--filename每个人的不一样,与当时创建的数据库存放的地址有关

🐼1.5 创建数据表

模板:

create table 表名(属性名1 类型,属性名2 类型,属性名3 类型--注意最后一条语句不用',')

范例:

Student_info数据库包含3张表:请按要求创建下表Student表、Course表及SC表,分别代表学生信息、课程信息及学生选课信息。三张表要求如下:
--创建Student表create table Student(Sno char(8) primary key not null,--学号,并设置为主键(primary key)和非空(not null)Sname varchar(8) not null,--学生姓名Sex char(2) default '男' not null,--性别,设置默认值(default)为'男'Birth smalldatetime not null,--出生年月Classno char(3) not null,--班级号Entrance_date smalldatetime not null,--入学时间Home_addr varchar(40)--家庭住址(可以为空))--创建Course表create table Course(Cno char(3) primary key not null,--课程号Cname varchar(20) not null,--课程名称Toal_perior smallint,--总学时Gredit tinyint check(Gredit>0 and Gredit<=6)--学分,这里要使用check约束)--创建sc表create table Sc(Sno char(8)  not null,--学号Cno char(3) not null,--课程号primary key(sno,cno),--设置sno和cno的属性组为主键foreign key(sno)references student(sno),--设置外键foreign key(cno)references course(cno),--设置外键Grade tinyint check(Grade>=0 and Grade<=100)--成绩)

二、用通过SQL Sever Management Studio

2.1 创建数据库

步骤:
1.右击“数据库“,在弹出的快捷菜单中选择”新建数据库“

  1. 将要求参数在此界面设置。如下图:

2.2 查看、验证创建的数据库。

右击Student_info1数据库,在弹出的快捷菜单中,单击“属性”按钮。

2.3 修改数据库的属性

在打开的数据库属性对话框中,单击“文件”选项卡,即可查看数据库的属性。
双击可直接修改.

2.4 数据库分离与附加

数据库分离:

右击Student_info1数据库,在弹出的快捷菜单中选择“属性“,在”数据库属性对话框“中选择”选项“选项卡。找到限制访问,将其修改为”SINGLE_USER“

在提示框中单击"是".

当左侧显示(单个用户)的时候表示分离成功了一半

最后在打开的“分离数据库”对话框中:勾选“更新统计信息”复选框。
若“消息”列表没有显示存在活动链接,则“状态”列会显示“就绪”。
另外一种情况,“消息“列表显示”活动链接“,“状态”列表就会显示“未就绪“。
此时需要再勾选”删除链接“列的复选框。

数据库的附加:

将Student_info数据库再次附加到服务器中
1.选中左边“数据库“,右击。在快捷菜单中选择”附加”命令。

结语

牛牛并不建议使用SQL Sever Management Studio来完成相应的数据库操作,重点是要学会sql语句命令来执行操作,这是因为当我们在执行大量的数据任务时,用sql语句会显得方便很多.
好了,这次就讲到这里了,后续会继续更新数据库的知识.加油吧!
我的博客即将同步至腾讯云开发者社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan?invite_code=2kvagxv62400o

😍😍😍
最后,小伙伴们的点赞就是给牛牛最大的支持,能不能给牛牛来一个一键三连呢?谢谢支持。

来源地址:https://blog.csdn.net/qq_67276605/article/details/128049736

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯