window删除MySQL服务

  • cmd下执行

    sc delete MySQL

登陆登出

  • 登陆:

    mysql -uroot -ppasswd -h host

  • 退出登陆

    mysqladmin -uroot -ppasswd shutdown

    note: 在mysql外面执行

linux修改管理员root密码

  • 外部命令修改

    mysqladmin -uroot -poldpasswd password newpasswd

  • MySQL内部修改

    update mysql.user set password=password(newpasswd) where user='root' and host='localhost';

windows修改root用户密码

  • 方法1: 用SET PASSWORD命令

    首先登录MySQL。

    格式:mysql> set password for 用户名@localhost = password('新密码');

    例子:mysql> set password for root@localhost = password('123');

  • 方法2:用mysqladmin

    格式:mysqladmin -u用户名 -p旧密码 password 新密码

    例子:mysqladmin -uroot -p123456 password 123

  • 方法3:用UPDATE直接编辑user表

    首先登录MySQL。

    mysql> use mysql;

    mysql> update user set password=password('123') where user='root' and host='localhost';

    mysql> flush privileges;

  • 方法4:在忘记root密码的时候,可以这样

    以windows为例:

  1. 关闭正在运行的MySQL服务。
  2. 打开DOS窗口,转到mysql\bin目录。
  3. 输入mysqld --skip-grant-tables 回车。--skip-grant-tables 的意思是启动MySQL服务的时候跳过权限表认证。
  4. 再开一个DOS窗口(因为刚才那个DOS窗口已经不能动了),转到mysql\bin目录。
  5. 输入mysql回车,如果成功,将出现MySQL提示符 >。
  6. 连接权限数据库: use mysql; 。
  7. 改密码:update user set password=password("123") where user="root";(别忘了最后加分号) 。
  8. 刷新权限(必须步骤):flush privileges; 。
  9. 退出 quit。
  10. 注销系统,再进入,使用用户名root和刚才设置的新密码123登录。

库操作

  • 创建普通库,此库的字符集和MySQL的字符集一致

    create database dbname

  • 创建特定字符集的字符串,以utf8为例

    create database dbname character set utf8 collate utf8_general_ci

  • 查看数据库支持的字符集

    show variables like '%set%';

  • 查看所有数据库

    show databases;

  • 使用库

    use databasename;

  • 删除库

    drop database dbname;

  • 查看当前所在库

    select database();

  • 查看创库语句(里面包含库的字符集和引擎信息)

    show create database dbname;

用户操作并授权

  • 创建用户

    create user username@host identified by passwd;

  • 删除用户

    drop user username@host;

  • 查看当前所在的用户

    select user();

  • 授权

    grant priviledges on dbname.* to username@host;

    note: 权限包括select,insert,update,create,drop,peferences,idex, alter,idex,create temporary tables,lock tables,

    execute,create view, show view,show view,create routine,alter routine, event, trigger

  • 查看用户权限

    show grants for username@host;

  • 回收用户权限

    revoke privileges on dbname.* from username@host;

  • 刷新权限

    flush privileges

授权局域网内主机远程连接数据库

  • 百分号法

    grant all on privileges *.* to dbname@10.0.0.% identified by passwd;

  • 子网掩码配置法

    grant all on *.* to dbname@255.255.255.0 identified by passwd;

索引

查询数据库,按照主键索引查询最快,每个表只能有一个主键列,但是可以有多个普通索引列。

主键列要求列的所有内容必须唯一,而索引列不要求内容必须唯一

  • 给表字段增加索引

    • 建表时添加
