历史

有很多软件公司开发了数据库产品,其中微软公司的数据库产品命名为 SQL Server,也称 MS SQL Server。

1989年 Ashton-Tate/Microsoft SQL Server 1.0 for OS/2 正式发布。

1996年,微软发布了 SQL Server 6.5,作为对 SQL Server 6.0 的重要更新。

1998年12月,SQL Server 7.0 正式上市。

2000年8月,SQL Server 2000 发布。

DDL(Data Definition Language)(数据库定义语言)

  • 创建

    • 创建数据库

      CREATE DATABASE 数据库名;
  • 查询
    • 查看所有的数据库

      SELECT Name FROM Master..SysDatabases ORDER BY Name
  • 删除
    • 删除数据库

      DROP DATABASE 数据库名;
  • 使用
    • 使用数据库

      use 数据库名称;

操作表

  • 创建

    • 创建表

      CREATE TABLE 表名 (

      字段名 1 字段类型 1,

      字段名 2 字段类型 2

      );
    • 数据库类型分类
分类 数据库中的类型 JAVA中对应类型
整数 bigint long
整数 bit boolean
整数 int(integer) int(integer)
整数 tinyint short
小数 float double
小数 decimal java.math.BigDecimal
小数 money java.math.BigDecimal
小数 smallmoney java.math.BigDecimal
日期 smalldatetime 表示时间类型(只精确到分)java.sql.Timestamp
日期 date 表示日期类型java.sql.Date
日期 datetime 同时可以表示日期和时间类型(精确到毫秒)java.sql.Timestamp
字符串 char(m) String
字符串 varchar(max) String
字符串 (text) String
字符串 varbinary(max) String
  • 查询:

    • 查询某个数据库中所有的表名称

      SELECT Name FROM Master..SysDatabases ORDER BY Name
    • 查询表结构
SELECT (case when a.colorder=1 then d.name else null end) 表名, ( d.name) 表名2,
a.colorder 字段序号,a.name 字段名,
(case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then '√'else '' end) 标识,
(case when (SELECT count(*) FROM sysobjects
WHERE (name in (SELECT name FROM sysindexes
WHERE (id = a.id) AND (indid in
(SELECT indid FROM sysindexkeys
WHERE (id = a.id) AND (colid in
(SELECT colid FROM syscolumns WHERE (id = a.id) AND (name = a.name)))))))
AND (xtype = 'PK'))>0 then '√' else '' end) 主键,b.name 类型,a.length 占用字节数,
COLUMNPROPERTY(a.id,a.name,'PRECISION') as 长度,
isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0) as 小数位数,(case when a.isnullable=1 then '√'else '' end) 允许空,
isnull(e.text,'') 默认值,isnull(g.[value], ' ') AS [说明]
FROM syscolumns a
left join systypes b on a.xtype=b.xusertype
inner join sysobjects d on a.id=d.id and d.xtype='U' and d.name<>'dtproperties'
left join syscomments e on a.cdefault=e.id
left join sys.extended_properties g on a.id=g.major_id AND a.colid=g.minor_id
left join sys.extended_properties f on d.id=f.class and f.minor_id=0
--where b.name is not null
WHERE d.name='YxphoneDeal' --如果只查询指定表,加上此条件 如果去掉则是查询全部的
order by a.id,a.colorder
  • 修改

    • 修改表名

      EXEC sp_rename '原有表名', '新表名';
    • 添加一列

      alter table 表名 add 列名 数据类型 not null--添加列
    • 修改列名称 类型

      exec sp_rename '[表名].[列名]','[新列名]' -- 注意,单引号不可省略。
    • 修改列属性

      alter table table_name alter column column_name column_type
    • 删除列

      alter table table_name drop column column_name
    • 添加主键

      Alter table YXHIS..TBICXXDZ Add Constraint PK_TBICXXDZ Primary Key (CICID,CICKMW) --添加主键约束 PK_TBMZFYHZ 创建新的主键约束名称
    • 删除主键

      Alter table YXHIS..TBICXXDZ Drop CONSTRAINT PK_TBICXXDZ --删除表主键约束(已定义主键名) PK_TBMZFYHZ 表创建中查看主键约束名称

DML(Data Manipulation Language)(数据操纵语言)

  • 添加数据

    insert into 表名(列名1,列名2,...列名n) values(值1,值2,...值n);

除了数字类型,其他类型需要使用引号单引起来(SqlServer严格区分单双引号)

  • 删除数据

    delete from 表名 [where 条件]
  • 修改数据

    update 表名 set 列名1 = 值1, 列名2 = 值2,... [where 条件];

DQL(Data Query Language)(数据查询语言)

  • 基础字段

    select

    字段列表

    from

    表名列表

    where

    条件列表

    group by

    分组字段

    having

    分组之后的条件

    order by

    排序

    • 分页

      • 第一种方式:offset fetch next方式(SQL2012以上的版本才支持:推荐使用 )

        select * from ArtistModels order by ArtistId offset 4 rows fetch next 5 rows only

        --order by ArtistId offset 页数 rows fetch next 条数 rows only --
      • 第二种方式:top not in方式 (适应于数据库2012以下的版本)

        select top 3 * from ArtistModels

        where ArtistId not in (select top 15 ArtistId from ArtistModels)

        ------where Id not in (select top 条数*页数 ArtistId from ArtistModels)
  • 查询运算符

    • 基础运算符

< 、> 、<= 、>= 、= 、<>、 BETWEEN...AND、 IN、 LIKE、 and 或 &&、or 或 ||、not 或 !

  • 复杂运算符
符号 含义
distinct 去掉重复数据
isnull(CBZ3,'') 如果CBZ3为null,结果返回''的值
CASE WHEN ISNULL(CTJYLSH,'')<> '' THEN CTJYLSH ELSE CJYLSH END 如果CTJYLSH不为空,则为CTJYLSH,否则为CJYLSH

