T-SQL语句

2019-10-12  本文已影响0人  璎珞纨澜

数据库常用术语

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

上一篇下一篇

猜你喜欢

热点阅读