一、数据库管理系统DBMS

  软件,存储数据

  认证,授权,限制

  SqlServer --- 微软(收费)

  Oracle,sqlite,access...MySQL

  服务端和客户端

想要使用MySQL来存储并操作数据,则需要做几件事情:

  a. 安装MySQL服务端
  b. 安装MySQL客户端
  b. 【客户端】连接【服务端】
  c. 【客户端】发送命令给【服务端MySQL】服务的接受命令并执行相应操作(增删改查等)

二、MySQL安装

WIN版本安装:

1、下载:http://dev.mysql.com/downloads/mysql/

2、解压:如果想要让MySQL安装在指定目录,那么就将解压后的文件夹移动到指定目录,如:C:\mysql-5.7.16-winx64

3、MySQL解压后的 bin 目录下有一大堆的可执行文件,执行如下命令初始化数据:

cd c:\mysql-5.7.16-winx64\bin
mysqld --initialize-insecure  # 初始化数据库,会做很多初始化操作,包括创建一个root用户,密码为空

4、启动MySQL服务:在bin文件夹下执行命令:mysqld

5、启动MySQL客户端(在bin路径下启动)并连接MySQL服务:

mysql -u root -p  # 回车,由于密码为空,再回车!

启动优化:

将mysql服务制做成windows服务

# 制作MySQL的Windows服务,在终端执行此命令:
C:\Users\Lowry>C:\mysql-5.7.21-winx64\bin\mysqld --install # 如果在bin目录下,只要执行mysqld --install就可以了 # 移除MySQL的Windows服务,在终端执行此命令:
mysqld --remove

注册成服务之后,以后再启动和关闭MySQL服务时,仅需执行如下命令:

# 启动MySQL服务
net start mysql # 关闭MySQL服务
net stop mysql

三、MySQL数据库

1、概念:

  数据库:文件夹

  数据表:文件

  数据行:文件中的一行

 

2、数据库基本操作:

  显示数据库:show databases;  # 命令后面一定要加;号,代表命令结束

  创建数据库:create database 数据库名称;  # 这个database没有s

  创建指定编码的数据库:

    # utf8

    create database 数据库名称 default charset utf8 collate utf8_general_ci;

    # GBK

    create database 数据库名称 default charset gbk collate gbk_chinese_ci;

  进入数据库:use 数据库名称;  # 个人感觉可能数据库的视图比较少,所以没有返回命令,show databases是全局命令,想改变数据库直接use就可以了。

  删除数据库:drop database 数据库名称;

  ----------------------------------------------------------------------------------------------------------------------------------

  显示数据表:show tables;

  创建数据库表:create table 表名(nid int,name varchar(20), pwd varchar(64));

  查看表中所有数据:select * from 表名;

  插入数据:insert into 表名(nid,name,pwd) value(1,"alex","123");

  删除数据表:drop table 表名;

  清空表数据:delete from 表名;     truncate table 表名;

  查看表结构:desc 表名;

 

3、用户管理:

  创建用户:create user "用户名"@"IP地址" identified by "密码";

    create user wpuser@192.168.6.130 identified by "magedu.com";

  删除用户:drop user "用户名"@"IP地址"

  修改用户名:rename user "用户名"@"IP地址" to "新用户名"@"IP地址";

  修改密码:set password for "用户名"@"IP地址" = Password("新密码")   

  用户相关数据保存在mysql数据库的user表中,所以也可以直接对其操作(不建议)

4、授权管理:

  查看用户权限:show grants for "用户名"@"IP地址"

  给用户授权:grant 权限 on 数据库.表 to  "用户名"@"IP地址"

  取消用户授权:revoke 权限 on 数据库.表 from "用户名"@"IP地址"

  flush privileges,将数据读取到内存中,从而立即生效。(直接在命令行中输入此命令)

  权限列表:

        all privileges  除grant外的所有权限
select 仅查权限
select,insert 查和插入权限
...
usage 无访问权限
alter 使用alter table
alter routine 使用alter procedure和drop procedure
create 使用create table
create routine 使用create procedure
create temporary tables 使用create temporary tables
create user 使用create user、drop user、rename user和revoke all privileges
create view 使用create view
delete 使用delete
drop 使用drop table
execute 使用call和存储过程
file 使用select into outfile 和 load data infile
grant option 使用grant 和 revoke
index 使用index
insert 使用insert
lock tables 使用lock table
process 使用show full processlist
select 使用select
show databases 使用show databases
show view 使用show view
update 使用update
reload 使用flush
shutdown 使用mysqladmin shutdown(关闭MySQL)
super 使用change master、kill、logs、purge、master和set global。还允许mysqladmin调试登陆
replication client 服务器位置的访问
replication slave 由复制从属使用

  对于目标数据库以及内部其他: 

数据库名.* 数据库中的所有
数据库名.表 指定数据库中的某张表
数据库名.存储过程 指定数据库中的存储过程
*.* 所有数据库

  IP地址的写法:

用户名@IP地址         用户只能在改IP下才能访问
用户名@192.168.1.% 用户只能在改IP段下才能访问(通配符%表示任意)
用户名@% 用户可以再任意IP下访问(默认IP地址为%)

