• 3.sql基础


    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;

  • 相关阅读:
    NOJ-1581 筷子 (线性DP)
    UVA-242 Stamps and Envelope Size (DP)
    POJ 1860 (SPFA判断正环)
    POJ 3268 最短路水题
    STL----priority_queue
    STL----unique
    POJ 2031(最小生成树Kruskal算法+几何判断)
    POJ 3468(线段树区间修改+区间求和)
    学习线段树
    POJ 1251(最小生成树裸题)
  • 原文地址:https://www.cnblogs.com/joesphos/p/5180100.html
Copyright © 2020-2023  润新知