数据库

删除数据库
drop databsae DBname
创建数据库
create table name ( column_name column_type);

create table if not exists 'table_name' (
    'id'  int unsigned auto_increment,
    'title' varchar(10) not null,
    'time' data,
    primary key ('id')
)engine = InnoDb default charset =utf8;

engine 设置存储引擎 charset 设置编码

删除数据表
drop table table_name
插入数据
insert into table_name ( field1,field2,field3) values (value1,value2,values3)
查询数据
select field1,field2 from table_name [where Clause][LIMIT N][OFFSET M] 

LIMIT 设定返回记录数
OFFSET 指定select语句开始查询的数据的偏移量,默认为0

WHERE
select field1,field2 from table1,table2
where condition1 [AND [OR]] condition2....
UPDATE
update table_name set field1=value1,field2=value2 [ where Clasus]
DELETE
delete from table_name [where Clause]
LIKE
select field1,field2 from table_name where field1 like condition1 [AND [OR ]] field2 ="value2"

like 匹配/模糊匹配
%a 以a结尾的数据
a% 以a开头的数据
%a% 含有a的数据
a 三位且中间的字母是a
a 二位且结尾是a
a
二位且开头是a

UNION
select * from table1 [where conditions] union [ALL | DISTINCT ] select * from table2 [where conditions]

ALL 返回所有的结果集,包含重复数据
DISTINCT 可选,删除结果集中重复的数据,默认已经删除

排序
select field1 from table_name order by field1 
[ASC [DESC]]

ASC 升序 DESC 降序

ORDER BY
select * from table_name order by data ASC

create table "employee_tbl" (
  'id' int(11) not null,
  'name' char(10) not null default ' ',
  'data' datetime not null,
  'singin' tinyint(4) not null default '0' comment '登陆次数',
  primary key('id')
) engine =InnoDB default charset =utf8

select name,count(*) from employee_tbl group by name
将数据表按名称进行分组,并统计每个人有多少条记录
连接的使用JOIN(联合多表查询)

inner join (内连接或等值连接):
left join 左连接:获取左表中所有记录
right join 右连接:


image.png
select a.runoob_id,a.runoob_author,b.runoob_count from runoob_tbl a join tcount_tbl b on a.runoob_author =b.runoob_author;
NULL 值处理

is null :当列的值为null ,返回true
is not null :
<=>:不等于

正则表达式

^:匹配输入字符串的开始位置
$:匹配字符串结束的位置
.:匹配除了"\n"之外的任意字符,要匹配"\n"在内的任何字符"[.\n]"
[abc]:匹配包含的任意一个字符,"[abc]"匹配"plain"中的'a'
[^ abc]:匹配未包含的任意字符,"[^abc]"匹配"plain"中的'p'
p1|p2|p3: 匹配p1或者p2,"(z|f)oof"匹配zood或者food
*:匹配前面的子表达式0次或者多次,zo能匹配z或者zoo,等价{0,}
+:匹配前面的子表达式一次或者多次,等价{1,}
{n}:匹配确定的n次
{n,m}:匹配最少n次最多m次

select name from person where name regexp '^st';
事务

主要用于处理操作量大,复杂度高的数据。
比如:在人员管理系统中,你删除一个人员,既需要删除人员的基本资料,也要删除和该人员相关的信息,如文章,信箱,这些数据库操作语句,就构成一个事务。
1.mysql中只有使用了innodb数据引擎的数据库或表才支持事务。
2.事务处理用来维护数据库的完整性,保证成批的SQL语句要么执行要么全部不执行。
3.事务用来管理insert,update,delete语句
事务满足四个条件:
1.原子性:一个事务中的所有操作要么全部完成,要么全部不完成
2.一致性:事务执行前后,数据库的完整性没有被破坏
3.隔离性:防止多个事务并发执行时由于交叉执行而导致数据的不一致。
4.持久性:事务处理结束后,对数据的修改是永久的。

    启动事务:
start transaction;
update from account set monet=money-100;
commit;  // 关闭事务
ALERT

修改数据表名或者数据字段

create table test(
  i int,
  c char(1)
);
删除i 字段
alert table test drop i;
添加i字段
alert table test add i int;
修改字段类型(modify)
alert table test modify c char(10);
修改字段类型(change)后面跟修改的字段名,新的字段名,类型
alert table test change i j bigint;
修改表名
alter table test rename to test_name
索引

