MySQL的命令介绍:
 
连接数据库服务器命令:
mysql -u 用户名 -p 密码
 
mysql是连接MySQL数据库的命令 -u表示后跟用户名 -p 后跟密码
 
如果登录后展示 "mysql >"表示登录成功
 
退出数据库命名:
quit;    或者 exit;   (注意MySQL以“;”结束一个语句)。
 
1、库相关的命令操作:
1.1、查看所有的库sql:
show databases;
 
1.2、创建数据库的SQL:
create database database_name;
 eg:创建一个名为test1的数据库
 
1.3、删除数据的SQL:
drop database database_name;
 
1.4、选择数据库的SQL:(多个数据库下,选择要使用的)
use database_name;
 
1.5、展示当前库下的所有的表SQL:
show tables;

2、表操作
 
2.1、创建表
create table table_name(
属性名 数据类型[完整性约束],
属性名 数据类型[完整性约束],
...
属性名 数据类型[完整性约束]
);
注意:在数据库创建的时候要选取合适的数据类型,而且
还要添加完整性约束,两个属性之间用逗号隔开,
完整性约束条件有:
-------------------------------------
     约束条件       | 说明
primary key        | 修饰的属性是该表的主键
foreign key         | 修饰的数据是该表的外键
not null               |表示该字段不能为null   
unique                |修饰的属性值是唯一的
auto_increment  |mysql的特色,表示该属性是自增的   
default                | 设置属性默认值
 
 数据类型:
int:整型
data:日期,只包含年月日 yyyy-MM-dd
datatime:   yyyy-MM-dd  HH:mm:ss
timestamp:时间戳类型 (包含年月日时分秒)如果将来不给这个字段赋值,或者赋值为null,则默认当前系统的时间自动赋值
varchar:字符类型
eg:create table t2(id int primary key, name varchar(5));
 
2.1、查看表
 
2.1.1、 desc table_name;
用desc可以查看表的字段名称、类型、是否为空、约束条件、默认值、备注信息
 
2.1.2 show create table table_name;
show create table可以打印创建的表的SQL,
并且显示该表的存储引擎和字符集编码
 
3.修改表:
 
修改数据库字符集:alter database 数据库名称 character set 字符集名称;
 
修改表名:   alter   table   旧表名  rename(to) 新表名;
 
修改表的字段类型:alter table 表名 modify 属性名 数据类型;
eg:alter table t1 id bigint;
 
修改表中属性名:alter  table  表名  change  旧属性名  新属性名  数据类型;
eg:alter table t1 change id idd int;
 
增加新的字段:
alter table 表名 add 属性名 数据类型 [约束条件] [first/        afters 属性名1];
 
删除属性:
alter table 表名 drop 属性名;
 
修改属性的排列顺序:
alter table 表名 modify 属性名1 数据类型  first/    after 属性名2;
 
修改表的存储引擎:
alter table 表名 engin = innodb | myisam;
 
4.删除:
 
drop database 数据库名称
删除前判断:drop database if not exists 数据库名称
 
删除属性SQL:
alter table table_name drop 属性名;
eg:alter table t1 drop age2;
 
5.查询
查询表SQL
SQL基本的结构如下:
select 属性列表 from table_name [where 条件表达式1]
[group by 属性1 [having 条件表达式2]]
[order by 属性2 [asc | desc]]
 
5.1 带in的子查询
[not] in(元素1,元素2...元素n)
eg:select * from Student where SID in (1,3,5);
 
5.2 带between and 的范围查询
[not] between 取值1 and 取值2
eg:select * from Student where SID between 3 and 7;
 
 5.3 带like的模糊查询字符串
[not] like 'abc';
注意:like可以结合通配符使用
%:表示0个或者是任意长度的字符串
_:只能表示单个字符 
eg:select * from Student where Sname like 'CJ%';
   
5.4 空值查询
is [not] null;   
eg:select * from Student where Sage is not null;
 
 5.5 带and 的多条件查询
