数据库的简介

数据库的基本概念

1、数据库的英文单词:DataBase 简称:DB
2、什么是数据库?
* 用于存储和管理数据的仓库。
3、数据库的特点:
1、持久化存储数据的。其实数据库就是一个文件系统
2、方便存储和管理数据
3、使用了统一的方式操作数据库 ------SQL
4、常见的数据库软件
MySQL

MySQL 数据库软件

     1、安装
     2、卸载
          1、找到MySQL的安装目录
     3、配置
       *MySQL服务启动
            1、手动。
            2、cmd   窗口里键入一个命令  services.msc    打开服务的窗口
            3、使用管理员打开cmd 
                      *net start mysql: 开启mysql的服务
                      *net stop mysql: 关闭mysql服务     
                      注意:mysql以实际的文档名称为准 如mysql80
        *MySQL登录
              1、mysql -uroot -p密码
              2、mysql -root -p  回车  再输密码就是加星号的了别人看不到
              3、mysql -h(ip) -uroot -p链接目标的密码
              4、mysql --host=ip --user=toor --password=链接目标的密码
        *MySQL退出  
              1、exit   
              2、quit
        *MySQL目录结构
              1、MySQL安装目录
                      *配置文件 my.ini
              2、MySQL数据目录  
                      *  几个概念
                      * 数据库:文件夹
                      * 表:文件
                      * 数据:文件中的数据

SQL

   1、什么是SQL?
               Structured Query Language :  结构化查询语言
               其实就是定义了操作所有关系型数据库的规则。每一种数据库操作的方式存在不一样的地方,称为“方言”
   2、SQL通用语法
              1、SQL 语句可以单行或多行进行书写,以分号结尾。
              2、可使用空格和缩进(Tab)来增强语句的可读性。
              3、MySQL 数据库的SQL不区分大小写,关键字建议使用大写。
              4、3种注释
                       * 单行注释:-- 注释内容 (此用法常用 特别注意 --后要加一个空格才表示注释 不然会报错)或  # 注释内容(mysql 特有)
                       * 多行注释:/*  注释  */
   3、SQL分类

DDL:操作数据库、表

 1、操作数据库:CRUD
   1、C(Create):创建
         *创建数据库:
              *create database 数据库名称;
         *创建数据库,判断不存在,再创建:
              *create database if not exists 数据库名称;
         *创建数据库,并指定字符集
              *create database 数据库名称 character set 字符集名;
                                   
   *练习:创建test3数据库,判断是否存在,并制定字符集为gbk
                  create database if not exists test3 character set gbk;
 2、R(Retrieve):查询
       *查询所有数据库的名称:
            *show databases;
       *查询某个数据库的字符集:查询某个数据库的创建语句
         *show create database 数据库名称;
 3、U(Update):修改
       *修改数据库的字符集
            *alter database 数据库名称 character set 字符集名称;
 4、D(Delete):删除
       *删除数据库
            *drop database 数据库名称;
       *判断数据库是否存在,存在再删除
            *drop database if exists 数据库名称;
 5、使用数据库
        *查询当前正在使用的数据库名称
              *select database();
        *使用数据库
              *use 数据库名称;     (一定注意:不要再加database了。)


2、操作表
  1、C(Create):创建
        1、语法:
              create table 表名(
                  列名1 数据类型1,
                  列名2 数据类型2,
                  列名3 数据类型3,
                   ...
                  列名n 数据类型n
                );
        * 注意:最后一列,不需要加逗号(,)
       * 数据库类型:
             1、int:整数类型
                  *age int,
             2、double:小数类型
                  *score double(5,2)     (表示一共有5位,保留小数点后两位,最大值为999.99)
             3、date:日期,只包含年月日,yyyy-MM-dd
             4、datetime:日期,包含年月日时分秒 yyyy-MM-dd HH:mm:ss
             5、timestamp:时间戳类型 包含年月日时分秒 yyyy-MM-dd HH:mm:ss
                   *如果将来不给这个字段赋值,或赋值为null,则默认使用当前的系统时间,来自动赋值
             6、varchar:字符串
                   *name varchar(20):姓名最大20个字符
                   *zhangsan 8个字符   张三 2个字符

              *创建表
                 create table student(
                      id int,
                      name varchar(32),
                      age int, 
                      score double(4,1),
                      birthday date,
                      insert_time timestamp
                 );
               *复制表:
                     *create table 表名 like 被复制的表名;
                                       
  2、R(Retrieve):查询
              *查询某个数据库中所有的表名称
                   *show tables;     
              *查询表结构
                   *desc 表名;  
  3、U(Update):修改
               1、修改表名
                     alter table 表名 rename to 新的表名;
               2、修改表的字符集
                     alter table 表名 character set 字符集的名称;
               3、添加一列
                     alter table 表名 add 列名 数据类型;
                                     
               4、修改列的名称 类型
                     alter table 表名 change 旧列名 新列名 新数据类型;
                     alter table 表名 modify 列名 新数据类型;   //修改数据类型
               5、删除列
                     alter table 表名 drop 列名;
 4、D(Delete):删除
            *drop table 表名;
            *drop table if exists 表名;