索引分为单列索引和组合索引
单列索引:一个索引只包含一个单列,一个表可以有多个单列索引
组合索引:一个索引包含多个列
索引也是一张表,该表保存了主键和索引的字段,并指向实体表的记录。
缺点:虽然索引能够大大提高查询速度,同时却会降低更新表的速度,如对表进行insert update delete,因为更新表时,mysql不仅要保存数据,还要保存一下索引文件。建立索引会占用磁盘空间的索引文件。
在关系数据库中,对于大量的数据,查找时想要非常快,就需要索引。
索引是关系数据库中对某一列或多列的值进行预排序的数据结构,通过索引,可以让数据库系统不必扫描整个表,而是直接定位到符合条件的记录,这样就大大加快查询速度。

例如,对于students表:
id class_id name gender score
1 1 小明 M 90
2 1 小红 F 95
3 1 小军 M 88
如果经常根据score进行排序,可以对score列创建索引

alert table student add index idx_score (score)
alert table student add index idx_score_name (score,name)

索引的效率取决于索引列的值是否扩散,即该列的值如果越互不相同,那么索引效率越高。反过来,如果记录的列存在大量相同的值,例如gender列,大约一半的记录值是M,另一半是F,因此,对该列创建索引就没有意义。
可以对一张表创建多个索引,索引的优点是提高查询效率,缺点是在插入、更新、删除记录时,需要同时修改索引,因此 索引越多,插入更新删除记录的速度就越慢。
对于主键,关系型数据库会自动对其创建主键索引。使用主键索引的效率最高,因为主键会保护绝对的唯一。

一、普通索引

1.创建索引

create index indexName on mytable(username(length))

2.添加索引

alert table tablename add index indexName(columnName)

3.创建表时直接指定索引

create table mytable(
  id int not null,
  username varchar(16) not null,
  index[indexName] (username(length))
)

4.删除索引

alert table tabename drop index [indexName] on mytable
二、唯一索引

不同:索引列的值必须唯一,允许有空值,如果是组合索引,则列值的组合必须唯一
在设计关系数据表的时候,看上去唯一的列,如身份证,邮箱地址,因为他们具有业务含义,一次不适合作为主键。
因此可以给该列添加唯一索引,

1.创建索引

alter table syudent add unique index indexName on mytable(username(length))

2.添加索引

alert table mytable add unique [indexName] (username(length))

3.创建表的时候指定

create table mytable(
  id int not null,
  username varchar(16) not null,
  unique [indexName] (username(length))
);

4.如果有相应的索引可用,数据库系统就会自动使用索引来提高查询效率,如果没有索引,查询也能正常使用,只是速度会变慢,

主键

定义:

主键:唯一标识一条记录,不能重复,不能为空,不具有任何业务相关的字段。
外键:表的外键是另一表的主键,外键可以重复,可以为空
索引:该字段没有重复值,但可以有一个空置

作用:

主键:用来保证数据的完整性
外键:用来和其他表建立联系
索引:提高查询排序的速度

三种基本关系
1.一对一

一个人对应一个妻子或者丈夫

2.一对多

例如:一个人有多辆车
“多”方添加一个外键字段

3.多对多

例如:一个学生可以选修多门客户才能,没门课程可供多个学生选择
创建一个关系表,采用联合主键的方式(学生主键和课程主键)建表。

第一范式

有主键、不能为空、不能重复。字段不可再分。
电话字段:家用电话和公司电话

第二范式

每列都和主键相关,不可把多种数据存在同一张表中

数据库的五大约束

primary
unique
default
not null
foreign key

数据库引擎InnoDB
数据库三大属性:实体 属性 关系
视图:视图是一个虚拟表

1000w数据使用limit offset分页时,越往后翻越慢,如何解决?
1.先查主键在分页
select * from tb where id in (select id from tb where id limit 10 offset 30)

数据库读写分离:二台服务器。主:用于删除、修改、更新。从:用于查。

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

推荐阅读更多精彩内容

  • ORA-00001: 违反唯一约束条件 (.) 错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。 O...
    我想起个好名字阅读 5,268评论 0 9
  • --- layout: post title: "如果有人问你关系型数据库的原理,叫他看这篇文章(转)" date...
    蓝坠星阅读 782评论 0 3
  • 转 # https://www.cnblogs.com/easypass/archive/2010/12/ 08/...
    吕品㗊阅读 9,714评论 0 44
  • 今天看到一位朋友写的mysql笔记总结,觉得写的很详细很用心,这里转载一下,供大家参考下,也希望大家能关注他原文地...
    信仰与初衷阅读 4,727评论 0 30
  • 索引 数据库中的查询操作非常普遍,索引就是提升查找速度的一种手段 索引的类型 从数据结构角度分 1.B+索引:传统...
    一凡呀阅读 2,886评论 0 8