sql语句是和dbms交谈专用的语句,不同dbms都认sql语法

sql语句中字符串用单引号

sql语句是大小写不敏感的,不敏感指的是sql关键字,字符串值还是大小写敏感的

创建表、删除表不仅可以手工完成,还可以执行sql语句完成,在自动化部署、数据导入中用的很多,create table t_person(id int not null, name nvarchar(50), age int null)、drop table t_person

简单的insert语句。 insert into t_person(id,name,age) values(1,'Jin',20)

(*) sql 主要分ddl数据定义语言和dml数据操作语言两类,create table、drop table,alter table等属于ddl,select、insert、delete、update等属于DML

sql server中两种常用的主键数据类型:int or bigint + 标识列(又称自动增长字段);uniqueidentifier(又称Guid、UUID)

用标识列实现字段自增可以避免并发的问题,不要开发人员控制自增。用标识列的字段在insert的时候不用指定主键的值。将字段的是标识列设为是,一个表只能有一个标识列。

Guid算法是一种可以产生唯一标识的高效算法,它使用网卡mac、地址、纳秒级时间、芯片id码等算出来的,这样保证每次生成的guid永远不会重复,无论是同一个计算机还是不同计算机。在公元3400年以前产生的guid与任何其他产生过的guid都不相同。sql server中生成guid的函数newid(),.net中生成guid的方法:Guid.NewGuid(),返回的是Guid类型。

int自增字段的优点:占用空间小、无需开发人员干预、易读;缺点:效率低,数据导入导出的时候很痛苦

Guid的优点:效率高、数据导入导出方便,缺点:占用空间大,不易读。

业界主流倾向使用Guid

数据插入insert

insert语句可以省略表名后的列名,但是不推荐

如果插入的行中有些字段的值不确定,那么insert的时候不指定那些列即可。

可以给字段默认值,如果Guid类型主键可以默认值设为newid()就会生产,很少这么做!

主键: insert into person(name,age) values('kk',29);

数据更新update

更新一个列update person set age=20;

更新多个列update perosn set name='jj',age=40

更新一部分数据update person set age=20 where name='kk'; sql中等于判断用单个=,而不是==

where中还可以使用复杂的逻辑判断update person set age=40 where name='jj' or age>30,or相当于c#中的||或者

where中可以使用的其他逻辑运算符:or,and,not,<,>,>=,<=,!=(or <>)等

数据删除delete

删除表中全部数据:delete from table1

delete只是删除数据,不删除表,drop table是删除表

delete也可以带where条件子句来删除部分数据:delete from table where name='tt'

数据检索select

简单的数据检索:select * from employee

只检索需要的列:select fid,fname from employee

列别名:select fname as 姓名 from employee

使用where检索符合条件的数据:select fname from employee where fsalary>1000

可以检索不与任何表关联的数据:select 1+2,select newid(),select getdate()

数据汇总

sql聚合函数:max最大值,min最小值,avg平均值,sum和,count数量

大于25岁的员工的最高工资:select max(salary) from employee where age>25

最低工资和最高工资:select min(salary),max(salary) from employee

数据排序order by

order by子句位于select语句的末尾,它允许指定按照一个列或者多个列进行排序,还可以指定排序方式是升序asc还是降序desc

按照年龄升序排序所有员工信息的列表:select * from employee order by age asc

按照年龄从大到小排序,如果年龄相同则按工资从大到小排序:select * from employee order by age desc, salary desc

order by子句要放到where子句之后:select * from employee where age>23 order by age desc, salary desc

通配符过滤

通配符过滤使用like

单字符匹配的通配符为半角下划线_,它匹配单个出现的字符。以任意字符开头,剩余部分为erry:select * from employee where name like '_erry'

多字符匹配的通配符为半角百分比%,它匹配任意次数出现的任意字符。k%匹配以k开头、任意长度的字符串,检索姓名中包含字母n的员工信息,select * from employee where name like '%n%'

空值处理

数据库中,一个列如果没有指定值,那么值就为null,这个null和c#中的null,数据库中null标识不知道,而不是表示没有,因此select null+1结果是null,因为不知道加1的结果还是不知道

select * from employee where name = null;select * from employee where name !=null;都没有任何返回结果,因为数据库也不知道

sql 中使用is null,is not null 来进行空值判断:select * from employee where name is null;select * from employee where name is not null;

多值匹配

select age,id,name from employee where age in (19,23,35)

范围值:select * from employee where age>=23 and age <=27; select * from employee where age between 23 and 27;

最新文章

  1. SQLite的基本使用
  2. 编写高质量的 Java 代码
  3. DWR实现扫一扫登录功能
  4. H5项目常见问题
  5. C语言字符串函数例子程序大全 – string相关
  6. php过滤ascii控制字符
  7. ACM: Gym 100935F A Poet Computer - 字典树
  8. js判断用户的浏览器设备是移动端还是pc端
  9. DedeCMS V5.7 Dialog目录下配置文件XSS漏洞
  10. HDU 4006 The kth great number(multiset(或者)优先队列)
  11. unity3d中获得物体的尺寸(size)
  12. hdu4655Cut Pieces
  13. 3、Hibernate三态间的转换
  14. Python3 XML解析
  15. mysql 错误 ERROR 1030 Got error 28 from
  16. vue day4 table
  17. Swift中关于集合计算的几种函数记录(intersect、symmetricDifference、union、subtract)
  18. mac 下 通过 brew 安装 MariaDB
  19. 基于ajax 验证表单是否被占用----------------附:10.25日总结
  20. input file accept类型

热门文章

  1. ModelBinder 请求容错性
  2. 基于supervisor秒级Laravel定时任务
  3. cuda npp库旋转图片
  4. 746. Min Cost Climbing Stairs(动态规划)
  5. Spring整合Junit框架进行单元测试Demo
  6. MG loves string
  7. 【ACM】nyoj_132_最长回文子串_201308151713
  8. 【ACM】NYOJ_69_数的长度_20130725
  9. [IOS/翻译]Core Services Layer
  10. [Java][Spring][scurity]同步session控制,防止一个用户多次登录