SQL基础笔记(一)

学习笔记(一)

参考内容:廖雪峰的博客mysql的教程

数据类型

对于一个关系型数据库表,除了每一列的名称外,还需要定义每一列的数据类型。数据库支持的标准数据类型包括数据、字符串、时间等“

名称:

INT BIGINT    REAL    DOUBLE    DECIMAL(M,N)    CHAR(N)    VARCHAR(N)    BOOLEAN        DATE        TIME          DATETIME

SQL

SQL是结构化查询语言Structured Query Language的缩写,用来访问和操作数据库系统。不同的数据库,都支持SQL(已经被ANSI组织定位标准)

实际情况是,如果我们只使用标准SQL的核心功能,那么所有数据通常都可以执行,不常用的SQL功能,不同的数据库支持的程度都不一样。而各个数据支持的各自拓展的功能,通常我们把他们称之为“方言”

SQL语言定义了以下几种操作数据库的能力

DDL:Data Definition Language

DDL运行用户定义数据,也就是创建表、删除表、修改表结构这些操作。通常,DDL由数据库管理员执行。

DML: Data Manipulation Language

DML为用户提供添加、删除、更新数据的能力,这些事应用程序对数据库的日常操作

DQL:Data Query Language

DQL允许用户查询数据,这也是最频繁的数据日常操作

语法特点:SQL语言的关键字是不区分大小写的!但是,列名和表名Linux和Windows上是区分的

MySQL

MySQL是目前应用最广泛的关系数据库。与其他的数据库不同的是,MySQL本身是SQL的一个接口,它的内部还包含了多种数据引擎,包括:

InnoDB:支持事务的数据库引擎

MyISAM:MySQL早期继承的默认数据库引擎,不支持事务

事务:数据库事务(Database Transaction)是指作为单个逻辑工作单元执行的一系列操作,要么完全的执行,要么完全的不执行。比如网购的一些列操作(读取用户信息,保存用户付款信息,生成订单保存,更新用户购物车数据)

事务必须满足的四个原则:A 原子性、C 一致性、I 隔离性、D 持久性

MySQL接口和数据库引擎的关系就好比浏览器和浏览器引擎的关系。对用户而言,切换浏览器不影响浏览器界面,切换MySQL引擎也不影响自己写的应用程序使用MySQL接口。(默认选择InnoDB)

关系模型

关系型数据是建立在关系模型上的,关系模型的本质就是若干个存储数据的二维表。关系型数据中,关系是通过主键和外键来维护的。

主键:

唯一确定一条记录的字段(主键最好选取与业务毫无关系的字段)

联合主键:

有两个或者更多的字段设置为主键

外键:

通过某个字段,可以把数据与另外一张表关联起来,这种列成为外键

(外键约束的语法:FOREIGN KEY(class_id)指定class_id作为外键 \ REFERENCES class (id)指定这个外键关联到class表的id列。通过外键约束,可以保证关系型数据库无法插入无效的数据,如果关系表没有,就无法插入数据。但这会降低性能,通常不会设置)

索引:

索引是关系型数据库中对某一列或者多个列的值进行预排序的数据结构。通过使用索引,可以让数据库系统不必扫描整个表,而是直接定位到符合条件的记录,加快查询速度。

(例如如果要经常根据 score 列进行查询,ADD INDEX idx_score (score),索引的效率取决于索引列值是否散列,即存在相同值的数量)

优点:提高查询效率                缺点:增删改查时需要修改索引,维护很耗费资源

(唯一索引:ADD UNIQUE INDEX uni_name (name)                唯一约束:ADD CONSTRAINT uni_name UNIQUE (name))

查询

1、字符串查询注意用单引号

2、NOT条件,select * from students where not class_id = 2  (不常用)

3、

排序查询 :

1、默认的查询结果是按照id来进行排序的,如果想要按照其他条件排序可以加上 ORDER BY column 子句,倒序加上DESC;

2、如果score列有相同的数据,需要进一步进行排序,可以继续添加列名。比如使用ORDER BY score DESC ,gender表示先按 score排序,如果有分数相同,再按照gender列排序。

3、ORDER BY 子句要放到WHERE子句后面

分页查询 :

1、limit <M> OFFSET <N>  (从 N 开始最多取 M 条)

2、分页查询关键在于,要确定每页要显示的结果数量pageSize,然后根据当前页的索引pageIndex

limit  :  设定为      pageSize

offset  :  计算公式    pageSize * (pageIndex - 1)

3、limit 15 相当于 limit 15 offset 0。在MySQL中,(LIMIT M OFFSET N) 还可以简写成 (LIMIT N M)

