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

数据库用户操作:

  1. #进入mysql客户端
  2. $mysql
  3. mysql> select user(); #查看当前用户
  4. mysql> exit # 也可以用\q quit退出
  5. # 默认用户登陆之后并没有实际操作的权限
  6. # 需要使用管理员root用户登陆
  7. $ mysql -uroot -p # mysql5.6默认是没有密码的
  8. #遇到password直接按回车键
  9. mysql> set password = password('root'); # 给当前数据库设置密码
  10. # 创建账号
  11. mysql> create user 'eva'@'192.168.10.%' IDENTIFIED BY '123';# 指示网段
  12. mysql> create user 'eva'@'192.168.10.5' # 指示某机器可以连接
  13. mysql> create user 'eva'@'%' #指示所有机器都可以连接
  14. mysql> show grants for 'eva'@'192.168.10.5';查看某个用户的权限
  15. # 远程登陆
  16. $ mysql -uroot -p123 -h 192.168.10.3
  17. # 给账号授权
  18. mysql> grant all on *.* to 'eva'@'%';
  19. mysql> flush privileges; # 刷新使授权立即生效
  20. # 创建账号并授权
  21. 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. js正则判断字符串中是否包含特殊字符和空格

    字符串只能是数字.字母和中文组成,不能包含特殊符号和空格. /^[\u4e00-\u9fa5_a-zA-Z0-9]+$/

  2. centos如何添加ftp目录

    检查Centos服务器中是否安装了vsftpd rpm -qa |grep vsftpd 如果没有显示则没有安装 2.安装vsftpd yum -y install vsftpd 3.打开vsftpd ...

  3. phpstudy 首次安装后打开网站 数据库内容 中文乱码

    首次安装完成 phpstudy 后,默认的 my.ini 配置只有数据库文件位置,其他的都没有设置,这时如果想要输出数据库中的中文后,显示到页面上就会变成中文乱码 解决方法: 打开 phpstudy ...

  4. Oracle中使用Table()函数解决For循环中不写成 in (l_idlist)形式的问题

    转: Oracle中使用Table()函数解决For循环中不写成 in (l_idlist)形式的问题 在实际PL/SQL编程中,我们要对动态取出来的一组数据,进行For循环处理,其基本程序逻辑为: ...

  5. object literal对象字面量

    <JavaScript高级程序设计(第3版)>有个陌生的新词:对象字面量,无法理解.看了一下英文原版,英文是object literal ,还是不太理解.后来想明白了,主要是literal ...

  6. Jenkins - 分布式构建

    1 - 简介 Jenkins支持分布式多节点(Master-Slave)运行模式. 将安装Jenkins的主机作为Master节点,然后通过界面配置(或远端启动服务)来添加Slave节点. 在这种部署 ...

  7. java 堆调优

    一.查看kafka集群的broker的堆内存使用情况 1>.使用jstat查看gc的信息([root@kafka116 ~]# jstat -gc 12698 1s 30) 参数说明:S0C:第 ...

  8. Java 注解基本原理

    原文地址 注解的本质 「java.lang.annotation.Annotation」接口中有这么一句话,用来描述『注解』. The common interface extended by all ...

  9. OpenVAS开源风险评估系统部署方案

    OpenVAS,即开放式漏洞评估系统,是一个用于评估目标漏洞的杰出框架.功能十分强大,最重要的是,它是“开源”的——就是免费的意思啦- 它与著名的Nessus“本是同根生”,在Nessus商业化之后仍 ...

  10. ThinkPHP3创建Model模型--对表的操作

    创建Model模型 把"Home/Model"文件夹剪切到Application文件夹下,让Home和Admin共同使用. 第一种实例化模型的方法 第二种实例化模型的方法 第三种实 ...