条件表达式1 and 条件表达式2 [and ...条件表达式n]
eg:select * from Student where Ssex ='nan' and Sage=20;
 
 5.6 带or的多条件查询
条件表达式1 or 条件表达式2 [or ...条件表达式n]
 
 5.7 去重复查询
select distinct 属性名
eg:select distinct Sage from Student;
 
 5.8 对结果排序
order by 属性名 [asc| desc];
asc:升序(默认是升序)  
desc:降序
eg:select * from Student order by SID asc;
 
5.9 分组查询
group by 属性名[having 条件表达式]
eg:select * from Student group by Ssex having Sage >= 18;
 
 5.10 limit分页查询
不指定起始位置 limit是记录数
eg:select * from Student limit 3;
 
指定初始位置是limit的起始位置、记录数
eg:select * from Student limit 2,5;
 
多表查询:
内连接、左连接、右连接
内连接:将连接的两个表共同存在的数据(共同存在的)获取
左连接:将左表对应的数据全部展示,左表存在右表 不存在的数据时,将右表对应字段填充为null
右连接:将右表对应的数据全部展示,右表存在左表不存在的数据时,将左表对应的数据全部填充为null
 
联合查询
内连接:
select 属性名1...属性名n from 表名1 inner join 表名2 on 表名1.属性 = 表名2.属性(注:属性指关联的字段,即使用外键)
外连接:
select 属性名1,...,属性名n from 表名1 lift|right join 表名2 on 表名1.属性 = 表名2.属性(注:属性指关联的字段,即使用外键)
复合查询:select 属性名1 ... 属性名2 from 表名1,表名2 where 表名1.属性 = 表名2.属性
 
批量插入数据:
insert into table_name (属性名1,...,属性名n)
values
(值11,...值1n),
(值21,...值2n),
...
(值n1,...值nn);
 
 
2、索引使用的SQL
 若查询表中存在上万的数据量,使用索引可以大大提高查询效率
2.1 创建表的时候指定索引字段的SQL
create table table_name(
   id int primary key,
   name varchar ,
   index(id)
);
在创建SQL时指定字段创建索引index(id),指对id字段添加索引
eg:create table test3(id int, name varchar(5),age int, index(name));
该表中创建了索引名为'name'作用于name属性到的索引
 
2.2、在已存在的表中添加索引
2.2.1、create [unique|fulltext|spatial] index 索引名 on 表名(属性名);
eg:create index idx_age on test3(age)
 
2.2.2 alter table 表名 add  [unique|fulltext|spatial] index 索引名 (属性);
eg:alter table test3 add index idx_id_name(id,name);
 
2.3、删除索引
drop index 索引名 on 表名;
eg:drop index idx_age on test3;
 
