MySQL基本命令和操作
开启和关闭mysql服务
Windows下开启和关闭mysql服务
net start mysql # 开启mysql服务
net stop mysql # 关闭mysql服务
没有重启mysql服务这个命令。
Linux下
service mysql start | stop | restart | status
- start 启动服务
- stop 停止服务
- restart 重启服务
- status 查看服务状态
登录mysql数据库
mysql -h hostname -u username -p
如何hostname是本机的话,要替换为127.0.0.1或者是localhost
例子:mysql -h localhost -uroot -p
这样输完之后会换行让你输密码,我们也可以直接把密码写在-p后面,当然这样不安全。
更改root密码
/usr/bin/mysqladmin -u root password ''
执行完这条命令后,root的密码改为123456。
添加新的用户
先用root登进数据库,然后
mysql > GRANT ALL PRIVILEGES ON *.* TO jack@localhost IDENTIFIED BY '' WITH GRANT OPTION;
格式:grant 权限 on 数据库.* to 用户名@登录主机 identified by "密码";
mysql > flush privileges; //刷新系统权限表
这是最基本的命令,反正还有好多选项,这个先作为一个了解。
修改登录密码
在登陆进数据库之后,可通过来修改密码
set password = password('');
查看当前所有存在的数据库
show databases; // show出来, 不止一个数据库这里我们要加s
创建数据库
create database database_name; // create是创建, 由于一次只能创建一个数据库, 这里database不加s, 最后接上数据库名称
查看创建好的数据库
show create database database_name\G
如果数据库创建成功则会显示数据库的创建信息
删除数据库
drop database database_name; // 注意这里的删除用的是drop, 而不是delete
使用drop database命令要特别谨慎,采用这种方式删除之后数据库中存储的所有数据表和数据会一同被删除,而且无法恢复。数据库管理系统使用数据引擎进行创建、查询、更新和删除数据操作,不同的存储引擎提供不同的存储机制、索引技巧、锁定水平等功能。
查看数据库的存储引擎
show engines\G
Support列表示某种引擎是否能用,YES表示可以使用,NO表示不能使用,DEFAULT表示该引擎为当前默认引擎。常见的mysql引擎有:
InnoDB,MyISAM,Memory,Merge,Archive,Federated,CSV,BLACKHOLE
选择当前数据库
数据表属于数据库,在对表进行任何操作前都要受限选择数据库,否则报错"No database selected"。
use database_name;
查看默认引擎
show variables like 'storage_engine';
创建数据表
create table <表名> (
字段名1, 数据类型 [列级别约束条件][默认值],
字段名1, 数据类型 [列级别约束条件][默认值],
...
[表级别约束条件] );
示例:
create table tb_emp1 (
id INT(11),
name VARCHAR(25),
deptId INT(11),
salary FLOAT
);
查看数据表
show tables;
创建主键约束
主键约束要求主键列的数据唯一,而且不允许为空,可唯一标识一条记录,结合外键还可定义不同数据表的关系,加快查询速度。
主键和记录之间的关系如同身份证和人之间的关系,一一对应。
主键有两种:单字段主键和多字段联合主键。
单字段主键
定义列时顺带就指定了主键,示例:
create table tb_emp2 (
id INT(11) primary key,
name varchar(25),
deptID INT(11),
salary float
);
所有列都定义完了之后,在决定主键是哪个,示例:
create table tb_emp3 (
id INT(11),
name varchar(25),
deptId int(11),
salary float,
primary key(id)
);
这两种方式的执行结果都是一样的,都会在id字段上设置主键约束
多字段联合主键
primay key(字段1, 字段2, ..., 字段n)
示例:
create table tb_emp4 (
name varchar(25),
deptId INT(11),
salary float,
primary key(name, deptId)
);
使用外键约束
外键用来在两个表的数据之间建立链接,它可以是一列或者多列。
一个表可以有一个或者多个外键。
一个表的外键可以为空值,若不为空,则每一个外键值必须等于另一个表中主键的某个值。
外键:首先是表中的一个字段,可以不是本表的主键,但对应着另外一个表的主键。
外键的作用主要是保证数据引用的完整性,定义外键后,不允许删除在另一个表中据欧关联关系的行。
例如部门表tb_dept的主键是id,在员工表tb_emp5中有一个键deptId与这个id关联。
主表(父表)主键所在那个表
从表(子表)外键所在的表
创建外键的语法规则如下:
[constraint <外键名>] foreign key 字段名1[, 字段名2, ...] references <主表名> 主键列1[, 主键列2, ...]
一个表中不能有相同名称的外键,示例:创建部门表tb_dept1
create table tb_dept1 (
id int(11) primary key,
name varchar(22) not null,
location varchar(50)
);
定义数据表tb_emp5,让它的键deptId作为外键关联到tb_dept1的主键id
create table tb_emp5 (
id int(11) primary key,
name varchar(25),
deptId int(11),
salary float,
constraint fk_emp_dept1 foreign key(deptId) references tb_dept1(id)
);
子表的外键必须关联父表的主键,且关联字段的数据类型必须匹配,如果类型不一样就会报错。
使用非空约束
指字段的值不能为空值,如果用户在添加数据时没有指定值,就会报错。
使用非空约束的语法:字段名 数据类型 not null;示例:
create table tb_emp6 (
id int(11) primary key,
name varchar(25) not null,
deptId int(11),
salary float
);
使用唯一性约束
唯一性约束要求该列唯一,允许出现空值,但是只能出现一个空值
唯一性约束的语法规则,定义完列之后直接定义唯一性约束
字段名 数据类型 unique
示例:
create table tb_dept2 (
id int(11) primary key,
name varchar(22) unique,
location varchar(50)
);
定义完所有列之后指定唯一约束:
[constraint <约束名>] unique (<字段名>)
示例:
create table tb_dept3 (
id int(11) primary key,
name varchar(22),
location varchar(50),
constraint sth unique(name)
);
unique和primay key的区别在于:
一个表中可以有多个字段声明为unique,但是只有一个primary key的声明;
声明为primay key的列不允许有null值,而unique允许null值存在。
使用默认约束
默认约束指定某列的默认值,如果插入新的记录没有为其赋值时,便会自动给该字段赋予默认值。
默认约束的语法规则:
字段名 数据类型 default 默认值
示例:
create table tb_emp7 (
id int(11) primary key,
name varchar(25) not null,
deptId int(11) default 1111,
salary float
);
设置表的属性值自动增加
mysql中auto_increment的初始值是1,每新增一条记录,字段值自动加1.
如果突然插了一个很大的id,那么id自动增是怎么增的呢?
一个表只能由一个字段使用auto_increment约束,且字段必须为主键的一部分,可以是任何整数类型。
自动增加语法规则如下:
字段名 数据类型 auto_increment
示例:
create table tb_emp8 (
id int(11) primary key auto_increment,
name varchar(25) not null,
deptId int(11),
salary float
);
查看数据表结构
describe 表名;
desc 表名;
查看表结构详细语句
show create table 表名\G
这里用\G使得信息更加规整
mysql主要使用alter table语句修改表
修改表名
alter table <旧表名> rename [to] <新表名>;
修改表名并不修改表结构
修改字段的数据类型
把字段的数据类型转化为另一种数据类型
alter table <表名> modify <字段名> <数据类型>
示例:
alter table tb_dept1 modify name varchar(30);
要是同时修改多个字段数据类型怎么办?
修改字段名
alter table <表名> change <旧字段名> <新字段名> <新数据类型>;
新的数据类型是指修改后的数据类型,如果不需要修改数据类型可以将其设置为和原来一毛一样,但就是不能为空。
alter table tb_dept1 change location loc varchar(50);
不同数据类型在机器中的存储方式及长度并不相同,修改数据类型可能会影响数据表中已有的数据。
因此当数据表中已经有数据时,不要轻易修改数据类型。
添加字段
alter table <表名> add <新字段名> <数据类型> [约束条件] [first | after 已存在的字段名];
如果不设置first或者after参数,则默认将新加的字段设置为数据标的最后一列。
示例:
alter table tb_dept1 add managerId INT(10);
alter table tb_dept1 add column1 varchar(12) not null;
alter table tb_dept1 add column2 int(11) first;
alter table tb_dept1 add column3 int(11) after name;
删除字段
alter table <表名> drop <字段名>;
alter table tb_dept1 drop column2;
修改字段的排列位置
alter table <表名> modify <字段1> <数据类型> first | after <字段2>;
alter table tb_dept1 modify column1 varchar(12) first;
alter table tb_dept1 modify column1 varchar(12) after location;
更改表的存储引擎
alter table <表名> engine = <更改后的存储引擎名>;
alter table tb_dept1 engine = myisam;
删除表的外键约束
alter table <表名> drop foreign key <外键约束名>;
外键约束名是在定义表时constraint关键字后面的参数。示例:受限创建表tb_emp9
create table tb_emp9 (
id int(11) primary key,
name varchar(25),
deptId int(11),
salary float,
constraint fk_emp_dept foeign key (deptId) references tb_dept1(id)
);
alter table tb_emp9 drop foreign key fk_emp_dept;
show create table tb_emp9 \G
删除数据表
将数据库中已经存在的表从数据库中删除,删除表的同时表的定义和表中的数据都会被删除。
drop table一次可以删除一个或者多个表
drop table [if exists] 表1, 表2, ..., 表n;
删除被其他表关联的主表
数据表存在外键的情况下,如果直接删除父表,结果会报错。
这样会破坏表的参照完整性,如果必须要删除可以先删除子表,再删除父表。
如果要保留子表,删除父表,则首先要解除子表的外键,然后删除父表。
示例:在数据库中创建两个关联的表,首先创建表tb_dept2:
create table tb_dept2 (
id int(11) primary key,
name varchar(22),
location varchar(50)
);
接下来创建tb_emp
create table tb_emp (
id int(11) primary key,
name varchar(25),
deptId int(11),
salary float,
constraint fk_emp_dept foreign key(deptId) references tb_dept2(id)
);
MySQL基本命令和操作的更多相关文章
- MySQL基本命令操作及数据库基本概念
MySQL基本命令操作及数据库基本概念 1.数据库的基本概念 2.主流数据库介绍 3.关系型非关系型数据库介绍 4.Mysql 安装方法 5.Mysql 基本操作命令 1.数据库的基本概念: 数据库的 ...
- MySQL基本命令语法之select
目录 MySQL基本命令语法之select 查询去重以及常数 空值与着重号 着重号 空值 运算符 算术运算符 比较运算符 符号型 非符号型 逻辑运算符 优先级 排序分页 排序 分页 拓展 多表查询 等 ...
- zabbix数据库mariadb从服务器迁移到云mysql数据库的操作
zabbix数据库mariadb从本机迁移到云mysql数据库的操作 1.将zabbix数据库导出,并导入到云数据库中 由于数据库较大,如果直接使用shell会话中断会导致数据库导出或者导入失败,使用 ...
- DBA必备:MySQL数据库常用操作和技巧
DBA必备:MySQL数据库常用操作和技巧 2011-02-25 15:31 kaduo it168 字号:T | T MySQL数据库可以说是DBA们最常见和常用的数据库之一,为了方便大家使用,老M ...
- Git基本命令行操作 (转)
Git远程操作详解 作者: 阮一峰 Git是目前最流行的版本管理系统,学会Git几乎成了开发者的必备技能. Git有很多优势,其中之一就是远程操作非常简便.本文详细介绍5个Git命令,它们的概念和 ...
- mysql没有delete操作,那是delete from操作,
1.mysql没有delete操作,那是delete from操作, 2.DELETE FROM table_name [WHERE Clause]
- MySQL查询in操作 查询结果按in集合顺序显示(转)
MySQL 查询in操作,查询结果按in集合顺序显示的实现代码,需要的朋友可以参考下. MySQL 查询in操作,查询结果按in集合顺序显示 复制代码代码如下: select * from test ...
- php笔记08:数据库编程---使用php的MySQL扩展库操作MySQL数据库
1.使用php的MySQL扩展库操作MySQL数据库: php有3种方式操作MySQL数据库 (1)mysql扩展库 (2)mysqli扩展库 (3)pdo mysql扩展库与mysql数据库 ...
- linux下mysql数据库的操作
本文主要针对linux下mysql数据库的安装,以及数据库的创建和简单的数据库操作进行说明. ①.Mysql数据库的安装: 数据库的安装分为源码安装和rpm安装. 当然对于老手来说需要进行一些自定义的 ...
随机推荐
- Python处理JSON(转)
参考: 概念 序列化(Serialization):将对象的状态信息转换为可以存储或可以通过网络传输的过程,传输的格式可以是JSON.XML等.反序列化就是从存储区域(JSON,XML)读取反序列化对 ...
- js实现new Date(),时间对象和时间戳操作
1.js中实现时间date对象 var myDate = new Date();//获取系统当前时间,结果:Wed Aug 09 2017 00:00:00 GMT+0800 (中国标准时间) 2.获 ...
- set 容器 的全解(转)
1.关于set C++ STL 之所以得到广泛的赞誉,也被很多人使用,不只是提供了像vector, string, list等方便的容器,更重要的是STL封装了许多复杂的数据结构算法和大量常用数据结构 ...
- 学习Tkinter
tutorial point这个网站教程很多,无所不包.还包括一堆在线IDE,值得收藏 一.第一个tkinter程序 import tkinter top = tkinter.Tk() # Code ...
- 网络工程实训_4RIP路由(动态路由)
实验4:RIP路由.包括RIPv1:RIPv2 动态路由协议包括距离向量路由协议和链路状态路由协议.RIP(Routing Information Protocol,路由信息协议)是使用最广泛的距离向 ...
- Linux vm运行参数 - overcommit相关的参数
一.前言 终于可以进入Linux kernel内存管理的世界了,但是从哪里入手是一个问题,当面对一个复杂系统的时候,有时候不知道怎么开始.遵守“一切以人为本”的原则,我最终选择先从从userspace ...
- Unix环境高级编程(二)文件和目录
本章主要介绍的是文件结构及目录.重点是通过stat函数获取文件的结构信息,然后是文件目录及其遍历.学完本章后,编写了一个输出给的目录下的文件信息的程序. 首先是包含在<sys/stat.h> ...
- Bridge - 桥接模式
1. 概述 在软件系统中,某些类型由于自身的逻辑,它具有两个或多个维度的变化,那么如何应对这种“多维度的变化”?如何利用面向对象的技术来使得该类型能够轻松的沿着多个方向进行变化,而又不引入额外的复杂度 ...
- Android IPC机制(三)在Android Studio中使用AIDL实现跨进程方法调用
在上一篇文章Android IPC机制(二)用Messenger进行进程间通信中我们介绍了使用Messenger来进行进程间通信的方法.可是我们能发现Messenger是以串行的方式来处理client ...
- stm32 spi1 bug
stm32 spi1调试NRF24L01时该模块作为接收机时,能收到数据,作为发送机时,发不出数据(虽然读NRF的寄存器显示数据已经发出,但实际并发不出),换到SPI2问题解决