*客户端图形化工具:SQLYog

DML:增删改表中的数据

1、添加数据:
         *语法:
              * insert into 表名(列名1,列名2,...列名n)  values(值1,值2,...值n);
         *注意:
              1、列名和值要一一对应。
              2、如果表名后,不定义列名,则默认给所有列添加值
                         insert into 表名  values(值1,值2,...值n);
              3、除了数字类型,其他类型需要使用引号(单双都可以)引起来
2、删除数据:
        *语法:
             *delete from 表名  [where 条件];
         *注意:
             1、如果不加条件,则删除表中所有记录。
             2、如果要删除所有记录
                     1、delete from 表名;   -- 不推荐使用。有多少记录就会执行多少次删除操作
                     2、TRUNCATE TABLE 表名;  -- 推荐使用,效率更高,先删除表,然后再创建一个一模一样的表。
           
3、修改数据:
         * 语法:
               * update 表名 set 列名1 = 值1, 列名2 = 值2,... [where 条件];
         *注意:
              1、如果不加任何条件,则会将表中所有记录全部修改。

DQL:查询表中的记录

        *       select  * from 表名;
        1、语法:
                 select 
                      字段列表
                 from
                      表名列表
                 where 
                      条件列表
                 group by 
                      分组字段
                 having 
                      分组之后的条件
                 order by
                      排序
                 limit 
                      分页限定
         2、基础查询
                 1、多个字段的查询
                          select 字段名1,字段名2... from 表名;
                    *注意:
                          如果查询所有字段,则可以使用*来替代字段列表。
                 2、去除重复
                          * distinct
                 3、计算列
                          * 一般可以使用四则运算计算一些列的值。(一般只会进行数值型的计算)
                          * ifnull(表达式1, 表达式2):null参与的运算,计算结果都为null
                               *表达式1:哪个字段需要判断是否为null
                               *表达式2:如果改字段为null后的替换值。
                 4、起别名
                         *as: as也可以省略

3、条件查询
1、where子句后跟条件
2、运算符
* >、<、<=、>=、=、<>
* BETWEEN…AND
* IN(集合)
* IS NULL
* and 或 &&
* or 或 ||
* not 或 !
* LIKE:模糊查询
*占位符:
* _: 单个任意字符
* %:多个任意字符
– 查询年龄大于20岁

SELECT * FROM student WHERE age>20;
SELECT * FROM student WHERE age>=20;
– 查询年龄等于20岁
SELECT * FROM student WHERE age = 20; – 注意不是java里的 == 来判断是否相等

– 查询年龄不等于20岁
SELECT * FROM student WHERE age !=20;
SELECT * FROM student WHERE age<>20;

– 查询年龄大于等于20 小于等于30
SELECT * FROM student WHERE age >=20 && age <=30;
SELECT * FROM student WHERE age >=20 AND age <=30;
SELECT * FROM student WHERE age BETWEEN 20 AND 30;

– 查询年龄22岁,19岁,25岁的信息
SELECT * FROM student WHERE age = 22 OR age = 18 OR age = 25;
SELECT * FROM student WHERE age IN(22,18,25);
– 查询英语成绩为null
SELECT * FROM student WHERE english = NULL; – 不对的,null值不能用 = (!=)判断
SELECT * FROM student WHERE english IS NULL;

– 查询英语成绩不为null
SELECT * FROM student WHERE english IS NOT NULL;

– 查询姓马的有哪些? like

SELECT * FROM student WHERE NAME LIKE ‘马%’;
– 查询姓名第二个字是化的人
SELECT * FROM student WHERE NAME LIKE “_化%”;

– 查询姓名是三个字的人

SELECT * FROM student WHERE NAME LIKE “___”;

– 查询姓名中包含德的人