聚合查询 :

对于统计总数、平均数这类计算,SQL提供了专门的聚合函数,使用聚合函数进行查询,就是聚合查询。

1、count(*)用来统计所有列的行数

2、 SUM    计算某一列的合计值,该列必须为数值类型              eg:SELECT AVG(score) FROM students WHERE gerder = "M"

AVG    计算某一列的平均值,该列必须为数值类型

MAX    计算某一列的最大值

MIN    计算某一列的最小值(如果是字符类型,MAX()和MIN()会返回排序最后和排序最前的字符)

注意:如果聚合查询的WHERE 条件没有匹配到任何行 count()会返回 0 ,而MAX()、MIN()会返回NULL

分组查询:

1、select count(*) num from students GROUP BY class_id 。

(GROUP BY子句指定按class_id分组,执行该语句时会把class_id相同的列先分组,再分别结算,会得到多行结果)

(在任意一个分组中,只有分组的列相同,其他条件都不同,所以只能放入分组的列)

2、SELECT class_id, gender, COUNT(*) num FROM students GROUP BY class_id, gender;

(也可以使用多个列进行分组,单记录会有多条)、

修改数据:

INSERT

insert into <table> (字段1,字段2) VALUES(值1,值2),(值1,值2)(还可以一次添加多个记录)

UPDATE

update <table> set 字段1=值1,字段2=值2,... WHERE ...;(如果不加where语句,所有的记录都会被更新)

DELETE

delete from <table> WHERE ...;

重新定义自增的序列

alter table t_card_info_copy AUTO_INCREMENT=500

truncate:会清空表中所有的数据,速度快,不可回滚;实质是删除整张表包括数据再重新创建表;

delete:逐行删除数据,每步删除都是有日志记录的,可以回滚数据;实质是逐行删除表中的数据;

MySQL

摘要:按照完MySQL以后,除了MySQL Server 即真正的MySQL服务器外,还需要MySQL Client命令行客户端来登陆执行SQL语句命令

链接:mysql -u root -p

退出:exit(知识断开了客户端和服务器的链接,MySQL服务器依然在继续运行)

MySQL中输入SQL语句通过TCP链接发送到MySQL Server 。端口号是3309,即如果发送到本机MySQL Server,地址就是127.0.0.1:3309

也可以只安装MySQL Client ,然后远程连接到MySQL Server。假设远程MySQL Server的IP地址是10.0.1.99,那么就使用-h指定IP或者域名

mysql -h 10.0.1099 -u root -p

1、数据库

A、列出所有的数据库    SHOW DATABASES(information_schema,mysql,performance_schema,sys)是系统库

B、新建  CREATE DATABASE test

C、删除 DROP DATABASE test

D、操作指定数据库  USE test

2、表

A、列出表  SHOW TABLES

B、表结构  DESC <表名>

C、查看创建 SHOW CAREATE TABLE stadents            CREATE TABLE student (

id int,

name varchar(20)

);

D、删除表  DROP TABLE students

3、列

A、新增列  ALTER TABLE students ADD COLUMN birth VARCHAR(10) NOT NULL;

B、重命名  ALTER TABLE students CHANCE COLUMN birth birthdat VARCHEAR(20) NOT NULL;

C、删除列  ALTER TABLE students DROP COLUMN birthday;

使用SQL

创建快照CREATE TABLE students_of_class1 SELECT * FROM students WHERE class_id =1;

事务

Read Uncommitted(读未提交)是隔离级别最低的一种事务级别。但是在这种隔离级别下,一个事务会读取到另一个事务更新后未提交的数据,如果另一个事务回滚,那么当前事务督导的数据就是脏数据,这就是脏读

Read Committed(读已提交)隔离级别下,一个事务可能会遇到不可重复读的问题。在一个事务内,多次读取同一数据,在这个事务还没有结束时,另一个事务恰好修改了这个数据,那么在第一个十五中,两次读取的数据就可能不一致

Repeatbale Read(可重复读)隔离级别下,一个事务可能会遇到幻读的问题。幻读是指,在一个事务中,第一次查询某条记录,发现没有,但是,当视图更新这条不存在的记录的时,竟然能成功,并且,再次读取同一条记录的时候,它就神奇第出现了

Serializable(串行化)是最严格的隔离级别,在这个隔离级别下,所有的事务按照次序依次执行。但是效率会大大的降低,在MySQL中,如果使用InnoDB,默认的隔离级别是Repeatable Read

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

推荐阅读更多精彩内容