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安装. 当然对于老手来说需要进行一些自定义的 ...
随机推荐
- TaskController
package main.java.com.zte.controller.system; import java.io.PrintWriter; import java.util.ArrayList; ...
- HDUOJ---3743Frosh Week(BIT+离散化)
Frosh Week Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- 马老师 linux必备web服务入门及高级进阶
http://edu.51cto.com/course/course_id-866.html HTTP: HyperText Transfer Protocol 超文本传输协议 超链接: Web: h ...
- linux 硬件设备文件名
- Template Method - 模板方法模式
1.概述 在面向对象开发过程中,通常我们会遇到这样的一个问题:我们知道一个算法所需的关键步骤,并确定了这些步骤的执行顺序.但是某些步骤的具体实现是未知的,或者说某些步骤的实现与具体的环境相关.例子1: ...
- Linux内核(13) - 子系统的初始化之以PCI子系统为例
由Kconfig这张地图的分布来看,PCI这块儿的代码应该分布在两个地方,drivers/pci和arch/i386/pci,两岸三地都属于一个中国,不管是drivers/pci那儿的,还是arch/ ...
- 关于阿里云centos 2.6下手机表情输入后无法保存到mysql数据库的问题调研及mysql版本从5.1升级到5.7的全过程纪要
近日在开发手机app的评论功能时,输入表情文字,保存后提示数据库保存失败.错误日志片段如下 caused by: java.sql.SQLException: Incorrect string val ...
- cocos2dx 3.3 getParentToNodeTransform bug
cocos2dx 3.3中getParentToNodeTransform实现如下: const Mat4& Node::getParentToNodeTransform() const { ...
- Vuejs搜索下拉框
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 【Android】20.4 录音
分类:C#.Android.VS2015: 创建日期:2016-03-13 一.简介 利用Android提供的MediaRecorder类可直接录制音频. 1.权限要求 录制音频和视频需要下面的权限: ...