create table tablename(
id int(4) not null auto_increment,
name char(20) not null,
primary key(id), --主键索引
key index_name(name) --普通索引`
);
  • 见表之后增加索引

    alter table tablename add index index_name(name);

  • 利用alter命令修改id列为自增主键索引列

    alter table tablename change id id int primary key auto_increment;

  • 建立普通索\对字段前n个字符创建普通索引

    create index index_name on tablename(name);

    create index index_name on tablename(name(3));

    note:对前n个字符创建索引的好处时可以节省内存空间,前提时前n个字符可以确定字段唯一

  • 创建联合索引

    create index index_name on tablename(name, age);

    note:联合索引上的字段可以有自己的索引且条件查询数据时,联合索引采用前缀生效特征,

    即:联合索引有a,b,c,仅a,ab,abc三个查询条件列可以走索引,ac就不可以

  • 创建唯一索引,作用时保证数据的唯一性

    create unique index uni_index_name on tablename(name);

  • 查看索引

    show index from table\G

    note:\G让展示内容垂直分布

  • 删除索引

    alter table tablename drop index index_name;

  • 索引创建及生效条件

索引相当于文章的目录,好处是加快查询速度,但是占用系统空间,更新数据库是还要维护索引数据。

因此数十行到几百行的小表无需建立索引;写频繁,读少的业务要少建索引

  • 建索引的位置

索引一定要创建在条件列,而不是select后的选择数据的列。另外要尽量选择在唯一值多的大表上建立索引

  • 表操作

    • 查看所有表

      show tables;

    • 查看创表语句

      show create table tablename;

    • 查看表结构

      desc tablename;

    • 修改表名

      ALTER TABLE tablename RENAME [TO] new_tablename

      或者

      rename table oldname to newname;

  • 创建外键

    在创表时添加外键关联

    constraint fk_authorities_users foreign key(username) references users(username)

    当创建好数据表时添加外键约束

    alter table user add foreign key(pid) references province(pId);

  • 表DDL

    • 修改表类型

      ALTER TABLE tablename MODIFY [COLUMN] column_definition [FIRST | AFTER col_name]

      eg:alter table person modify name varchar(30) after age;

    • 增加表字段

      ALTER TABLE tablename ADD [COLUMN] column_definition [FIRST | AFTER col_name]

      eg: alter table person add classes varchar(6) after name;

    • 删除表字段

      ALTER TABLE tablename DROP [COLUMN] col_name

      eg: alter table person drop column name;

    • 字段改名

      ALTER TABLE tablename CHANGE [COLUMN] old_col_name column_definition [FIRST|AFTER col_name]

      eg: alter table tablename chage column age age1 int(4);

      note: change可以修改列名称,modify 则不能

  • 表DML



    • INSERT INTO tablename (field1,field2,……fieldn) VALUES(value1,value2,……valuesn);

      INSERT INTO tablename (field1,field2,……fieldn) VALUES(value1,value2,……valuesn), (value1,value2,……valuesn)...;



    • delete from tablename where 条件;

      drop table tablename;

      truncate tablename;

二者区别:truncate删除表的速度更快,因为truncate时通过物理磁盘删除的;而drop是通过逻辑一行一行删除的。



  • update tablename set field1=value1, field2=value2,... [where condition];



  • slect field1, field2,... from tablename [where condition];

    检查查有没有走索引的方法

    explain sql语句

MySQL总结01的更多相关文章

  1. MySQL案例01:Last_SQL_Errno: 1755 Cannot execute the current event group in the parallel mode

    周五同事监控报警,有个MySQL从库复制状态异常,让我帮忙排查下,经过排查发现是MySQL5.6并行复制的一个Bug所致,具体处理过程如下: 一.错误信息 登录mysql从库服务器,检查复制状态 my ...

  2. MySql笔记01

    用了两天的时间终于把MySql安装好了,还是很麻烦的,之所以没有选择直接安装,使用的是免安装版本,主要是想了解这个数据库的配置,这样以后就可以更好的了解它了. 登录MySql:mysql –h loc ...

  3. mysql笔记01 MySQL架构与历史、Schema与数据类型优化

    MySQL架构与历史 1. MySQL架构推荐参考:http://www.cnblogs.com/baochuan/archive/2012/03/15/2397536.html 2. MySQL会解 ...

  4. MYSQL基础01(新增,修改,删除)

    首先说明一下,本人之前一直都是用MSSQL,由于工作原因,每天写上百条sql语句,并持续了几年;由于换了工作目前主要接触的MYSQL;所以现在开始学习MYSQL. 我的学习计划很简单,我在MSSQL使 ...

  5. MySQL高级01

    MySQL支持大型数据库,支持5000万条记录的数据仓库,32位系统表文件最大可支持4GB,64位系统支持最大的表文件为8TB. 官网下载地址:http://dev.mysql.com/downloa ...

  6. MySQL Cluster --01

    [MySQL Cluster] MySQL Cluster 是MySQL 官方集群部署方案, 支持自动分片.读写扩展:通过实时备份冗余数据.适合于分布式计算环境的高实用.高冗余版本,是可用性最高的方案 ...

  7. Angular4+NodeJs+MySQL 入门-01

    有一定的后台开发经验ES6语法.后台没有用框架来,纯自己写.会sql语句 安装NodeJS的安装 从网上下载 https://nodejs.org/en/ 选择自己,我用的是最新版本 Angular ...

  8. MySQL 初识01

    最近开始学习MySQL 所以将这两天所学习到的知识简单小结一下 1.status 显示数据库信息 2.数据类型: a.字符串: char(m):固定长度的字符,最多255个字符: varchar(m) ...

  9. MySQL丨01丨数据库基本概念

    以前记录数据可能很少也很简单,比如说老王借了老李半斤肉,这样的数据老李直接就写到墙上就行了. 后来数据多了人们就以表格的方式开始记录,写到一张A4纸上,比如学生的档案,有表头和序号等. 表头里有姓名. ...

随机推荐

  1. 利用Graphziv帮助理解复杂的类层次关系

    最近在学习osg三维视景仿真平台,学习的过程中涉及到许多的类与类之间的继承和包含关系.在复杂点的例子中,许多的类和节点组合在一起,很容易让人迷失方向.在编译源代码的时候,无意间发现了Graphviz这 ...

  2. Ubuntu添加与删除PPA源

    目录 PPA,英文全称为 Personal Package Archives,即个人软件包档案.是 Ubuntu Launchpad 网站提供的一项源服务,允许个人用户上传软件源代码,通过 Launc ...

  3. OKVIS框架之前端

    1. 数据流入 在okvis_app_sychronous.cpp内,把IMU和图像数据加入到各自的队列里.由ThreadedKFVio负责队列的各种操作.作者对队列加了特殊功能,保证队列是线程安全的 ...

  4. Serilog 自定义 Enricher 来增加记录的信息

    原文:Serilog 自定义 Enricher 来增加记录的信息 Serilog 自定义 Enricher 来增加记录的信息 Intro Serilog 是 .net 里面非常不错的记录日志的库,结构 ...

  5. SQL数据库— <3>高级查询、常用函数 --摘录网络

    SQL Server T-SQL高级查询 高级查询在数据库中用得是最频繁的,也是应用最广泛的. Ø 基本常用查询 --select select * from student; --all 查询所有 ...

  6. 转载:java面试题(二)

    这部分主要是开源Java EE框架方面的内容,包括Hibernate.MyBatis.Spring.Spring MVC等,由于Struts 2已经是明日黄花,在这里就不讨论Struts 2的面试题, ...

  7. js 数组、字符串、Json互相转换

    arr.join(): 数组转字符串 let arr = [1,2,3,4]; let str = arr.join(','); arr.split():字符串转数组 let str = '1,2,3 ...

  8. day12 python函数名的应用 闭包 迭代器

    day12 python   一.函数名的应用(是第一类对象)     函数名的命名规范和变量是一样的     函数名其实就是变量名 def func():     print('i am funct ...

  9. css实现下拉框导航条

    html <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <ti ...

  10. oracle 数据库插入中文乱码

    一. 查询数据库编码 select userenv('language') from dual; 查询服务器编码 select * from v$nls_parameters; 推出sql查询系统编码 ...