2.4、展示索引
show create table 表名;
eg: show create table test3;
    +-------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
    | Table | Create Table                                                                                                                                                                                                        |
    +-------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
    | test3 | CREATE TABLE `test3` (
      `id` int(11) DEFAULT NULL,
      `name` varchar(5) DEFAULT NULL,
      `age` int(11) DEFAULT NULL,
      KEY `name` (`name`),
      KEY `idx_id_name` (`id`,`name`)
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1 |
其中:KEY 后即为该表中的索引 展示的格式为KEY  索引名(索引对应的字段)
 
 
 

mysql的简单命令的更多相关文章

  1. Ubuntu 安装mysql和 简单命令操作

    ubuntu上安装mysql非常简单只需要几条命令就可以完成. 1. sudo apt-get install mysql-server   2. apt-get isntall mysql-clie ...

  2. day39——SQL语句简单介绍、库、表、记录、安装mysql简单命令

    day39 SQL语句简单介绍 库(增删改查) 查看数据库 show databases; 查看其中一个库 show create database db1; 创建数据库 create databas ...

  3. Ubuntu 安装mysql和简单操作

    http://www.cnblogs.com/zhuyp1015/p/3561470.html ubuntu上安装mysql非常简单只需要几条命令就可以完成. 1. sudo apt-get inst ...

  4. Mysql的简单使用(三)

    接上文Mysql的简单使用(二) mysql中结构相同的两个表进行合并:(注意需要两个表的结构是一样的) 有如下结构的两个表father和person. 合并的步骤为: 1.把person表和fath ...

  5. mysql show processlist命令 详解

    SHOW PROCESSLIST显示哪些线程正在运行.您也可以使用mysqladmin processlist语句得到此信息.如果您有SUPER权限,您可以看到所有线程.否则,您只能看到您自己的线程( ...

  6. MYSQL经常使用命令列表

    MYSQL经常使用命令列表 1.系统管理 mysql -h主机地址 -uusername -p 连接MYSQL(在mysql/bin) exit 退出MYSQL命令 mysqladmin -uuser ...

  7. MySQL的简单使用-(一)

    MySQL的简单使用 使用MySQL命令行工具 Windows 用户使用: MySQL Client, 输入密码 Linux: mysql -u用户名 -p密码 mysql -uroot -p 显示数 ...

  8. mysql安装简单教程(自动安装/配置安装)

    mysql安装简单教程(自动安装/配置安装) 1.1前言: 由于特殊原因,在最近2-3个月里mysql真是安装了无数遍,每次安装都要上网找教程,每个教程基本都不一样,因此还是自己写下来比较好,毕竟自己 ...

  9. mysql 中启动服务的命令 、登录命令、退出命令 mysql 的常用命令

    1.cmd 以管理员执行 下面命令 启动服务 :net start mysql57 关闭 服务:net stop mysql57 查看mysql 的版本信息 : mysql -V 指定主机地址登录: ...

随机推荐

  1. 2013-10-6 datagridview实现换行并自动设置行高

    datagridview设置换行,如下,文本设置\r\n即可换行 dv4.DefaultCellStyle.WrapMode = DataGridViewTriState.True; dv4.Auto ...

  2. Python--day25--面向对象之多态

    多态(Python天生支持多态) 多态指的是一类事物有多种形态 动物有多种形态:人,狗,猪 import abc class Animal(metaclass=abc.ABCMeta): #同一类事物 ...

  3. 前端开发之JavaScript

    JavaScript JS是一种脚本语言,浏览器执行,用于渲染HTML网页,实现网页的动画效果. JavaScript的引用方式: 1,在HTML文件中script标签中写JS代码 <scrip ...

  4. P1099 双连击

    题目描述 我们假设一个二位整数 \(N(10 \le N \le 99)\) ,它的十位上的数字是 \(A\) ,个位上的数字是 \(B\) ,如果 \(A\) 和 \(B\) 的比例关系满足 \(A ...

  5. P1072 城市轰炸

    题目描述 一个大小为N*M的城市遭到了X次轰炸,每次都炸了一个每条边都与边界平行的矩形. 在轰炸后,有Y个关键点,指挥官想知道,它们有没有受到过轰炸,如果有,被炸了几次,最后一次是第几轮. 输入格式 ...

  6. WPF 元素裁剪 Clip 属性

    本文介绍如何在 WPF 使用 Clip 裁剪元素 在 WPF 的 UIElement 提供了 Clip 属性,这个属性默认是空,但是如果设置了这个属性就会对元素进行裁剪 这个属性是一个 Geometr ...

  7. H3C生成树协议

  8. jquery超级简单的后台系统自适应框架

    系统后台自适应简单框架 <!DOCTYPE HTML> <html lang="zh-CN"> <head> <meta http-equ ...

  9. dotnet core 用值初始化整个数组

    如果想要创建一个数组,在这个数组初始化一个值,有多少不同的方法? 本文告诉大家三个不同的方法初始化 在开发中,会不会用很多的时间在写下面的代码 var prime = new bool[1000]; ...

  10. poj2826 An Easy Problem?!(计算几何)

    传送门 •题意 两根木块组成一个槽,给定两个木块的两个端点 雨水竖直下落,问槽里能装多少雨水, •思路 找不能收集到雨水的情况 我们令线段较高的点为s点,较低的点为e点 ①两条木块没有交点 ②平行或重 ...