MySQL是目前最流行的关系型数据库管理系统之一,它是由MySQL AB公司开发、发布并支持。MySQL是一个跨平台的开源关系型数据库管理系统,被广泛地应用在internet上的中小型网站开发中。相比于其他大型数据库管理系统(如Oracle、DB2、SQL Server等),MySQL规模小、功能有限,但它体积小、速度快、成本低。且它提供的功能对稍微复杂的应用来说已经够用了。

MySQL内部有多个数据库,每个数据库里可以有多个表格,每个表格由行和列组成。所以进入数据库进行相应操作流程如下:1、登入mysql用户    2、进入指定数据库   3、对指定表格操作

数据库命令不分大小写,一般都是用大写,本人为了更好理解命令行的意思,均采用小写。进入MySQL后的每次命令都要在后面加上分号。

用户

  • 进入mysql
mysql -u账号 -p密码
  • 退出:\q
  • 创建用户
create user '账号'@'%' identified by '密码';
  • 给新创建的用户赋予权限
grant all on *.* to '账号'@'%';
  • 使权限更改后立即生效
flush privileges;

数据库

  • 查看当前数据库
select database();
  • 展示所有数据库
show databases;
  • 创建数据库
create database [if not exists] database_name;
  • 删除数据库
drop database [if exists] database_name;
  • 进入数据库
use database_name;

表格

  • 查看所有表格
show tables;
  • 创建表格
create table [if not exists] table_name(字段名 类型[,字段名 类型]);
  • 删除表格
drop table table_name;
  • 查看表结构
desc table_name;或者show create table table_name;
  • 增   没写字段名时,默认给所有字段都增添值。
insert into table_name([字段名,字段名]) value(字段值);#一次性插入一行
insert into table_name([字段名,字段名]) valyes(字段值),[,(字段值),(字段值)];#一次性插入多行 insert into table_name set 字段名 = 字段值,字段名 = 字段值;
  • 删   where语句后接一个条件
delete from table_name [where 字段名 = 字段值];
uodate table_name set 字段名=  字段值 [where 条件];
select * from table_name;#查看一个表的所有数据
select 字段名 from table_name;#查看一个表的指定字段名的所有值

表约束

  • 非空约束(not null):保证在增添数据时,指定的字段名的值非空,否则会报错。下面创建了一个含有两个非空约束字段的表格。
create table table_name(id int not null,name varchar(20) not null);
  • 唯一约束(unique key):保证指定字段名下的值都是唯一的,不能有重复。
create table table_name(id int unique key,name varchar(20) not null);
  • 主键约束(primary key):保证指定字段名下的值是非空且唯一,它的作用是可以唯一标识一条数据,每张表里只能有一个主键,当表里没有指定主键时,第一个出现非空且唯一的列被当成主键。
create table table_name(id int primary key,name varchar(20) not null);
  • 自增长约束(auto_increment):自动编码,一般与主键组合使用,默认情况下起始值为1,每次增量为1,也可自己设定起始值。
create table table_name(id int unique key auto_increment [=起始值],name varchar(20) not null);
  • 默认约束(default):给指定字段设定一个默认值,插入数据时,若没有给这个字段赋值,则自动使用默认值。
create table table_name(age int not null default 18);
  • 外键约束(foreign key):保持数据的一致性,完整性,实现表格间的三种关系,三种关系在下面会有介绍。
foreign key(本表的字段名) references 其他表的表名(其他表的字段名);

有时一个字段名不能充当主键,但两个字段名联合就可以,这时可以设置一个联合主键。

primary key(字段名,字段名)

表关系

  1. 一对一:这时用外键方式将两个表的主键关联。
  2. 一对多:创建一个字段名,用外键方式将之与另一表的主键相关联。
  3. 多对多:创建一个中间表,用两次外键的方式分别与两张表的主键相关联。

修改表结构

  • 增加字段名 : 其中位置有first(表示放在第一列)和after,after后跟字段名,表示放在指定字段名的后一列。
alter table table_name [字段名][类型][位置];
  • 删除字段名
alter table table_name drop 字段名;
  • 改:改有三种,分别是改数据类型、字段名、表名。
alter table table_name modify 字段名 类型;#改数据类型
alter table table_name change 字段名 新字段名 类型;#改字段名
alter table 原表名 rename 新表名;