isnull(CBZ3,''<>'' cbz3字段不为空

多表查询

略(和MySql一样)

SqlServer数据库约束

约束种类
约束名 约束关键字
主键 primary key
唯一 unique
非空 not null
外键 foreign key
默认值约束 Default
自增约束 AUTO_INCREMENT
检查 CHECK
  • 检查约束

    Check约束通过逻辑表达式来判断数据的有效性,用来限制输入一列或多列的值的范围,在列中更新数据时,所要输入的内容必须满足Check约束的条件,否则将无法正确输入。

SqlServer事物

和MySQL差不太多,都是默认自动提交。

不同点:默认隔离级别:MySql是可重复读,SqlServer是读已提交。

SqlServer基础语法的更多相关文章

  1. SqlServer基础语法(三)

    1.数据库备份的方法: 完整数据库备份GPOSDB 文件大小:23MB 日志备份 GPOSDB日志备份文件大小:211KB --完整备份 Backup DATABASE GPOSDB To disk= ...

  2. SqlServer基础语法(二)

    先看一下腰实现的功能:

  3. ASP.NET实现二维码 ASP.Net上传文件 SQL基础语法 C# 动态创建数据库三(MySQL) Net Core 实现谷歌翻译ApI 免费版 C#发布和调试WebService ajax调用WebService实现数据库操作 C# 实体类转json数据过滤掉字段为null的字段

    ASP.NET实现二维码 using System;using System.Collections.Generic;using System.Drawing;using System.Linq;us ...

  4. sqlserver 常用语法

    sqlserver查找 table, view, column select * from information_schema.tables where table_schema='bk' sele ...

  5. ORACLE| ORACLE基础语法汇总

    创 ORACLE| ORACLE基础语法汇总 2018-07-18 16:47:34 YvesHe 阅读数 9141更多 分类专栏: [数据库]   版权声明:本文为博主原创文章,遵循CC 4.0 B ...

  6. Swift与C#的基础语法比较

    背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...

  7. iOS-----正则表达式的基础语法

    正则表达式简单语法总结 一.什么是正则表达式 从概念上来说,正则表达式也是一门小巧而精炼的语言,它可以用来简化检索特定的字符串,替换特定字符等功能,有许多开发语言工具,都内嵌支持正则表达式.那么一个正 ...

  8. python之最强王者(2)——python基础语法

    背景介绍:由于本人一直做java开发,也是从txt开始写hello,world,使用javac命令编译,一直到使用myeclipse,其中的道理和辛酸都懂(请容许我擦干眼角的泪水),所以对于pytho ...

  9. emmet 系列(1)基础语法

    emmet 系列(1)基础语法 emmet 是一个能显著提升开发html和css开发效率的web开发者工具 emmet基本上目前已知的编辑器都有相应的插件,各个编辑器的emmet插件的下载地址:点我下 ...

随机推荐

  1. 第二十八个知识点:什么是公钥密码学的IND-CCA安全定义?

    第二十八个知识点:什么是公钥密码学的IND-CCA安全定义? 我们将在这篇博客中讨论公钥加密的IND-CCA安全. IND-CCA安全代表选择明文的不可伪造性.这样的安全方案的思想就是给定一个密文,攻 ...

  2. Entropy Search for Information-Efficient Global Optimization

    目录 概 主要内容 的估计 的估计 Hennig P, Schuler C J. Entropy search for information-efficient global optimizatio ...

  3. PIC18 bootloader之CAN bootloader

          了解更多关于bootloader 的C语言实现,请加我Q扣: 1273623966 (验证信息请填 bootloader),欢迎咨询或定制bootloader(在线升级程序). PIC18 ...

  4. 每天学一点——python用户的交互、格式化输出与基础运算符运用

    用户交互 input输入 input接收的数据都是字符串类型 如下图 output输出 还可以相加 换行符 想让他们隔行排列的话就可以这样(如图) 在想各行的开头前面加上\n即可 那若是想将两个输出的 ...

  5. Elasticsearch单机安装Version7.10.1

    1.说明 Elasticsearch单机安装, 基于Elasticsearch的7.10.1版本, 在Linux上安装Elasticsearch单机, 使用安装包elasticsearch-7.10. ...

  6. docker构建.net core运行的镜像

    在docker很火的今天,越来越多的应用现在都在往docker上迁移,.net core怎么能落后? 项目要运行在docker上,我们需要先制作镜像,可以基于centos来制作,当然也可以基于Ubun ...

  7. MongoDB 变更流(Change Stream)介绍

    1. 什么是Change Stream Change Stream 是MongoDB用于实现变更追踪的解决方案,类似于关系数据库的触发器,但原理不完全相同: | | Change Stream | 触 ...

  8. centos6.5-搭建Apache-地址限制和用户访问

    对于企业内部的WEB管理平台,例如日志分析系统(Awstats)为了更好实现访问控制,在通过客户端访问时,提交一些用户密码或对客户IP地址进行授权,避免服务器的安全隐患. 常见的访问控制方式:应用于配 ...

  9. 分享一篇:sql语句中使用子查询,可能会引起查询的性能问题,查询时间会变长

    前段时间,做自动化适配的时候,查找需要的数据的时候,使用到了dblink,跨数据库实例进行访问,整段sql拼接再加上dblink,在plsql查询的时候,性能还不是很长时间,最多2分钟可以查到,前期调 ...

  10. 初识python: 装饰器

    定义: 本质是函数,功能是"装饰"其它函数,即为其他函数添加附加功能原则: 1.不能修改被装饰函数的源代码: 2.不能修改被装饰函数的调用方式实现装饰器知识储备: 1.函数即&qu ...