MySql

来源:互联网 发布:2015年国民经济数据 编辑:程序博客网 时间:2024/06/09 23:23

一、数据库的简介

  • 1、 数据库:
    长期保存在计算机的存储设备上,按照一定规则组织起来,可以被各种用户和应用共享的数据集合

  • 2、数据库管理系统:
    一种操作和管理数据库的软件,用于建立、维护和使用数据库,对数据库进行统一管理和控制,保证数据库的安全性和完整性
    注:
    (1)用户通过数据管理系统访问数据库中的数据。
    (2)数据库是通过数据库管理系统创建和操作的。
    (3)数据库:存储、维护和管理数据的集合。

二、sql的分类

  • 1、DDL->数据定义语言,用于定义数据库对象:库、表、列等
    关键字:create、alter、drop

    • 1.1. 操作数据库
      1.1.1创建:

      创建一个名称为mydb1的数据库:create database mydb1; 创建一个使用gbk字符集的mydb2数据库:create database mydb2 character set gbk; 创建一个使用gbk字符集,并带校对规则的mydb3数据库: createdatabase mydb3 character set gbk COLLATE gbk_chinese_ci;

      1.1.2查询:

      查看当前数据库服务器中的所有数据库:show databases;查看前面创建的mydb2数据库的定义信息:show create database mydb2;

      1.1.3修改:

      查看服务器中的数据库,并把mydb2的字符集修改为utf8;alter database mydb2 character set utf8;

      1.1.4删除:

      删除mydb3库;drop database mydb3;

      1.1.5其他:

      查看当前使用的数据库select database();切换到mydb1数据库use mydb1;
    • 1.2.操作数据表
      1.2.1创建:

      create table 表名(    字段1 字段类型,    字段2 字段类型,    .    .    .    字段n 字段类型);

      1.2.2.数据类型介绍

      int 整型;double 浮点型;例:double(3, 2)表示最多三位,必须有2位小说,即最大值为9.99;char 固定长度字符串;eg:char(6) 'abc   ';varchar 可变长度的字符串类型;eg:varchar(6) 'abc';text 字符串类型;blob 字节类型;data 日期类型,格式yyyy-MM-dd;time 时间类型,格式hh:mm:ss;timestamp:时间戳类型,yyyy-MM-dd hh:mm:ss 会自动赋值;datatime:日期时间类型,yyyy-MM-dd hh:mm:ss;

      1.2.3.查看

      查看数据库中的所有表:show tables;查看表的字段信息:DESC 表名;查看表的创建细节:show create table 表名;

      1.2.4.修改与删除

      在表中增加一个名为name的列alter table 表名 add name blob;修改表中的一个列的长度为10alter table 表名 modify 列名 varchar(10);修改表名rename table 旧表名 to 新表名;修改表的字符集为gbkalter table 表名 character set gbk;修改列名alter table 表名 change 旧列名 新列名 字段类型;删除表中的一列alter table 表名 drop 列名;删除表drop table 表名;
  • 2、DML->数据操作语言,用来定义数据库记录(数据);
    关键字:insert update delete

    • 2.1.插入操作(INSERT)
      2.1.1.语法:
       insert into 表名(列名1, 列名2…..) values(列值1,列值2….);
      2.1.2.注意:
       (1)列名与列值的类型、个数、顺序要一一对应。
       (2)可以把列名当做java中的形参,把列值当做实参。
       (3)值不要超出列定义的长度。
       (4)如果插入空值,请使用null
       (5)插入的日期和字符一样,都使用引号括起来。

    • 2.2.修改操作(UPDATE)
      2.2.1.语法:
       update 表名 set 列名1=列值1, 列名2=列值2 where 条件;

    • 2.3.删除操作(DELETE)
      2.3.1.语法:
       delete from 表名 where 条件;
      注:还有一种删除操作 truncate
       区别:
        delete: 删除表中的数据,表结构还在,删除的数据还可以找回
        truncate: 直接把表drop掉,然后重新创建一个新表,删除的数据不能找回,但是执行速度比delete快**

  • 3、DCL->数据控制语言,用来定义访问权限和安全级别;
  • 4、DQL->数据查询语言,用来查询记录(数据)(十分重要)
    关键字:select

    • 4.1.牢记
      数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端,查询返回的结果集是一张虚拟表

    • 4.2.语法:
      select 列名 from 表名 [where/group by/having/order by];

    • 4.3.基础查询

      查询表中所有列select * from 表名;查询指定列select 列名1,列名2,....... from 表名;
    • 4.4.条件查询
      条件查询就是在查询是给出where自居,在where子句中给出条件
      4.4.1.运算符和关键字:
       (1) =、!=、<>(不等于)、< 、>、<=、>=
       (2) between….and
       (3) in(set)
       (4) is null、is not null
       (5) and、or、not

    • 4.5.模糊查询
      关键字:like
      通配符:
       _ :匹配任意一个字符
       5 :任意0~n个字符

    • 4.6.字段控制查询
      4.6.1.去除重复记录
       当有两行或者两行以上记录中的数据都相同的时候,如果想去除重复记录就使用该语法
       关键字: distinct
       eg:select distinct 列名 from 表名;
      4.6.2.给查询到的列添加别名
       关键字:as
       eg: select money1 as money2 from salary;
       注:给列取别名的时候 可以省略as关键字

    • 4.7.排序
      语法:order by 列名 asc(默认)/desc;
       asc(升序) desc(降序)

    • 4.8.聚合函数(用于纵向运算)
      关键字:sum avg max min count
      (1) count():统计指定列不为NULL的记录行数;
      (2) max():计算指定列的最大值,如果指定列是字符串类型,那么使用字符串排序运算;
      (2) min():计算指定列的最小值,如果指定列是字符串类型,那么使用字符串排序运算;
      (4) sum():计算指定列的数值和,如果指定列类型不是数值类型,那么计算结果为0;
      (5) avg():计算指定列的平均值,如果指定列类型不是数值类型,那么计算结果为0;

    • 4.9.分组查询
      关键字:group by、having
      注意:
       1、凡是和聚合函数同时出现的列名,一定要写在group by后面
       2、having和where的区别:
        (1) having 是在分组后对数据进行过滤
          where 是在分组前对数据进行过滤
        (2) having 后可以使用聚合函数(统计函数)
          where 后不能使用聚合函数
        (3) where是针对分组前如果不满足where子句,就不会参加分组,having是对分组后的数据进行约束。

    • 4.10.limit 方言
      limit 用来限定查询结果的起始行,已经总行数。
      eg:
       查询student表中的五行数据,起始行为2
       select * from student limit 2, 5;

    • 注意书写顺序和执行顺序:
      查询语句书写顺序:
       select – from- where- group by- having- order by-limit
      查询语句执行顺序:
       from - where -group by - having - select - order by-limit

