day37

一丶Python进阶----数据库的基础,mysql数据库语言基础(增删改查,权限设定)

什么是数据库:

   简称:DataBase ---->DB

   数据库即存放数据的仓库,只不过这个仓库是在计算机存储设备上,而数据是按照一定的格式存放

   数据库中的数据按照一定的数据模型组织,描述和储存,具有较小的冗余度,较高的数据独立性和易扩展性,并可为各种用户共享

数据库管理系统:

   简称:DataBases Management System ----> DBMS

   数据库管理系统产品: MySQL,Oracle,SQLite,SQL Server....

数据库的优势:

   1.程序稳定性:机器宕机了不影响数据和数据库服务

   2.数据一致性:所有的数据存储在一起,所有的程序操作的数据都是统一的,不会出席不一致现象

​   3.并发:数据库可以良好的支持并发,数据库本身也支持网络操作.

   4.效率:使用数据库对数据进行增删改查的效率高

​   5.保证数据安全

二丶数据库分类

关系型数据库:

   含义:

      关系模型可以简单理解为二维表格模型,而一个关系型数据库就是由二维表及其之间的关系组成的一个数据组织

   常见的关系型数据库:

      mysql oracle sqlserver sqllite accesse

非关系型数据库(NoSQL:no only sql):

   含义:

​      以键值对的形式存储,且结构不固定.每一个元组可以有不一样的字段,每个元组可以根据需要增加一些自己的键值对.

​   优势:

      可以减少一些时间和空间的开销,

      模式自由: 不需要定义表结构,数据表中的每条记录都可能有不同的属性和格式。

​      逆规范化: 不遵循范式要求,去掉完整性约束,减少表之间的依赖

​      弹性可扩展: 可在系统运行的过程中,动态的删除和增加节点

​      多副本异步复制: 数据快速写入一个节点,其余节点通过读取写入的日志来实现异步复制

​      弱事务: 不能完全满足事务的ACID特性,但是可以保证事务的最终一致性。

   常见的非关系型数据库:

​      redis mongodb memcache(内存级别)

三丶mysql数据库

什么是mysql:

   MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件。

   MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

​   MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库

安装mysql数据库:

   详细步骤:https://www.cnblogs.com/Eva-J/articles/9669675.html

四丶mysql语句

SQL语言:

   结构化查询语言检查SQL,是一种特殊目的编程语言,是一种数据库查询和程序设计语言.用于存取数据以及查询,更新和管理关系型数据库系统

​   SQL语言主要用于存取数据,查询数据,更新数据和管理关系型数据库.

SQL语言类型:

​   DDL:数据库定义语言: 数据库,表,视图,存储过程,索引,: create XXX

​   DML:数据库操纵语言:增insert, 删delete, 改update ,查select

​   DCL:数据库控制语言:用于控制用户的访问权限grant,revoke

数据库简单操作

1. 操作文件夹(库)
增:create database db1 charset utf8;
查:show databases;
改:alter database db1 charset latin1;
删除: drop database db1; 2. 操作文件(表)
先切换到文件夹下:use db1
增:create table t1(id int,name char);
查:show tables;
改:alter table t1 modify name char(3);
alter table t1 change name name1 char(2);
删:drop table t1; 3. 操作文件中的内容(记录)
增:insert into t1 values(1,'egon1'),(2,'egon2'),(3,'egon3');
查:select * from t1;
改:update t1 set name='sb' where id=2;
删:delete from t1 where id=1; 清空表:
delete from t1; #如果有自增id,新增的数据,仍然是以删除前的最后一样作为起始。
truncate table t1;数据量大,删除速度比上一条快,且直接从零开始, *auto_increment 表示:自增
*primary key 表示:约束(不能重复且不能为空);加速查找

数据库用户操作:

#进入mysql客户端
$mysql
mysql> select user(); #查看当前用户
mysql> exit # 也可以用\q quit退出 # 默认用户登陆之后并没有实际操作的权限
# 需要使用管理员root用户登陆
$ mysql -uroot -p # mysql5.6默认是没有密码的
#遇到password直接按回车键
mysql> set password = password('root'); # 给当前数据库设置密码 # 创建账号
mysql> create user 'eva'@'192.168.10.%' IDENTIFIED BY '123';# 指示网段
mysql> create user 'eva'@'192.168.10.5' # 指示某机器可以连接
mysql> create user 'eva'@'%' #指示所有机器都可以连接
mysql> show grants for 'eva'@'192.168.10.5';查看某个用户的权限
# 远程登陆
$ mysql -uroot -p123 -h 192.168.10.3 # 给账号授权
mysql> grant all on *.* to 'eva'@'%';
mysql> flush privileges; # 刷新使授权立即生效 # 创建账号并授权
mysql> grant all on *.* to 'eva'@'%' identified by '123'

