sql sever数据库常用的执行语句
--使用master数据库
use master
--创建数据库文件
create database 数据库名字
on
(
name=, --逻辑名称
filename= .ndf, --数据文件物理路径名称
size=, --文件初始大小
maxsize= , --文件最大的大小
filegrowth= --自动增长
)
--创建数据库日志文件
log on
(
name=, --逻辑名称
filename= .ldf, --日志文件物理路径名称
size=, --文件初始大小
maxsize= , --文件最大的大小
filegrowth= --自动增长
)
go
--修改数据库的名称
alter database 数据库名称
modify name = 新名称
--给数据库添加一个数据文件
alter database testdb
add file
(
name=, --逻辑名称
filename= .ndf, --数据文件物理路径名称
size=, --文件初始大小
maxsize= , --文件最大的大小
filegrowth= --自动增长
)
go
--给数据库添加一个日志文件
alter database testdb
add log file
(
name=, --逻辑名称
filename= .ldf, --日志文件物理路径名称
size=, --文件初始大小
maxsize= , --文件最大的大小
filegrowth= --自动增长
)
go
--删除数据文件或日志文件
alter database testdb
remove file 数据文件逻辑名称
go
alter database testdb
remove file 日志文件逻辑名称
go
--修改数据文件或日志文件
alter database testdb
modify file
(
name=, --逻辑名称
filename= .ndf, --数据文件物理路径名称
size=, --文件初始大小
maxsize= , --文件最大的大小
filegrowth= --自动增长
)
go
modify file
(
name=, --逻辑名称
filename= .ldf, --日志文件物理路径名称
size=, --文件初始大小
maxsize= , --文件最大的大小
filegrowth= --自动增长
)
go
--分离数据库(执行存储过程)
exec sp_detach_db 数据库名字
go
--附加数据库(执行存储过程)
exec sp_attach_db @dbname=, --附加的逻辑名称
@filename1=, --数据文件物理路径名称
@filename2= --日志文件物理路径名称
go
--删除数据库
use master
go
drop database 数据库名字
go
--数据类型
种类:
数字数据类型:int,bigint,smallint,tinyint,decimal,mumeric,float,real,money,smallmoney,bit
字符数据类型:char,varchar,nchar,nvarchar,ntext text
日期和时间:datetime,smalldatetime,date,time,datetime2,datetimeoffsef
二进制数据类型:binary,varbinary,image
其他数据类型:uniqueidentifier,xml,timestamp,sql_variant
整型:
bigint(取值范围在(-2^63次方)到(2^63次方-1))、存储8个字节。(不常用)
int(取值范围在(-2^31次方)到(2^31次方-1))、存储4个字节。
smallint(取值范围在(-2^15次方)到2^15次方-1)、存储2个字节。
tinyint(取值范围在0到255)、存储1字节。
浮点类型:
float(存储取决与n的值)
real(存储4个字节)
字符类型:
char 类型是固定长度
varchar 类型是可变长度
日期类型:
datetime(取值范围在 1753年1月1日到9999年12月31日)、精确度3.33毫秒。
smalldatetime(取值范围在 1900年1月1日到2079年6月6日)、精确度1分钟。
其他类型:
a)用于存储大型非Unicode字符、Unicode字符及二进制数据的固定长度数据类型和可变长度数据类型:
ntext:类型长度是可变的Unicode,最大长度为2^30次方-1个字符,存储大小是所输入字符个数的两倍。
text:服务器代码页中长度可变的非Unicode数据,最大长度为2^31次方-1个字符,当服务器代码页使用双字节字符时,存储仍是2,147,483,647 字节。根据字符串,存储大小可能小于2,147,483,647 个字节。
image:长度可变的二进制数据,从0到2^31次方-1个字节。
b)用来存储Unicode字符数据集的字符数据类型(nchar 长度固定,nvarchar 长度可变)。
nchar[(n)]:n个字符的固定长度的Unicode字符数据,n值必须在1到4000之间(含)。存储大小为两倍n字节。
nvarchar[(n|max)]:可变长度Unicode字符数据,n值咋1到4000之间(含),max指示最大存储大小为2^31次方-1字节。
存储大小是所输入字符个数的两倍+2个字节,所输入数据的长度可以为0个字符。
c)用来存储二进制数据的固定长度或可变长度的Binary数据类型。
binary[(n)]:长度为n字节的固定长度二进制数据,其中n是从1到8,000的值。存储大小为n字节。
varbinary[(n|max)]:可变长度二进制数据。n可以取从1到8,000的值。max指示最大的存储大小为2^31字节-1字节。存储大小为所输入数据的实际长度+2个字节。所输入数据的长度可以是0字节。
创建数据表:
--先使用新创建的数据库,然后再创建表
use 数据库名
go
--创建数据表
create table 数据表名
(
--表里的字段的定义
--语法:字段名 数据类型 [约束]
--约束可加可不加,加一个约束可以,加多个约束也可以
)
go
--创建数据表添加约束
create table 数据表名
(
--identity标识列约束:自动增长,只能在整形的列上添加该约束
--primary key主键约束:不能为空且值不能重复
--unique唯一约束:值唯一不能重复,但可以为空
--not null非空约束:值不能为空
--check检查约束:可以设置检查条件
--default默认约束:可以设置默认值
)
go
--修改表
alter table 表名
--添加列
alter table 表名
add 列名 数据类型 列的特征
--删除表
drop table 表名
--删除列
alter table 表名
drop column 列名
--修改用户名
alter table 表名
alter column 列名
--添加检查约束
alter table 表名
add constraint 约束名 约束表达式
--删除一个约束
alter table 表名
drop constraint 约束名
约束类型:
主键约束(primary key constraint):主键列数据唯一,并且不为空,简称pk。
唯一约束(unique constraint):保证该列不允许出现重复值,简称UQ。
检查约束(check constrait):限制列中允许的取值以及多个列之间的关系,简称CK。
默认约束(default constraint):设置某列的默认值,简称DF。
外健约束(foreign key constraint):用于在两个表之间建立关系,需要指定主从表,简称FK。
添加约束语法:
alter table 表名
add constraint 约束名 约束类型 具体的约束说明
数据操纵语言(DML):
按照指定的组合、条件表达式或排序检索已存在的数据库中数据,或对已经存在的数据库表进行元组的插入、删除、修改等操作。
命令:
select 字段名 from 表名
where 当下条件
insert into 表名(字段名)
values(值1、值2、值....)
update 表名 set 字段名=值
where 当下条件
delete from 表名
where 当下条件
数据定义语言(DDL)
创建、修改或删除数据库中各种对象,包括表、视图、索引等。
命令:
create table , create view ,create index、alter table , drop table , drop view , drop index
数据控制语言(DCL)
用来授予或收回访问数据库的某种特权、控制数据访问的发生时间及效果、对数据库进行监视。
命令:
grant、revoke
事务控制语言(TCL)
用来操作事务提交或回滚操作的语句。
命令:
commit、rollback
逻辑运算符:
and 逻辑语 (如果两个布尔表达式都为true,那么就为true)。
not 逻辑非 (对任何其他布尔运算符的值取反)。
or 逻辑或 (如果两个布尔表达式中的一个为true,那么就为true)
比较运算符
between (如果操作输在某个范围之内,那么就为true)。
in (如果操作数等于表达式列表中的一个,那么就为true)。
like (如果操作数与一种模式相匹配,那么就为true)。
通配符:
% (包含零个或更多字符的任意字符串)。
_(下划线) (任何单个字符)。
添加数据操作:
插入数据:
1)insert into 表名(字段1、字段n...)
values(值1、值2、值....)
2)insert into 表名
select 字段 from 新表名
直接创建没创建的表:
3)select 字段 into 未创建过的新表名 form 表名
4)insert into 表名
values (值1),(值2),(值3)
5)insert into 表名
select 值1 union 值2 union 值3
修改数据操作:
updade 表名 set 字段名 (不带条件)
updade 表名 set 字段名1、字段名2 where 当下条件 (带条件)
删除数据操作:
delete from 表名 (不带条件)
delete from 表名 where 当下条件 (带条件)
删除表里的所有数据:
truncate table 表名
查询数据操作:
--查询所有行所有列
select * from 表名
--查询部分行部分列
select 字段1,字段2,字段n from 表名
--查询部分行所有列
select * from 表名
where 当下条件
--查询部分行部分列
select 字段1,字段2,字段n from 表名
where 当下条件
--指定列查询,并给每一列设置一个列名(相当于取一个别名)
第一种方式:
select 别名1=字段名1,别名2=字段名2,别名n=字段名n from 表名
第二种方式:
select 字段名1 as 别名1,字段名2 as 别名2,字段名n as 别名n from 表名
group by分组查询:
第一种方式:
select 字段名1 from 表名 group by 字段名1
第二种方式:
select 字段名1 from 表名
where 当下条件
group by 字段名1
第三种方法:
select 字段名1 from 表名
group by 字段名1
having count(*)范围
第四种方法:
select 字段名1 from 表名
where 当下条件
group by 字段名1
having count(*)范围
order by查询后排序:
第一种方法(降序):
select * from 表名
order by 字段名 desc
第二种方法(升序):
select * from 表名
order by 字段名 asc(asc不写,默认的也是升序)
第三种方法(按多个不同的类型分别排序):
select * from 表名
order by 字段名1 desc(降序),字段名2 desc(降序)
top取前几条数据:
第一种方法(比如取前5条):
select top 5 * from 表名
第二种方法(用10%):
select top 10 percent * from 表名
使用“+”符号进行多列合并并查询
注:
1、可能有忽略了一些,但基本上很齐全。
2、本博文为原创,是个人积累的笔记。
sql sever数据库常用的执行语句的更多相关文章
- 关于Java连接SQL Sever数据库
1.前提条件 需要: 1>本机上装有SQL Sever数据库(2005.2008或者更高版本) 2>eclipse或者myeclipse开发环境 3>jar文件(名为sql_jdbc ...
- C#常见控件与SQL Sever数据库交互
C#常见控件与SQL Sever数据库交互 下拉框(ComboBox)与数据库绑定 首先,我们采用DataSet作为临时的数据库,这样会比较好 那么,我们先创建两个成员(对象) string sqlc ...
- 数据库操作----找了MySQL和SQL Sever两个的基础语句
这是MySQL的基本操作: 1 登入数据库:mysql -uroot -p+密码 (SQL Sever登入: osql -U 用户名 -P 密码) 显示已存在的数据库:show databases; ...
- 如何把本机Sql Sever数据库转移到虚拟主机sql数据库
不少站长的网站都是asp+access的网站 因为操作access数据库的网站非常简单,甚至你对数据库不懂都可以 但如果是mssql数据库的网站,有些新手朋友就不知道该怎么弄了 在这里给大家做个简 ...
- C#窗体程序与sql sever 数据库链接
一.所用工具 Visual Studio 2017和SQL Server Management Studio 2012 二.连接 打开SQL Server Management Studio 2012 ...
- SQL Server数据库常用的T-SQL命令
1. 查看数据库的版本 select @@version 2.查看数据库所在机器操作系统参数 exec master..xp_msver 3. 查看数据库启动的参数 sp_configure 4.查看 ...
- 通过sql 向数据库插入多行语句
我们知道通过insert into 表名(列名) values(值)是向表中插入一条语句,可是当我们需要向数据库插入多条语句时,应该怎么做呢? 可以通过如下格式的sql 语句来实现一次向数据库插入多行 ...
- SQL Server数据库常用函数
好久没学习新知识了.今天学了下sql的一些常用语句.人还是需要不断学习进步的 否则只能停滞不前. 先从最简单的一句开始说起吧. select *from 表名 这里*的含义 表示了表的各字段,以逗号隔 ...
- 3-1创建Sql Sever数据库登录名
登录名:连接Sql Sever 服务器 数据库用户名: Sql Sever 的使用者 每个用来登录Sql Sever 的账户都是一个用户. 同一个数据库可以拥有多个用户,每一个用户也同时可以访问多个数 ...
随机推荐
- java入门学习(4)— 类,对象理解,如何创建类,对象
1.什么是类?具有一定相同的属性的对象的集合就叫类.2.对象:类的具体实例,就是类的实例化.比如学生是一个类(student),那学生里面的小红就是一个对象,一个有学生的属性的对象.3.如何定义一个类 ...
- linux系统编程-进程
进程 现实生活中 在很多的场景中的事情都是同时进行的,比如开车的时候 手和脚共同来驾驶汽车,再比如唱歌跳舞也是同时进行的: 如下是一段视频,迈克杰克逊的一段视频: http://v.youku.com ...
- ubuntu 搜狗输入法成功安装
第一次成功安装这个破玩意,心里万分高兴啊! 几个条件: 1 ubuntu14.04 2 对的教程 参考文献:http://jingyan.baidu.com/article/ad310e80ae6d9 ...
- 【剑指offer】09-2跳台阶,C++实现
原创博文,转载请注明出处! # 本文是牛客网<剑指offer>刷题笔记 1.题目 # 一只青蛙一次可以跳1级台阶,也可以跳2级.求该青蛙跳n级的台阶总共有多少种跳法. 2.思路 # 跳0级 ...
- HDU2161
解题思路:判断素数模板题. #include<cstdio> #include<cstring> #include<algorithm> using namespa ...
- [Java]如何为一个自定义类型的List排序。
好吧,三年了,又重拾我的博客了,是因为啥呢,哈哈哈.今天被问到一个题目,当场答不出来,动手动的少了,再此记录下来. Q:有一个MyObject类型的List,MyObject定义如下: class M ...
- object references an unsaved transient instance【异常】
[异常提示] TransientObjectException: object references an unsaved transient instance -save the transient ...
- POJ2728 Desert King 【最优比率生成树】
POJ2728 Desert King Description David the Great has just become the king of a desert country. To win ...
- C# 中那些可以被重载的运算符,以及使用它们的那些丧心病狂的语法糖
C# 中的操作符重载并不新鲜.然而,到底有哪些操作符可以重载,重载操作符可以用来做哪些丧心病狂的事情呢? 本文收集了 C# 中所有可以重载的操作符,并且利用他们做了一些丧心病狂的语法糖. 可以重载 ...
- MAC OS、Windows 、HTML,CSS,font-family:中文字体的英文名称
宋体 SimSun 黑体 SimHei 微软雅黑 Microsoft YaHei 微软正黑体 Microsoft JhengHei 新宋体 NSimSun 新细明体 PMingLiU 细明体 Ming ...