T-SQL语句

数据库常用术语

  • 关系:关系即二维表,每一个关系有一个关系名,就是表名。
  • 记录:表中的行
  • 域:即取值范围
  • 关联:不同数据表之间的数据彼此联系的方式
  • 关键字:属性或属性的组合,可以用于唯一标识一条记录。
  • 外部关键字:如果表中的一个字段,不是本表中的关键字,而是其他表中的关键字,称之为外部关键字。
  • 数据冗余:数据库表中的重复数据。
  • 数据完整性:指数据的一致性。
  • 数据库操作异常:
    • 插入异常
    • 更新异常
    • 删除异常
      插入、更新、删除操作导致当两个关联的表产生矛盾则会产生异常。
  • SQL 与 T-SQL的区别:
    • SQL:关系型数据库的标准语言,区别与高级语言sql语言只是数据库能够识别的一些指令。
    • T-SQL:在标准sql的基础上加强,除了标准sql所支持的命令外还对于sql进行了补充,提供了类似高级语言的基本功能:变量申明、流程控制、功能函数等。
  • T-SQL包括以下内容:
    • DQL(Data QueryLanguage) 数据查询语言:用来查询数据库中的数据。
    • DML(Data Manipulation Language) 数据操纵语言:用来插入、删除、修改数据库中的数据。
    • DCL (Data Control Language) 数据控制语言:用来控制数据库的存取许可、存取权限等。
    • DDL(Data Definition Language) 数据库定义语言:用来定义数据库、数据库对象和定义其列,大部分以create开头。
    • 说明、类型函数、其他命令等等。。

T-SQL创建数据库

create database testdb1
on
(
  name=testdb,
  filename='C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\DATA\testdb.mdf',
  size=6,
  maxsize=12,
  filegrowth=10%
)
log on
(
  name=testdb_log,
  filename='C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\DATA\testdb_log.ldf',
  size=1,
  maxsize=8,
  filegrowth=10%
)
  • 创建数据库需要定义数据库文件名,数据库文件存放位置,初始值,最大值,增量值。
  • 创建数据库需要定义数据库日志文件名,数据库日志文件文件存放位置,初始值,最大值,增量值。

T-SQL创建和删除表

  1. 创建表

创建职工表:

use testdb
create table Employee
(
    EmpId int,
    EmpName text,
    EmpAge int,
    EmpPay money,
    EmpJob text,
    EmpAddress text
)

创建教师表:

use testdb
create table Teacher
(
    教师编号 int,
    教师姓名 text,
    教师职称 text,
    教师工资 money
)

创建学生表:

use testdb
create table 学生表
(
    学生编号 int,
    学生姓名 varchar(50),
    学生年龄 int,
    家庭住址 text
)
  1. 删除表
use testdb
drop table 学生表

T-SQL修改数据库与数据表

  1. 为数据库增加数据文件和事物日志文件
alter database testdb
add file
(
    name=testdb2,
    filename='C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\DATA\testdb2.mdf',
    size=6
)
alter database testdb
add log file
(
    name=testdb2_log,
    filename='C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\DATA\testdb2_log.ldf',
    filegrowth=10%
)
  1. 删除数据库文件和事物日志文件

把刚才增加的两个文件删除:

alter database testdb
remove file testdb2
alter database testdb
remove file testdb2_log
  1. 修改数据库名称
exec sp_rename "学生表","Student"
  1. 为表增加字段或者删除字段
  • 添加字段
use testdb
alter table Teacher
add 家庭住址 text
alter table Teacher
add email varchar(50) default 'xxx@qq.com'

添加字段步骤:
(1)打开testdb数据库
(2)获取修改Teacher表的权限
(3)增加字段

  • 删除字段
use testdb
alter table Teacher
drop column 家庭住址
删除有约束的字段会执行报错

email字段有默认值的约束,所以需要先删除约束才能删除该字段。

use testdb
alter table Teacher
drop constraint [DF__Teacher__email__4AB81AF0]
alter table Teacher
drop column email
  1. 修改字段属性
use testdb
alter table Teacher
alter column 教师职称 varchar(60)

T-SQL 插入表

use testdb
insert into Teacher(教师编号,教师姓名,教师职称,教师工资) values(1,'王老师','高级教师','5000')
insert into Teacher(教师编号,教师姓名,教师职称,教师工资) values(2,'刘老师','高级教师','5000')
insert into Teacher(教师编号,教师姓名,教师职称,教师工资) values(3,'江老师','中级教师','3000')
insert into Teacher(教师编号,教师姓名,教师职称,教师工资) values(4,'李老师','中级教师','3200')
insert into Teacher(教师编号,教师姓名,教师职称,教师工资) values(5,'黄老师','高级教师','4000')

列属性如果不允许为null值,插入的时候必须有值,否则会报错无法插入。

T-SQL 查询表

  1. select * from dbo.Teacher
    * 是通配符,代表查询所有字段。

  2. select 教师编号,教师职称 from dbo.Teacher
    只查询教师编号和教师职称字段,不同字段的名称用逗号隔开。

  3. 按照某个字段的范围查询


    查询教师工资低于4000的记录
  4. 按照某几个字段逻辑运算结果查询
    (1)条件与
    select * from dbo.xxx where 条件1 and 条件2 and 条件3 and...
    (2)条件或
    select * from dbo.xxx where 条件1 or 条件2 or 条件3 or...
    (3)条件非
    select * from dbo.xxx where !条件1
    select * from dbo.xxx where not 条件1
    例如:select * from dbo.Teacher where not 教师工资>4000
    也等效于select * from dbo.Teacher where 教师工资!>4000
    其实,我们可以在where子句中使用多个条件语句进行运算得到查询条件,且其规则遵循运算符优先级:
    (1)括号
    (2)Not(非)、正号、负号
    (3)乘、除
    (4)加、减
    (5)比较运算符
    (6)And
    (7)Or

  5. 使用 in 查询多个状态值
    查询教师编号为2、3、4的记录:
    select * from dbo.Teacher where 教师编号 in (2,3,4)
    查询教师姓名不为刘老师、李老师、黄老师的记录:
    select * from dbo.Teacher where CONVERT(VARCHAR(4000),教师姓名) not in('刘老师','李老师','黄老师')
    注意:查询中文时,要将text(ntext)数据转换varchar(nvarchar),否则会报错 The data types text and varchar are incompatible in the equal to operator.

  6. 查询记录的某个字段是否为空值
    select * from dbo.XXX where 字段 is null
    select * from dbo.XXX where 字段 is not null

T-SQL 更新表

将所有的中级教师升级为高级教师,工资加1000元:

use testdb
update Teacher set 教师职称='高级教师',教师工资=教师工资+1000 where 教师职称='中级教师'

33

T-SQL 删除表

  1. 删除表中的所有记录
use testdb
delete from Teacher
  1. 按照条件删除表中记录
use testdb
delete from Teacher where 教师工资<4000

2-22

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,080评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,422评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,630评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,554评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,662评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,856评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,014评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,752评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,212评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,541评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,687评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,347评论 4 331
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,973评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,777评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,006评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,406评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,576评论 2 349

推荐阅读更多精彩内容