mysql 操作示例( 加 ; 分号 ):

    1. 创建数据库 create database db1 charset utf8 ; ---->创建名字为db1的数据库,数据库的字符集是utf-8

    2. 删除数据库 drop database db1;

    3. 使用数据库use db1 , 创建表 user ,表的字段 id 和 name : create table user(id int(2) ,name char(2) );

    4. show tables; 查看所有表

    5. 对表 user 增加数据 insert into 表名(表的字段) values(值1,值2) ; 值要与表的字段一一对应.

    6. 对表 user 修改数据: update 表名 set 修改的值,如name='ls' where 条件(哪一条数据) : update user set name='ls' where id=1;

    7. 对表 user 查询数据: select * from 表名; : select * from user; 查所有

    7. select id from 表名; 查某一字段 : select id from user;

    8. 对表 user 删除数据 delete from 表名 where 条件 ; : delete where ,



    8. 删除表 delete from 表名;

Python进阶----数据库的基础,关系型数据库与非关系型数据库(No SQL:not only sql),mysql数据库语言基础(增删改查,权限设定)的更多相关文章

  1. python操作三大主流数据库(2)python操作mysql②python对mysql进行简单的增删改查

    python操作mysql②python对mysql进行简单的增删改查 1.设计mysql的数据库和表 id:新闻的唯一标示 title:新闻的标题 content:新闻的内容 created_at: ...

  2. MySQL数据库安装,MySQL数据库库的增删改查,表的增删改查,表数据的基本数据类型

    一 MySQL的安装 MySQL现在属于甲骨文公司,所以和java语言匹配度较高,同时甲骨文公司的另一种数据库为Oracle,两者同为关系型数据库,即采用关系模型来组织数据,以行和列的方法来存储数据的 ...

  3. python的Web框架,Django的ORM,模型基础,MySQL连接配置及增删改查

    Django中的ORM简介 ORM概念:对象关系映射(Object Relational Mapping,简称ORM): 用面向对象的方式描述数据库,去操作数据库,甚至可以达到不用编写SQL语句就能够 ...

  4. mysql实现简单的增删改查,放入xmapp自带数据库中

    1.mysql概念:SQL-Structured Query Language,是一种特殊的语言,专用于操作关系型数据库服务器中的数据,所有的SQL语句分为四类: (1)DDL(2)DQL(3)DML ...

  5. MySQL数据库学习笔记(九)----JDBC的ResultSet接口(查询操作)、PreparedStatement接口重构增删改查(含SQL注入的解释)

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  6. django基础之day04,必知必会13条,双下划线查询,字段增删改查,对象的跨表查询,双下划线的跨表查询

    from django.test import TestCase # Create your tests here. import os import sys if __name__ == " ...

  7. python之MySQL学习——简单的增删改查封装

    1.增删改查封装类MysqlHelper.py import pymysql as ps class MysqlHelper: def __init__(self, host, user, passw ...

  8. Java学习笔记——JDBC之与数据库MySQL的连接以及增删改查等操作

    必须的准备工作 一.MySQL的安装.可以参考博文: http://blog.csdn.net/jueblog/article/details/9499245 二.下载 jdbc 驱动.可以从在官网上 ...

  9. 在python中连接mysql数据库,并进行增删改查

    数据库在开发过程中是最常见的,基本上在服务端的编程过程中都会使用到,mysql是较常见的一种数据库,这里介绍python如果连接到数据库中,并对数据库进行增删改查. 安装mysql的python扩展 ...

随机推荐

  1. visual studio 2019 企业版下载

    由于visual studio从2017开始就是网络下载安装,所以网速慢的朋友安装上就存在时间感,所以笔者在百度云上提供了visual studio 2019的下载包.需要的朋友自己下载安装.不过,2 ...

  2. arris1750 pandorabox安装bandwidthd之后带宽监控(nlbwmon)报资源不足

    nlbwmon 报错资源不足不能看的原因很可能是内存不足导致,因为重启进程会概率可用一下,且删除老的数据后又好用了. 可能与设置的最大数据库条数有关,条数过大导致申请内存大,改成默认的10000. 可 ...

  3. EF获取当天的数据集合

    ).DefaultIfEmpty().Count(); 主要是使用了: DbFunctions.DiffDays

  4. java agent 详细介绍 -javaagent参数

    java agent 详细介绍 简介 java agent是java命令的一个参数.参数 javaagent 可以用于指定一个 jar 包,并且对该 java 包有2个要求: 这个 jar 包的MAN ...

  5. javascript常用方法 - Array

    //1.Aarry方法 // 1.1 Array.from(arrayLike[, mapFn[, thisArg]]) // @arrayLike 想要转换成数组的伪数组对象或可迭代对象. // @ ...

  6. python 一般处理

    #!/usr/bin/env python# -*- coding:utf-8 -*-# Author:afei# QQ:97259460# date = 2019/8/29 s_code1=''s_ ...

  7. 修复Nginx报错:upstream sent too big header while reading response header from upstream

    在 nginx.conf 的http段,加入下面的配置: proxy_buffer_size 128k; proxy_buffers 32k; proxy_busy_buffers_size 128k ...

  8. Spring AOP的常用方法

    转  https://blog.csdn.net/u014745069/article/details/84887765

  9. find命令实例

    按时间查找也有参数 -atime 访问时间 -ctime 改变状态的时间 -mtime修改的时间. 这里的时间是以24小时为单位的. 查找最近30分钟修改的当前目录下的.php文件 find . -n ...

  10. Java IO 与 NIO 服务器&客户端通信小栗子

    本篇包含了入门小栗子以及一些问题的思考 BIO package com.demo.bio; import java.io.*; import java.net.ServerSocket; import ...