Python:Day35 mysql基础
一、数据库管理系统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基础的更多相关文章
- python操作mysql基础一
python操作mysql基础一 使用Python操作MySQL的一些基本方法 前奏 为了能操作数据库, 首先我们要有一个数据库, 所以要首先安装Mysql, 然后创建一个测试数据库python_te ...
- python 操作 mysql基础补充
前言 本篇的主要内容为整理mysql的基础内容,分享的同时方便日后查阅,同时结合python的学习整理python操作mysql的方法以及python的ORM. 一.数据库初探 在开始mysql之前先 ...
- Python之MySQL基础
一.存储引擎 1.1 什么是存储引擎 MySQL中的数据通过不同的技术存储再文件或者内存中,每种技术有不同的存储机制,索引技巧,锁定水平,并且提供不同的能力,而实现这些技术的我们就称之为存储引擎 1 ...
- python操作Mysql基础
import pymysql #不修改数据 def no_data_change(): db=pymysql.connect('host','user','pw','db_name') #host,u ...
- MySQL基础语句与其在Python中的使用
一.MySQL基础语句 $ mysql -u root -p (有密码时) $ mysql -u root (无密码时) QUIT (or \q) 退出 查看当前所有数据库 show dat ...
- python进阶08 MySQL基础补充
python进阶08 MySQL基础补充 本次课程都是基于三张表格的使用 一.子查询 #如何找到‘张三’的成绩 #思路:先找到张三的学号,在拿这个张三的学号到成绩表里面去匹配,得出成绩 #如何用一条查 ...
- python学习之-- Mysql 基础知识
数据库介绍及MYSQL基础操作了解 关系型数据库(RDBMS)是按照数据结构来组织,存储和管理数据的仓库.特点:1:数据以表格的形式出现2:每行为各种记录名称3:每列为记录名称所对应的数据域4:许多的 ...
- 使用 python 管理 mysql 开发工具箱 - 1
Mysql 是一个比较优秀的开源的数据库,很多公司都在使用.作为运维人员,经常做着一些重复性的工作,比如创建数据库实例,数据库备份等,完全都可以使用 python 编写一个工具来实现. 一.模块 Co ...
- python使用mysql数据库
一,安装mysql 如果是windows 用户,mysql 的安装非常简单,直接下载安装文件,双击安装文件一步一步进行操作即可. Linux 下的安装可能会更加简单,除了下载安装包进行安装外,一般的l ...
随机推荐
- JavaScript主流框架3月趋势总结
原文: What’s New in JavaScript Frameworks-March 2018 译者: Fundebug 为了保证可读性,本文采用意译而非直译.另外,本文版权归原作者所有,翻译仅 ...
- BZOJ4407: 于神之怒加强版(莫比乌斯反演 线性筛)
Description 给下N,M,K.求 感觉好迷茫啊,很多变换看的一脸懵逼却又不知道去哪里学.一道题做一上午也是没谁了,, 首先按照套路反演化到最后应该是这个式子 $$ans = \sum_{d ...
- BZOJ2746: [HEOI2012]旅行问题(AC自动机 LCA)
Time Limit: 30 Sec Memory Limit: 256 MBSubmit: 1188 Solved: 383[Submit][Status][Discuss] Descripti ...
- pycharm最新code码,分享给大家
最新的pycharm激活码,到明年11月份,一名努力的Python程序员 这俩天,在忙学校布置的小项目,给大家更新少了,我会慢慢补上的,努力学pycharm,有什么问题可以问我哦,我竭尽所能帮大家解答 ...
- java的优点和误解 《java核心技术卷i》第一章
<java核心技术卷i>第一章主要内容包括三点: 1:Java白皮书的关键术语:描述Java的十一个关键字: 2:Java applet 3 :关于Java的常见误解 1:第一章:Ja ...
- git 入门教程之冲突合并
如果足够幸运的话,团队成员互不影响,彼此相安无事,大家各自基于 master 分支的某个 commit 创建自己的分支,平时在分支上独立工作,等到一段时间后再合并 merge 到 master 分支, ...
- springmvc复习笔记----Restful 风格,PathVariable获取 Url实例
结构 包与之前相同 <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi=&qu ...
- 关于Inception默认配置的一个坑
本文地址:https://www.cnblogs.com/ajiangg/p/9850902.html 约半年前上线了去哪儿的开源审核工具Inception(最近发现已经闭源了.....)以及基于In ...
- Python语法的转义字符
Python语法的转义字符 转义字符 说 明 \ 续行符 \n 换行符 \0 空 \t 水平制表符,用于横向跳到下一制表位 \'' 双引号 \' 单引号 \\ 一个反斜杠 \f 换页 \0dd 八进 ...
- c/c++ 函数模板初探
函数模板初探 1,由来:有时候,函数的逻辑是一样的,只是参数的类型不同,比如下面 int Max(int a, int b){ return a > b ? a : b; } double Ma ...