数据库的介绍

mysql数据库介绍

  开放源码的轻量级关系型数据库管理系统,体积小、速度快、操作便捷。

数据库的启动和连接

mysql数据库启动

  在终端输入以下命令,启动mysql服务器

service mysql start

  输入命令,查询mysql服务器状态

service mysql status

  出现如下提示表示mysql服务器以启动成功

mysql数据库连接

  输入账户和密码连接数据库

  表示启动成功。

mysql数据库断开连接

  输入exit,如果显示Bye表示断开成功。

数据库的操作

显示数据库

show databases;

创建数据库

create database 库名 default character set utf8;

删除数据库

drop database 库名;

使用数据库

use 库名;

  表示以成功切换到study数据库。

数据表的操作

显示数据表

show tables;

创建数据表

## 创建表语句
create tables 表名(字段名 类型 约束,字段名 类型 约束,......);
## 注意:mysql是没有序列的,但是可以在创建表的时候直接指定主键是自赠的。
    在字段后使用 auto_increment 表示自增。 ## MySQL常见字段类型
数值类型:
int(长度)表示整数类型的数据
float/double表示浮点数
字符类型:
varchar(长度)动态分配存储长度
char(长度)分配固定长度
日期类型:
date:格式为yyyy-mm-dd
datetime:格式为yyyy-MM-dd hh:mm:ss 占用8个字节
timestamp:特点:会自动进行时区的转换,占用4个字节
time:时间
year:年份
其他类型:
TEXT:字符数据
BLOB:二进制数据 ## 约束
  主键约束:
    在创建表时,在字段后使用 primary key 即可
    在创建表语句的最后面使用 constraint 约束名 pirmary key(主键字段名)
  非空约束:
    在创建表的时候直接在字段后使用 nut null 即可
    注意:
      mysql的非空约束中空字符是可以存储进去的。
  检查约束:
    在mysql中是没有检查约束的,但是使用check关键字又不会报错。
    解决:
      使用代码逻辑进行无效的数据过滤。
      使用 mysql 的存储过程。
  唯一约束:
    在字段名后直接使用 unique 即可
    在创建表语句的最后面使用 constraint 约束名 unique(字段名)
  外键约束:
    在字段名后直接使用 references 父表名(父表主键名)
    在创建表语句的最后面使用 constraint 外键约束名 foreign key(字段名) references 父表名(父表主键名) ## 在表外部添加约束
  ## 主键约束
  alter table 表名 add constraint 约束名 pirmary key(主键字段名);
  ## 唯一约束
  alter table 表名 add constraint 约束名 unique key(字段名);
  ## 非空约束
  alter table 表名 modify 字段名 类型 not null;
  ## 外键约束
  alter table 表名 constraint 外键约束名 foreign key(字段名) references 父表名(父表主键名)on delete set null on update cascase;

修改数据表

添加字段:
alter table 表名 add 字段名 类型 约束;
删除字段:
alter table 表名 drop 字段名;
修改字段类型:
alter table 表名 modify 字段名 新的类型;
修改字段名:
alter table 表名 change 字段名 新的字段名 类型;
修改表名:
alter table 表名 rename as 新的表名;

删除数据表

drop table 表名;

查看表创建语句

show create table 表名;

表数据的操作

查询数据

## 单表查询
## 查询全部
select * from 表名;
## 别名
直接在字段后使用即可
select 字段,字段 别名,字段 from 表名;
## 连接符
使用concat(字段名,“连接的字符”)
## 去除重复
使用 distinct 关键字即可
## 排序
order by 字段名
## where字句
select * from 表名 where 判断条件;
## 分组
group by 字段名
注意:
分组可以和字段一起使用
## having
分组后筛选
## 多表查询
select * from 表名1 别名1,表名2 别名2 where 别名1.字段名 判断条件 别名2.字段名; select * from 表名1 别名1 inner join 表名2 字段名2 on 别名1.字段名 判断条件 别名2.字段名;
## 子查询
select * from 表名 where 字段名 in (select 字段名 from 表名 where 查询条件);

增加数据

insert into 表名 values(值1,值2,值3,...);    全字段插入
insert into 表名(主键字段名,字段,字段,...) values(值1,值2,值3,...); 部分字段插入

删除数据

delete from 表名 where 条件;

修改数据

update 表名 set 字段名=值,字段名=值,... where 条件;

分页查询

select * from 表名 limit x,y;
x:从第几条数据开始查询
y:每页显示多少条数据 ## 每页显示n条,查询第m页的信息
select * from 表名 limit m*n-n,n;

数据库的备份

导出

## 导出整个数据库
mysqldump -u root -p 数据库名>/目录/文件名.sql;
## 只导出一个表
mysqldump -u root -p 数据库名 表名>/目录/文件名.sql;

导入

## 方法一 连接数据库之后输入
mysql>source /目录/文件名.sql;
## 方法二 连接数据库之前输入
mysql -u root -p 数据库名<文件名.sql;