SELECT * FROM student WHERE NAME LIKE “%德%”;
1、DQL:查询语句
1、排序查询
* 语法:order by 子句
* order by 排序字段1 排序方式1,排序字段2 排序方式2…
*排序方式:
* ASC : 升序,默认的。
* DESC:降序。
*注意:
如果有多个排序条件,则当前边的条件值一样时,才会判断第二条件。
2、聚合函数:将一列数据作为一个整体,进行纵向的计算。
1、count: 计算个数
(1) 一般选择非空的列:主键 (推荐)
(2) count(
):只要一行数据中有一个不为null,这行就被计入。(不推荐)
2、max: 计算最大值
3、min: 计算最小值
4、sum: 计算和
5、avg: 计算平均值

              * 注意:聚合函数的计算,排除null值。
              * 解决方案:
                    1、选择不包含非空的列进行计算
                    2、IFNULL 函数
                    SELECT COUNT(IFNULL(english,0)) FROM student
    3、分组查询
             1、语法:group by 分组字段;
             2、注意:
                      1、分组之后查询的字段:分组字段、聚合函数
                      2、where 和 having 的区别?
                         1、 where 在分组之前(group by之前)进行限定,如果不满足条件,则不参与分组。having在分组之后进行限定,如果不满足结果则不会被查询出来
                         2、 where 后不可以跟聚合函数,having可以进行聚合函数的判断。一般聚合函数会起个中文名字判断
                   SELECT sex, AVG(math),COUNT(id) 人数 FROM student WHERE math >70 GROUP BY sex HAVING 人数 >2;

    4、分页查询
             1、语法:limit 开始的索引,每页查询的条数;
             2、公式:开始的索引 = (当前的页码-1)*每页显示的条数
   
             -- 每页显示3条记录
                select * from student limit 0,3;   -- 第1页
				SELECT * FROM student LIMIT 3,3;   -- 第2页
				SELECT * FROM student LIMIT 6,3;   -- 第3页
			3、limit 是一个MySQL“方言”

约束

  * 概念:对表中的数据进行限定,保证数据的正确性、有效性和完整性。
  * 分类:
       1、主键约束:primary key
       2、非空约束:not null
       3、唯一约束:unique
       4、外键约束:foreign key

     *非空约束:not null,值不能为null
         1、创建表时添加约束
                create table stu1(
											        id int,
											        name varchar(20) not null   -- name为非空
											);
		2、创建表完后,添加非空约束
                 ALTER TABLE stu1 MODIFY NAME VARCHAR(20) NOT NULL;
        3、删除name的非空约束
                ALTER TABLE stu1 MODIFY NAME VARCHAR(20);

    *唯一约束:unique,值不能重复
           -- 创建表添加唯一约束
			CREATE TABLE stu1(
			         id INT,
			         phone_number VARCHAR(20) UNIQUE  -- 添加了唯一的约束
			);
			
			* 注意:mysql中,唯一约束限定的列的值可以有多个null
							
			-- 删除唯一约束
			ALTER TABLE stu1 DROP INDEX phone_number;
			
			-- 在创建表后添加唯一约束				
			ALTER TABLE stu1 MODIFY phone_number VARCHAR(20) UNIQUE;
	
	*主键约束:primary key
	     1、注意:
	           1、含义:非空且唯一
	           2、一张表只有一个字段为主键
	           3、主键就是一张表中记录的唯一标识
        2、在创建表时,添加主键		
                   create table stu1(
                              id int primary key,   -- 给id添加主键约束
                              name varchar(20)
				);
	    3、删除主键
				-- 删除主键
				             -- 错误 alter table stu1 modify id int;					
				ALTER TABLE stu1 DROP PRIMARY KEY;
									
		4、创建完表后,添加主键
				ALTER TABLE stu1 MODIFY id INT PRIMARY KEY;
		5、自动增长:
		    1、概念:如果某一列是数值类型的,使用 auto_increment 可以来完成值的自动增长

		    2、在创建表时,添加主键约束,并且完成主键的自增长
		     create table stu1(
                              id int primary key auto_increment,   -- 给id添加主键约束
                              name varchar(20)
				);
			3、-- 删除自动增长						
					ALTER TABLE stu1 MODIFY id INT;
					
			4、-- 添加自动增长
					ALTER TABLE stu1 MODIFY id INT AUTO_INCREMENT;
  • 外键约束:foreign key ,让表与表产生关系,从而保证数据的正确性。
    1、在创建表时,可以添加外键
    * 语法:
    create table 表名(

                       外键列
                       constraint 外键名称 foreign key (外键列名称) references 主表的名称(主表列名称)
                 );
    
    2、 删除外键
         alter table 表名 drop foreign key 外键名称;
    

    3、创建表之后,添加外键
    ALTER TABLE 表名 ADD CONSTRAINT外键名称 FOREIGN KEY (外键字段) REFERENCES 主表名称(主表列名称);

    4、 级联操作

2、约束
3、多表之间的关系
4、范式
5、数据库的备份和还原

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值