MySQL笔记(一)的更多相关文章

  1. MySQL笔记汇总

    [目录] MySQL笔记汇总 一.mysql简介 数据简介 结构化查询语言 二.mysql命令行操作 三.数据库(表)更改 表相关 字段相关 索引相关 表引擎操作 四.数据库类型 数字型 字符串型 日 ...

  2. 涂抹mysql笔记-数据库中的权限体系

    涂抹mysql笔记-数据库中的权限体系<>能不能连接,主机名是否匹配.登陆使用的用户名和密码是否正确.mysql验证用户需要检查3项值:用户名.密码和主机来源(user.password. ...

  3. centos7.2下安装Mysql笔记

    centos7.2下安装Mysql笔记 安装 MySQL 适用于 CentOS 7.0 或以后版本: yum install mariadb mariadb-server 适用于 CentOS 6.8 ...

  4. MySQL笔记(六)游标练习

    23.3.1 Trigger Syntax and Examples 意义不明的几道练习,留着备用. 感觉不好写,而且难以调试..不知道以后会不会有实际的应用场景. 环境:MySQL 笔记(三)由 t ...

  5. mysql 笔记(一)

    mysql 笔记 预留 mysql> use mysql; mysql> grant all privileges  on *.* to root@'%' identified by &q ...

  6. 【MySQL笔记】SQL语言四大类语言

     SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML,数据定义语言DDL,数据控制语言DCL.   1. 数据查询语言DQL 数据查询语言DQL基本结构是由SELECT子句,FROM子句, ...

  7. Mysql 笔记二

    Mysql 笔记二 Mysql 笔记二 Table of Contents 1. 前言 2. Master Thread 工作方式 2.1. 主循环(loop) 2.2. 后台循(backgroup ...

  8. 深入浅出mysql笔记---1、mysql下载安装

    深入浅出mysql笔记---1.mysql下载安装 一.总结 一句话总结: linux下rpm安装即可 1.linux的wget命令作用? 下载文件的工具:比如wget http://cn.wordp ...

  9. 深入浅出mysql笔记---0、序

    深入浅出mysql笔记---0.序 一.总结 一句话总结: 心得:买书之前建议先找找电子书,纸质书太难带了 1.开源作用? 开源对mysql的发展至关重要 2.mysql在2002年就全面支持了事务, ...

  10. 最全mysql笔记整理

    mysql笔记整理 作者:python技术人 博客:https://www.cnblogs.com/lpdeboke Windows服务 -- 启动MySQL net start mysql -- 创 ...

随机推荐

  1. java基础源码 (4)--reflect包-AnnotatedElement接口

    接口:AnnotatedElement * Represents an annotated element of the program currently running in this * VM. ...

  2. 新版本vue-cli3.x 无法热更新问题【转载】

    版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/weixin_38644883/articl ...

  3. CVE-2010-0249(极光)分析报告

    2019/9/10          报告doc在文件里面 1.    发现可疑流量 A.分析流量,导出字节流 B.得到网页代码,发现需要执行的代码需要解密(加密的字符串部分太长了,就省略了): C. ...

  4. 76.Python中F表达式详解

    F表达式是用来优化ORM操作数据库的. 举个例子:我们做口罩的公司要将所有员工的薪水增加2000元,如果按照正常的流程,应该是先从数据库中提取所有的员工的工资到Python内存中,然后使用Python ...

  5. 【新年呈献】高性能网络通信框架 HP-Socket v5.7.1

    项目主页 : http://www.oschina.net/p/hp-socket 开发文档 : https://www.docin.com/p-2287339564.html 下载地址 : http ...

  6. java多线程并发(二)--线程的生命周期及方法详解

    上篇随笔介绍了线程的相关基础知识以及新启线程的几种方法,本片将继续介绍线程的生命周期及方法详解. 一.线程的生命周期 在Thread代码中,线程的状态被分为6种 public enum State { ...

  7. javascript实现抽奖程序

    昨天开年会的时候看到一个段子说唯品会年会抽奖,结果大奖都被写抽奖程序的部门得了,CTO现场review代码. 简单想了一下抽奖程序的实现,花了十几分钟写了一下,主要用到的知识有数组添加删除,以及ES5 ...

  8. Day 2:线程与进程系列问题(二)

    补充: 线程的创建方式二: 1.自定义一个实现Runnable接口的类 2.实现Runnable接口中的run方法把自定义线程的任务写在run方法中 3.创建实现Runnable接口的对象 4.创建T ...

  9. CodeForces - 446A DZY Loves Sequences(dp)

    题意:给定一个序列a,求最长的连续子序列b的长度,在至多修改b内一个数字(可修改为任何数字)的条件下,使得b严格递增. 分析: 1.因为至多修改一个数字,假设修改a[i], 2.若能使a[i] < ...

  10. SpringCloud学习之Config分布式配置中心(八)

    统一配置中心概述 如果微服务架构中没有使用统一配置中心时,所存在的问题: 配置文件分散在各个项目里,不方便维护 配置内容安全与权限,实际开发中,开发人员是不知道线上环境的配置的 更新配置后,项目需要重 ...