学习笔记—MySQL基础的更多相关文章

  1. 数据库学习笔记 - MySQL基础知识

    一.数据库基础知识 1.1 Whats's 数据库 数据库(Database,DB):将大量数据保存起来,通过计算机加工而成的可以进行高效访问的数据集合.如:大型-银行存储的信息,小型-电话簿. 数据 ...

  2. MyBatis:学习笔记(1)——基础知识

    MyBatis:学习笔记(1)--基础知识 引入MyBatis JDBC编程的问题及解决设想 ☐ 数据库连接使用时创建,不使用时就释放,频繁开启和关闭,造成数据库资源浪费,影响数据库性能. ☐ 使用数 ...

  3. mybatis学习笔记之基础框架(2)

    mybatis学习笔记之基础框架(2) mybatis是一个持久层的框架,是apache下的顶级项目. mybatis让程序将主要精力放在sql上,通过mybatis提供的映射方式,自由灵活生成满足s ...

  4. bootstrap学习笔记之基础导航条 http://www.imooc.com/code/3111

    基础导航条 在Bootstrap框中,导航条和导航从外观上差别不是太多,但在实际使用中导航条要比导航复杂得多.我们先来看导航条中最基础的一个--基础导航条. 使用方法: 在制作一个基础导航条时,主要分 ...

  5. Django学习笔记(基础篇)

    Django学习笔记(基础篇):http://www.cnblogs.com/wupeiqi/articles/5237704.html

  6. MySQL学习笔记-MySQL体系结构总览

    MySQL体系结构总览 不管是用哪种数据库,了解数据库的体系结构都是极为重要的.MySQL体系结构主要由数据库和数据库实例构成. 数据库:物理操作系统文件或者其它文件的集合,在mysql中,数据库文件 ...

  7. C#学习笔记(基础知识回顾)之值类型与引用类型转换(装箱和拆箱)

    一:值类型和引用类型的含义参考前一篇文章 C#学习笔记(基础知识回顾)之值类型和引用类型 1.1,C#数据类型分为在栈上分配内存的值类型和在托管堆上分配内存的引用类型.如果int只不过是栈上的一个4字 ...

  8. C#学习笔记(基础知识回顾)之值传递和引用传递

    一:要了解值传递和引用传递,先要知道这两种类型含义,可以参考上一篇 C#学习笔记(基础知识回顾)之值类型和引用类型 二:给方法传递参数分为值传递和引用传递. 2.1在变量通过引用传递给方法时,被调用的 ...

  9. C#学习笔记(基础知识回顾)之值类型和引用类型

    一:C#把数据类型分为值类型和引用类型 1.1:从概念上来看,其区别是值类型直接存储值,而引用类型存储对值的引用. 1.2:这两种类型在内存的不同地方,值类型存储在堆栈中,而引用类型存储在托管对上.存 ...

随机推荐

  1. 【STM32H7教程】第7章 STM32H7下载和调试方法(IAR8)

    完整教程下载地址:http://forum.armfly.com/forum.php?mod=viewthread&tid=86980 第7章   STM32H7下载和调试方法(IAR8) 本 ...

  2. MySQL 中基于 XA 实现的分布式事务

    1 XA协议 首先我们来简要看下分布式事务处理的XA规范可知XA规范中分布式事务有AP,RM,TM组成: 其中应用程序(Application Program ,简称AP):AP定义事务边界(定义事务 ...

  3. elasticsearch6.6.2在Centos6.9的安装

    JDK8 做个记录,以防以后忘记能够查看. 1.elastic是java编写的,先搭建运行环境,6.6.2版本必须要jdk8以上版本才可运行,先官网下载jdk,上传服务器 https://www.or ...

  4. C# 《编写高质量代码改善建议》整理&笔记 --(六)编码规范及习惯

    一.命名规范 1.考虑在命名空间中使用复数 System.AllCollections System.TheCollection 2.用名词和名词组给类型命名 ScoreManager UserCon ...

  5. redis测试实践

    最近测试服务端的时候,接触到了redis,之前也看过,但不系统,借着这次实践,记录一下. 一.写在前面 Redis是一个开源的使用ANSI C语言编写.遵守BSD协议.支持网络.可基于内存亦可持久化的 ...

  6. 如何理解Axis?

    前言 只有光头才能变强. 回顾前面: 从零开始学TensorFlow[01-搭建环境.HelloWorld篇] 什么是TensorFlow? TensorFlow读写数据 不知道大家最开始接触到axi ...

  7. pins-模块内的代码及资源隔离方案

    随着项目的不断迭代,复杂的业务模块及项目自身的基础技术组件迅速扩张,以往基于单个模块的项目往往显得过于臃肿.代码目录结构,包名混乱,代码模块职责不清晰,耦合度高,不便维护.基础公共组件没有抽取并剥离干 ...

  8. python中的del

    python中的del,只删除变量,不删除数据,具体表现为: a=1,c=a,del a,(c=1) 和 a = [1,2,3,4,5] b= a[0] del a[0] print a ([2,3, ...

  9. 从0开始构建你的api网关--Spring Cloud Gateway网关实战及原理解析

    API 网关 API 网关出现的原因是微服务架构的出现,不同的微服务一般会有不同的网络地址,而外部客户端可能需要调用多个服务的接口才能完成一个业务需求,如果让客户端直接与各个微服务通信,会有以下的问题 ...

  10. 号称“新至强,可拓展,赢当下”的Xeon可拓展处理器有多逆天?

    目前企业数据中心正在发生重大变化,许多企业正在经历基于在线服务和数据的广泛转型.他们将这些数据用于功能强大的人工智能和分析应用程序,这些应用程序可以将其转化为改变业务的洞察力,然后推出可以使这些洞察力 ...