Mysql数据库概述
阅读目录
引擎介绍
mysql中的存储引擎(https://www.cnblogs.com/Eva-J/articles/9682063.html)
表介绍
表就相当于文件,表中的一条记录就相当于文件的一行内容,不同的是,表中的一条记录有对应的标题,称为表的字段
还记得我们之前写过的‘员工信息表作业’么?存储这员工信息的文件是这样的:
- id,name,age,sex,phone,job
- 1,Alex,83,female,13651054608,IT
- 2,Egon,26,male,13304320533,Tearcher
- 3,nezha,25,male,13332353222,IT
- 4,boss_jin,40,male,13332353333,IT
如果把上面这个文件改成一张表,应该是下面这个样子
id | name | age | sex | phone | job |
1 | Alex | 83 | female | 13651054608 | IT |
2 | Egon | 26 | male | 13304320533 | Teacher |
3 | nezha | 25 | male | 13332353222 | IT |
4 | boss_jin | 40 | male | 13332353333 | IT |
- id,name,age,sex,phone,job称为字段,其余的,一行内容称为一条记录
创建表
- #语法:
- create table 表名(
- 字段名1 类型[(宽度) 约束条件],
- 字段名2 类型[(宽度) 约束条件],
- 字段名3 类型[(宽度) 约束条件]
- );
- #注意:
- 1. 在同一张表中,字段名是不能相同
- 2. 宽度和约束条件可选
- 3. 字段名和类型是必须的
- mysql> create database staff;
- Query OK, 1 row affected (0.00 sec)
- mysql> use staff;
- Database changed
- mysql> create table staff_info (id int,name varchar(50),age int(3),sex enum('male','female'),phone bigint(11),job varchar(11));
- Query OK, 0 rows affected (0.02 sec)
- mysql> show tables;
- +-----------------+
- | Tables_in_staff |
- +-----------------+
- | staff_info |
- +-----------------+
- 1 row in set (0.00 sec)
- mysql> desc staff_info;
- +-------+-----------------------+------+-----+---------+-------+
- | Field | Type | Null | Key | Default | Extra |
- +-------+-----------------------+------+-----+---------+-------+
- | id | int(11) | YES | | NULL | |
- | name | varchar(50) | YES | | NULL | |
- | age | int(3) | YES | | NULL | |
- | sex | enum('male','female') | YES | | NULL | |
- | phone | bigint(11) | YES | | NULL | |
- | job | varchar(11) | YES | | NULL | |
- +-------+-----------------------+------+-----+---------+-------+
- 6 rows in set (0.00 sec)
- mysql> select id,name,sex from staff_info;
- Empty set (0.00 sec)
- mysql> select * from staff_info;
- Empty set (0.00 sec)
建表
- mysql> insert into staff_info (id,name,age,sex,phone,job) values (1,'Alex',83,'female',13651054608,'IT');
- Query OK, 1 row affected (0.00 sec)
- mysql> insert into staff_info values (2,'Egon',26,'male',13304320533,'Teacher');
- Query OK, 1 row affected (0.00 sec)
- mysql> insert into staff_info values (3,'nezha',25,'male',13332353222,'IT'),(4,'boss_jin',40,'male',13332353333,'IT');
- Query OK, 2 rows affected (0.00 sec)
- Records: 2 Duplicates: 0 Warnings: 0
- mysql> select * from staff_info;
- +------+----------+------+--------+-------------+---------+
- | id | name | age | sex | phone | job |
- +------+----------+------+--------+-------------+---------+
- | 1 | Alex | 83 | female | 13651054608 | IT |
- | 2 | Egon | 26 | male | 13304320533 | Teacher |
- | 3 | nezha | 25 | male | 13332353222 | IT |
- | 4 | boss_jin | 40 | male | 13332353333 | IT |
- +------+----------+------+--------+-------------+---------+
- 4 rows in set (0.00 sec)
插入数据
查看表结构
查看表结构有两种方式:
describe [tablename];这种方法和desc [tablename];效果相同;可以查看当前的表结构
虽然desc命令可以查看表的定义,但是其输出的信息还不够全面,为了得到更全面的表定义信息,有时候就需要查看创建表的SQL语句,使用show create table语法。除了可以看到表定义之外,还可以看到engine(存储引擎)和charset(字符集)等信息。(\G选项的含义是是的记录能够竖向排列,以便更好的显示内容较长的记录。)
- mysql> describe staff_info;
- +-------+-----------------------+------+-----+---------+-------+
- | Field | Type | Null | Key | Default | Extra |
- +-------+-----------------------+------+-----+---------+-------+
- | id | int(11) | YES | | NULL | |
- | name | varchar(50) | YES | | NULL | |
- | age | int(3) | YES | | NULL | |
- | sex | enum('male','female') | YES | | NULL | |
- | phone | bigint(11) | YES | | NULL | |
- | job | varchar(11) | YES | | NULL | |
- +-------+-----------------------+------+-----+---------+-------+
- 6 rows in set (0.00 sec)
- mysql> desc staff_info;
- +-------+-----------------------+------+-----+---------+-------+
- | Field | Type | Null | Key | Default | Extra |
- +-------+-----------------------+------+-----+---------+-------+
- | id | int(11) | YES | | NULL | |
- | name | varchar(50) | YES | | NULL | |
- | age | int(3) | YES | | NULL | |
- | sex | enum('male','female') | YES | | NULL | |
- | phone | bigint(11) | YES | | NULL | |
- | job | varchar(11) | YES | | NULL | |
- +-------+-----------------------+------+-----+---------+-------+
- 6 rows in set (0.00 sec)
- mysql> show create table staff_info\G;
- *************************** 1. row ***************************
- Table: staff_info
- Create Table: CREATE TABLE `staff_info` (
- `id` int(11) DEFAULT NULL,
- `name` varchar(50) DEFAULT NULL,
- `age` int(3) DEFAULT NULL,
- `sex` enum('male','female') DEFAULT NULL,
- `phone` bigint(11) DEFAULT NULL,
- `job` varchar(11) DEFAULT NULL
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8
- 1 row in set (0.01 sec)
- ERROR:
- No query specified
desc和show create table
mysql中的数据类型
mysql支持的数据类型(https://www.cnblogs.com/Eva-J/articles/9683316.html)
表的完整性约束
mysql表的完整性约束(https://www.cnblogs.com/Eva-J/articles/9687915.html)
修改表结构
- 语法:
- 1. 修改表名
- ALTER TABLE 表名
- RENAME 新表名;
- 2. 增加字段
- ALTER TABLE 表名
- ADD 字段名 数据类型 [完整性约束条件…],
- ADD 字段名 数据类型 [完整性约束条件…];
- 3. 删除字段
- ALTER TABLE 表名
- DROP 字段名;
- 4. 修改字段
- ALTER TABLE 表名
- MODIFY 字段名 数据类型 [完整性约束条件…];
- ALTER TABLE 表名
- CHANGE 旧字段名 新字段名 旧数据类型 [完整性约束条件…];
- ALTER TABLE 表名
- CHANGE 旧字段名 新字段名 新数据类型 [完整性约束条件…];
- 5.修改字段排列顺序/在增加的时候指定字段位置
- ALTER TABLE 表名
- ADD 字段名 数据类型 [完整性约束条件…] FIRST;
- ALTER TABLE 表名
- ADD 字段名 数据类型 [完整性约束条件…] AFTER 字段名;
- ALTER TABLE 表名
- CHANGE 字段名 旧字段名 新字段名 新数据类型 [完整性约束条件…] FIRST;
- ALTER TABLE 表名
- MODIFY 字段名 数据类型 [完整性约束条件…] AFTER 字段名;
- mysql> desc staff_info;
- +-------+-----------------------+------+-----+---------+-------+
- | Field | Type | Null | Key | Default | Extra |
- +-------+-----------------------+------+-----+---------+-------+
- | id | int(11) | YES | | NULL | |
- | name | varchar(50) | YES | | NULL | |
- | age | int(3) | YES | | NULL | |
- | sex | enum('male','female') | YES | | NULL | |
- | phone | bigint(11) | YES | | NULL | |
- | job | varchar(11) | YES | | NULL | |
- +-------+-----------------------+------+-----+---------+-------+
- 6 rows in set (0.00 sec)
- # 表重命名
- mysql> alter table staff_info rename staff;
- Query OK, 0 rows affected (0.00 sec)
- mysql> desc staff;
- +-------+-----------------------+------+-----+---------+-------+
- | Field | Type | Null | Key | Default | Extra |
- +-------+-----------------------+------+-----+---------+-------+
- | id | int(11) | YES | | NULL | |
- | name | varchar(50) | YES | | NULL | |
- | age | int(3) | YES | | NULL | |
- | sex | enum('male','female') | YES | | NULL | |
- | phone | bigint(11) | YES | | NULL | |
- | job | varchar(11) | YES | | NULL | |
- +-------+-----------------------+------+-----+---------+-------+
- 6 rows in set (0.00 sec)
- # 删除sex列
- mysql> alter table staff drop sex;
- Query OK, 0 rows affected (0.02 sec)
- Records: 0 Duplicates: 0 Warnings: 0
- mysql> desc staff;
- +-------+-------------+------+-----+---------+-------+
- | Field | Type | Null | Key | Default | Extra |
- +-------+-------------+------+-----+---------+-------+
- | id | int(11) | YES | | NULL | |
- | name | varchar(50) | YES | | NULL | |
- | age | int(3) | YES | | NULL | |
- | phone | bigint(11) | YES | | NULL | |
- | job | varchar(11) | YES | | NULL | |
- +-------+-------------+------+-----+---------+-------+
- 5 rows in set (0.01 sec)
- # 添加列
- mysql> alter table staff add sex enum('male','female');
- Query OK, 0 rows affected (0.03 sec)
- Records: 0 Duplicates: 0 Warnings: 0
- # 修改id的宽度
- mysql> alter table staff modify id int(4);
- Query OK, 0 rows affected (0.02 sec)
- Records: 0 Duplicates: 0 Warnings: 0
- mysql> desc staff;
- +-------+-----------------------+------+-----+---------+-------+
- | Field | Type | Null | Key | Default | Extra |
- +-------+-----------------------+------+-----+---------+-------+
- | id | int(4) | YES | | NULL | |
- | name | varchar(50) | YES | | NULL | |
- | age | int(3) | YES | | NULL | |
- | phone | bigint(11) | YES | | NULL | |
- | job | varchar(11) | YES | | NULL | |
- | sex | enum('male','female') | YES | | NULL | |
- +-------+-----------------------+------+-----+---------+-------+
- 6 rows in set (0.01 sec)
- # 修改name列的字段名
- mysql> alter table staff change name sname varchar(20);
- Query OK, 4 rows affected (0.03 sec)
- Records: 4 Duplicates: 0 Warnings: 0
- mysql> desc staff;
- +-------+-----------------------+------+-----+---------+-------+
- | Field | Type | Null | Key | Default | Extra |
- +-------+-----------------------+------+-----+---------+-------+
- | id | int(4) | YES | | NULL | |
- | sname | varchar(20) | YES | | NULL | |
- | age | int(3) | YES | | NULL | |
- | phone | bigint(11) | YES | | NULL | |
- | job | varchar(11) | YES | | NULL | |
- | sex | enum('male','female') | YES | | NULL | |
- +-------+-----------------------+------+-----+---------+-------+
- 6 rows in set (0.00 sec)
- # 修改sex列的位置
- mysql> alter table staff modify sex enum('male','female') after sname;
- Query OK, 0 rows affected (0.02 sec)
- Records: 0 Duplicates: 0 Warnings: 0
- mysql> desc staff;
- +-------+-----------------------+------+-----+---------+-------+
- | Field | Type | Null | Key | Default | Extra |
- +-------+-----------------------+------+-----+---------+-------+
- | id | int(4) | YES | | NULL | |
- | sname | varchar(20) | YES | | NULL | |
- | sex | enum('male','female') | YES | | NULL | |
- | age | int(3) | YES | | NULL | |
- | phone | bigint(11) | YES | | NULL | |
- | job | varchar(11) | YES | | NULL | |
- +-------+-----------------------+------+-----+---------+-------+
- 6 rows in set (0.00 sec)
- # 创建自增id主键
- mysql> alter table staff modify id int(4) primary key auto_increment;
- Query OK, 4 rows affected (0.02 sec)
- Records: 4 Duplicates: 0 Warnings: 0
- mysql> desc staff;
- +-------+-----------------------+------+-----+---------+----------------+
- | Field | Type | Null | Key | Default | Extra |
- +-------+-----------------------+------+-----+---------+----------------+
- | id | int(4) | NO | PRI | NULL | auto_increment |
- | sname | varchar(20) | YES | | NULL | |
- | sex | enum('male','female') | YES | | NULL | |
- | age | int(3) | YES | | NULL | |
- | phone | bigint(11) | YES | | NULL | |
- | job | varchar(11) | YES | | NULL | |
- +-------+-----------------------+------+-----+---------+----------------+
- 6 rows in set (0.00 sec)
- # 删除主键,可以看到删除一个自增主键会报错
- mysql> alter table staff drop primary key;
- ERROR 1075 (42000): Incorrect table definition; there can be only one auto column and it must be defined as a key
- # 需要先去掉主键的自增约束,然后再删除主键约束
- mysql> alter table staff modify id int(11);
- Query OK, 4 rows affected (0.02 sec)
- Records: 4 Duplicates: 0 Warnings: 0
- mysql> desc staff;
- +-------+-----------------------+------+-----+---------+-------+
- | Field | Type | Null | Key | Default | Extra |
- +-------+-----------------------+------+-----+---------+-------+
- | id | int(11) | NO | PRI | 0 | |
- | sname | varchar(20) | YES | | NULL | |
- | sex | enum('male','female') | YES | | NULL | |
- | age | int(3) | YES | | NULL | |
- | phone | bigint(11) | YES | | NULL | |
- | job | varchar(11) | YES | | NULL | |
- +-------+-----------------------+------+-----+---------+-------+
- 6 rows in set (0.01 sec)
- mysql> alter table staff drop primary key;
- Query OK, 4 rows affected (0.06 sec)
- Records: 4 Duplicates: 0 Warnings: 0
- # 添加联合主键
- mysql> alter table staff add primary key (sname,age);
- Query OK, 0 rows affected (0.02 sec)
- Records: 0 Duplicates: 0 Warnings: 0
- # 删除主键
- mysql> alter table staff drop primary key;
- Query OK, 4 rows affected (0.02 sec)
- Records: 4 Duplicates: 0 Warnings: 0
- # 创建主键id
- mysql> alter table staff add primary key (id);
- Query OK, 0 rows affected (0.02 sec)
- Records: 0 Duplicates: 0 Warnings: 0
- mysql> desc staff;
- +-------+-----------------------+------+-----+---------+-------+
- | Field | Type | Null | Key | Default | Extra |
- +-------+-----------------------+------+-----+---------+-------+
- | id | int(11) | NO | PRI | 0 | |
- | sname | varchar(20) | NO | | | |
- | sex | enum('male','female') | YES | | NULL | |
- | age | int(3) | NO | | 0 | |
- | phone | bigint(11) | YES | | NULL | |
- | job | varchar(11) | YES | | NULL | |
- +-------+-----------------------+------+-----+---------+-------+
- 6 rows in set (0.00 sec)
- # 为主键添加自增属性
- mysql> alter table staff modify id int(4) auto_increment;
- Query OK, 4 rows affected (0.02 sec)
- Records: 4 Duplicates: 0 Warnings: 0
- mysql> desc staff;
- +-------+-----------------------+------+-----+---------+----------------+
- | Field | Type | Null | Key | Default | Extra |
- +-------+-----------------------+------+-----+---------+----------------+
- | id | int(4) | NO | PRI | NULL | auto_increment |
- | sname | varchar(20) | NO | | | |
- | sex | enum('male','female') | YES | | NULL | |
- | age | int(3) | NO | | 0 | |
- | phone | bigint(11) | YES | | NULL | |
- | job | varchar(11) | YES | | NULL | |
- +-------+-----------------------+------+-----+---------+----------------+
- 6 rows in set (0.00 sec)
示例
删除表
- DROP TABLE 表名;
多表结构的创建与分析
如何找出两张表之间的关系
- 分析步骤:
- #1、先站在左表的角度去找
- 是否左表的多条记录可以对应右表的一条记录,如果是,则证明左表的一个字段foreign key 右表一个字段(通常是id)
- #2、再站在右表的角度去找
- 是否右表的多条记录可以对应左表的一条记录,如果是,则证明右表的一个字段foreign key 左表一个字段(通常是id)
- #3、总结:
- #多对一:
- 如果只有步骤1成立,则是左表多对一右表
- 如果只有步骤2成立,则是右表多对一左表
- #多对多
- 如果步骤1和2同时成立,则证明这两张表时一个双向的多对一,即多对多,需要定义一个这两张表的关系表来专门存放二者的关系
- #一对一:
- 如果1和2都不成立,而是左表的一条记录唯一对应右表的一条记录,反之亦然。这种情况很简单,就是在左表foreign key右表的基础上,将左表的外键字段设置成unique即可
建立表之间的关系
- #一对多或称为多对一
- 三张表:出版社,作者信息,书
- 一对多(或多对一):一个出版社可以出版多本书
- 关联方式:foreign key
- =====================多对一=====================
- create table press(
- id int primary key auto_increment,
- name varchar(20)
- );
- create table book(
- id int primary key auto_increment,
- name varchar(20),
- press_id int not null,
- foreign key(press_id) references press(id)
- on delete cascade
- on update cascade
- );
- insert into press(name) values
- ('北京工业地雷出版社'),
- ('人民音乐不好听出版社'),
- ('知识产权没有用出版社')
- ;
- insert into book(name,press_id) values
- ('九阳神功',1),
- ('九阴真经',2),
- ('九阴白骨爪',2),
- ('独孤九剑',3),
- ('降龙十巴掌',2),
- ('葵花宝典',3)
- ;
sql示例
- 班级和学生
- 一个班级可以对应多个学生,但一个学生只能对应一个班级
- 主机和机房
- 一个机房可以有多台主机,但是一个主机只能属于一个机房
其他示例
- #多对多
- 三张表:出版社,作者信息,书
- 多对多:一个作者可以写多本书,一本书也可以有多个作者,双向的一对多,即多对多
- 关联方式:foreign key+一张新的表
- =====================多对多=====================
- create table author(
- id int primary key auto_increment,
- name varchar(20)
- );
- #这张表就存放作者表与书表的关系,即查询二者的关系查这表就可以了
- create table author2book(
- id int not null unique auto_increment,
- author_id int not null,
- book_id int not null,
- constraint fk_author foreign key(author_id) references author(id)
- on delete cascade
- on update cascade,
- constraint fk_book foreign key(book_id) references book(id)
- on delete cascade
- on update cascade,
- primary key(author_id,book_id)
- );
- #插入四个作者,id依次排开
- insert into author(name) values('egon'),('alex'),('yuanhao'),('wpq');
- #每个作者与自己的代表作如下
- egon:
- 九阳神功
- 九阴真经
- 九阴白骨爪
- 独孤九剑
- 降龙十巴掌
- 葵花宝典
- alex:
- 九阳神功
- 葵花宝典
- yuanhao:
- 独孤九剑
- 降龙十巴掌
- 葵花宝典
- wpq:
- 九阳神功
- insert into author2book(author_id,book_id) values
- (1,1),
- (1,2),
- (1,3),
- (1,4),
- (1,5),
- (1,6),
- (2,1),
- (2,6),
- (3,4),
- (3,5),
- (3,6),
- (4,1)
- ;
sql示例
- 服务和机器
- 一个服务可能被部署到多台机器上,一台机器上也可以部署多个服务
- 学生和课程
- 一个学生可以选择多门课程,一门课程也可以被多个学生选择
其他示例
- #一对一
- 两张表:学生表和客户表
- 一对一:一个学生是一个客户
- 关联方式:foreign key+unique
- create table customer(
- -> id int primary key auto_increment,
- -> name varchar(20) not null,
- -> qq varchar(10) not null,
- -> phone char(16) not null
- -> );
- create table student(
- -> id int primary key auto_increment,
- -> class_name varchar(20) not null,
- -> customer_id int unique, #该字段一定要是唯一的
- -> foreign key(customer_id) references customer(id) #外键的字段一定要保证unique
- -> on delete cascade
- -> on update cascade
- -> );
- #增加客户
- mysql> insert into customer(name,qq,phone) values
- -> ('韩蕾','',13811341220),
- -> ('杨澜','',15213146809),
- -> ('翁惠天','',1867141331),
- -> ('杨宗河','',1851143312),
- -> ('袁承明','',1861243314),
- -> ('袁清','',18811431230)
- mysql> #增加学生
- mysql> insert into student(class_name,customer_id) values
- -> ('脱产1班',3),
- -> ('周末1期',4),
- -> ('周末1期',5)
- -> ;
sql示例
- 例一:一个用户只有一个博客
- 用户表:
- id name
- 1 egon
- 2 alex
- 3 wupeiqi
- 博客表
- fk+unique
- id url name_id
- 1 xxxx 1
- 2 yyyy 3
- 3 zzz 2
- 例二:一个管理员唯一对应一个用户
- 用户表:
- id user password
- 1 egon xxxx
- 2 alex yyyy
- 管理员表:
- fk+unique
- id user_id password
- 1 1 xxxxx
- 2 2 yyyyy
其他示例
简单的操作
根据表结构合理设计表与表之间的主外键关系和约束,并完成表结构的创建。
Mysql数据库概述的更多相关文章
- PHP的MySQL扩展:MySQL数据库概述
来源:http://www.ido321.com/1023.html 一.SQL:结构化查询语言 SQL(Structured Query Language)是高级的非过程化变成语言,专门用于查询和修 ...
- PHP的MySQL扩张:MySQL数据库概述
资源:http://www.ido321.com/1023.html 一.SQL:结构化查询语言 SQL(Structured Query Language)是高级的非过程化变成语言.专门用于查询和改 ...
- Mysql --数据库概述1
什么是数据(Data)? 描述事物的符号记录称为数据,描述事物的符号既可以是数字,也可以是文字.图片,图像.声音.语言等,数据由多种表现形式,它们都可以经过数字化后存入计算机 在计算机中描述一个事物, ...
- MySQL数据库笔记一:简介及简单操作
一.初识MySQL数据库 1.数据库的概述 <1>数据库:Database 长期存储在计算机内的,有组织的,可共享的数据集合. 存储数据的仓库.(文件) <2>数据库管理系统: ...
- 第一章 数据库概述、MySQL的安装和配置
第一章 数据库概述.MySQL的安装和配置 1.为什么要使用数据库 最早是纸质文件来存储数据 缺点:不易保存,占用空间大 计算机出现以后,采用软件来进行保存(excel) 缺点:容易损坏 文件 ...
- MySQL数据库学习: 01 —— 数据库的概述
壹 概述 一 了解SQL 1.1 数据库基础 1.1.1 什么是数据库 数据库(database)保存有组织的数据的容器(通常是一个文件或一组文件). 易混淆:人们常常用“数据库”这个词语来代表他们使 ...
- python 全栈开发,Day60(MySQL的前戏,数据库概述,MySQL安装和基本管理,初识MySQL语句)
一.MySQL的前戏 在学习Mysql之前,我们先来想一下一开始做的登录注册案例,当时我们把用户的信息保存到一个文件中: #用户名 |密码 root|123321 alex|123123 上面文件内容 ...
- {MySQL数据库初识}一 数据库概述 二 MySQL介绍 三 MySQL的下载安装、简单应用及目录介绍 四 root用户密码设置及忘记密码的解决方案 五 修改字符集编码 六 初识sql语句
MySQL数据库初识 MySQL数据库 本节目录 一 数据库概述 二 MySQL介绍 三 MySQL的下载安装.简单应用及目录介绍 四 root用户密码设置及忘记密码的解决方案 五 修改字符集编码 六 ...
- MySQL数据库(1)- 数据库概述、MySQL的安装与配置、初始SQL语句、MySQL创建用户和授权
一.数据库概述 1.什么是数据(Data) 描述事物的符号记录称为数据,描述事物的符号既可以是数字,也可以是文字.图片,图像.声音.语言等,数据由多种表现形式,它们都可以经过数字化后存入计算机. 在计 ...
随机推荐
- 大型工程多个目录下的Makefile写法
1.前言 目前从事于linux下程序开发,涉及到多个文件,多个目录,这时候编译文件的任务量比较大,需要写Makefile.关于Makefile的详细内容可以参考网上流传非常广泛的<跟我一起写Ma ...
- token session cookie
token 登录握手与身份验证: cookie.session 记录会话状态 兼有 token的功能: cookie session 功能更强大. 所有这些都是为了便捷和密码安全考虑.
- C# 获取 IEnumerable 集合的个数
IEnumerable<DocApply> data1 = data.Where(n => n.DocName.Contains(search)); if (data1.GetEnu ...
- Match 基因匹配 题解(From luoguBlog)
N<=20000!N2的LCS要原地爆炸. 去您妈的优化考场上有分就行TLE60真香嘿嘿嘿 然而这显然是个板子只不过像我这样见识短浅的蒟蒻不知道罢了 正解: 某大佬的博客 转化为lis后二分 复 ...
- vue移动端Ui组件 mint-ui 使用指南
1.上啦加载下拉刷新的使用 this.$refs.loadmore.onTopLoaded(); this.$refs.loadmore.onBottomLoaded(); 上啦刷新下拉加载的 动画显 ...
- Linux删除重复内容命令uniq笔记
针对文本文件,有时候我们需要删除其中重复的行.或者统计重复行的总次数,这时候可以采用Linux系统下的uniq命令实现相应的功能. 语法格式:uniq [-ic] 常用参数说明: -i 忽略大小写 - ...
- 物理cpu与逻辑cpu概述
物理cpu与逻辑cpu概述(本博客属于转载部分内容:主要学习目的用于大数据平台Hadoop之yarn资源调度的配置) 一.yarn资源调度器中主要的资源分类 1.memory(内存) 2. ...
- P1125 笨小猴
P1125 笨小猴 标签:NOIp提高组 2008 云端 难度:普及- 时空限制:1s / 128MB 题目描述 笨小猴的词汇量很小,所以每次做英语选择题的时候都很头疼.但是他找到了一种方法,经试验证 ...
- 数组(day07)
数组名称不可以代表存储区 数组名称可以代表数组里第一个存储区的地址 可以对数组名称进行sizeof计算,结果是 数组里所有存储区的总大小 C99规范里可以使用变长数组 声明变长数组的时候可以用变量表示 ...
- luogu 2483 K短路 (可持久化左偏树)
题面: 题目大意:给你一张有向图,求1到n的第k短路 $K$短路模板题 假设整个图的边集为$G$ 首先建出以点$n$为根的,沿反向边跑的最短路树,设这些边构成了边集$T$ 那么每个点沿着树边走到点$n ...