4、数据表操作:

  创建表:

  create table 表名(

    列名  类型  是否可以为空  default 缺省值,

    列名  类型  是否可以为空  default 缺省值)ENGINE=InnoDB DEFAULT CHARSET=utf8;

   是否为空:默认允许为空,not null设置为不允许为空,如果将列设置为主键,将自动设置为not null

   default:如果不设置,默认值为null

  

  auto-increment:

  (1)默认不自增,如果想要设置成自增加上auto_increment。

  (2)一张表中只能有一个自增列,自增列必须是数字且必须是key(索引),否则报错!

  (3)如果把某列设置成自增列,插入数据时可以不设置该列值,默认自增;但是也可以手工设置为某个值,这个值可以比当前最大的值大,也可以比最大的值小,只要不重复就OK。

  

  唯一列:

  (1)一张表可以有多个唯一列

  (2)唯一,不重复

  (3)可以为Null

  primary key:一种特殊的唯一索引

  (1)一张表只能有一个主键

  (2)唯一,不重复

  (3)不能为空

  (4)不能为Null

  create table tb3(

    nid int,

    name varchar(10),

    primary key(nid,name));  # 把两列设置成一个主键,这个命令必须要写在列名称括号中!!

  foreign key:一种特殊的索引

  修改表:

   

  

  

Python:Day35 mysql基础的更多相关文章

  1. python操作mysql基础一

    python操作mysql基础一 使用Python操作MySQL的一些基本方法 前奏 为了能操作数据库, 首先我们要有一个数据库, 所以要首先安装Mysql, 然后创建一个测试数据库python_te ...

  2. python 操作 mysql基础补充

    前言 本篇的主要内容为整理mysql的基础内容,分享的同时方便日后查阅,同时结合python的学习整理python操作mysql的方法以及python的ORM. 一.数据库初探 在开始mysql之前先 ...

  3. Python之MySQL基础

    一.存储引擎 1.1  什么是存储引擎 MySQL中的数据通过不同的技术存储再文件或者内存中,每种技术有不同的存储机制,索引技巧,锁定水平,并且提供不同的能力,而实现这些技术的我们就称之为存储引擎 1 ...

  4. python操作Mysql基础

    import pymysql #不修改数据 def no_data_change(): db=pymysql.connect('host','user','pw','db_name') #host,u ...

  5. MySQL基础语句与其在Python中的使用

    一.MySQL基础语句 $ mysql -u root -p (有密码时) $ mysql -u root     (无密码时) QUIT (or \q)  退出 查看当前所有数据库 show dat ...

  6. python进阶08 MySQL基础补充

    python进阶08 MySQL基础补充 本次课程都是基于三张表格的使用 一.子查询 #如何找到‘张三’的成绩 #思路:先找到张三的学号,在拿这个张三的学号到成绩表里面去匹配,得出成绩 #如何用一条查 ...

  7. python学习之-- Mysql 基础知识

    数据库介绍及MYSQL基础操作了解 关系型数据库(RDBMS)是按照数据结构来组织,存储和管理数据的仓库.特点:1:数据以表格的形式出现2:每行为各种记录名称3:每列为记录名称所对应的数据域4:许多的 ...

  8. 使用 python 管理 mysql 开发工具箱 - 1

    Mysql 是一个比较优秀的开源的数据库,很多公司都在使用.作为运维人员,经常做着一些重复性的工作,比如创建数据库实例,数据库备份等,完全都可以使用 python 编写一个工具来实现. 一.模块 Co ...

  9. python使用mysql数据库

    一,安装mysql 如果是windows 用户,mysql 的安装非常简单,直接下载安装文件,双击安装文件一步一步进行操作即可. Linux 下的安装可能会更加简单,除了下载安装包进行安装外,一般的l ...

随机推荐

  1. 浏览器解析JavaScript原理

    1.浏览器解析JavaScript原理特点: 1.跨平台 2.弱类型 javascript 定义的时候不需要定义数据类型,数据类型是根据变量值来确定的.    var a = 10; 数字类型    ...

  2. 19.Odoo产品分析 (二) – 商业板块(11) – 在线活动(1)

    查看Odoo产品分析系列--目录 点击安装"在线活动". 1. 主页 在线活动绑定在电子商务中,在网站中可以看到在线活动的菜单:  在这里可以按时间看到每一个活动. 2. 新建活动 ...

  3. View在测量时的MeasureSpec由什么决定?

    我们都知道系统要确定View的大小,首先得先获得MeasureSpec,再通过MeasureSpec来决定View的大小. MeasureSpec(32为int值)由两部分组成: SpecMode(高 ...

  4. 运行 python *.py 文件出错,如:python a.py

    运行 python *.py 文件出错,如:python a.py(下图) 原因:没有安装web.py 解决:下载并安装 网址:http://webpy.org/install#install  (h ...

  5. Linux-pthread如何设置线程的优先级

    设置线程优先级的函数: int pthread_setschedparam(pthread_t target_thread, int policy, const struct sched_param ...

  6. LeetCode题解之Binary Tree Right Side View

    1.题目描述 2.问题分析 使用层序遍历 3.代码 vector<int> v; vector<int> rightSideView(TreeNode* root) { if ...

  7. 口碑点餐相关问题FAQ

    1.菜品上传中:出现重复错误或者违禁词 检查并修改商家中心本次上传中的重复菜品,或者删除口碑掌柜以及第三方平台已添加的重复菜品(重复菜品临时快捷办法:修改菜品名称) 2.手持pos 打开自动接单,无响 ...

  8. Java代码优化总结(持续更新)

    1.对equals不熟 例子 if(user.get("s").equals("ss")){ //一堆代码 } 注:一旦前端页面传null值过来,就错了,nul ...

  9. 洗礼灵魂,修炼python(88)-- 知识拾遗篇 —— 线程(2)/多线程爬虫

    线程(下) 7.同步锁 这个例子很经典,实话说,这个例子我是直接照搬前辈的,并不是原创,不过真的也很有意思,请看: #!usr/bin/env python #-*- coding:utf-8 -*- ...

  10. SQL Server最大内存设为0后的处置办法

    故障说明: 远程调整实例内存时疏忽,将实例最大内存调整为了0,因此最大内存变成了128MB的最小值. 解决方式: 1.正常关闭SQL Server服务,如果是集群,需要先关停止集群角色防止故障转移,然 ...