三、数据的完整性

作用:保证用户输入的数据保存到数据库中是正确的
实现:在创建表的时候给表添加约束
分类:实体完整性、域完整性、引用完整性

  • 1、实体完整性
    实体:即表中的一行(一条记录)代表一个实体(entity)
    实体完整性的作用:标识每一行数据不重复。
    约束类型: 主键约束(primary key) 唯一约束(unique) 自动增长列(auto_increment)

    • 1.1. 主键约束(primary key)
      特点:数据唯一,且不为null;
      eg:

      创建一个学生表 要求学号唯一方式一:(优点:创建联合主键)create table student(    id int,    name varchar(16),    primary key(id));    联合主键:create table student(    id int,    name varchar(16),    primary key(id, name));方式二:create table student(    id int primary key,    name varchar(16));方式三:create table student(    id int,    name varchar(16));alter table student add primary key(id);
    • 1.2.唯一约束(unique)
      eg:

      create table student(    id int primary key,    name varchar(16) unique);
    • 1.3 .自动增长列(auto increment)
      给主键添加自动增长的数值,列只能为整数类型,但是如果删除之前增长的序号,后面添加的时候序号不会重新开始,而是接这被删除的那一列序号开始
      eg:

      create table student(    id int primary key auto increment,    name varchar(16),    primary key(id));insert into student(name) values("学生1");insert into student(name) values("学生2");
  • 2、域完整性
    域代表当前单元格
    域完整性的作用:
     限制此单元格的数据正确,不对照此列的其它单元格比较
    域完整性约束:
     数据类型 非空约束(not null) 默认值约束(default)
    Check约束(mysql不支持) check();

    • 2.1.数据类型:
      数值类型、日期类型、字符串类型
    • 2.2.非空约束:not null
      eg:

      姓名不为空create table student(    id int pirmary key,    name varchar(50) not null,    sex varchar(10));insert into student values(1,’tom’,null);
    • 2.3.默认值约束:default
      eg:

      默认性别为男create table student(    id int pirmary key,    name varchar(50) not null,    sex varchar(10) default '男');insert into student values(1,’tom’,default);insert into student values(2,’Amy’,‘女’);
  • 3、引用完整性
    要有外键必须先有主键,主键和外键的类型必须一致

注:sql语句以分号;结尾,且不区分大小写

原创粉丝点击