Java学习之MySQL(一)

Java学习之MySQL(一)

SQL(Structured Query Language):结构化查询语言,是使用所有关系模型的数据库语言。

SQL分类

  1. DDL(数据定义语言) ,用于定义不同的数据段、数据库、表、列、索引等数据库对象,常用的关键字包括:create, drop, alert等;
  2. DML(数据操纵语言) ,用于添加、删除、更新和查询数据库记录,并检查数据完整性,常用关键字包括:insert、delete、update、select等;
  3. DCL(数据控制语言),用于定义数据库、表、字段的访问权限以及安全级别,创建用户等,常用关键字包括:grant、revoke;

SQL的用法

  1. sql语句可以单行或者多行,以分号或者“\g”结束

DDL(数据定义语言)

  1. 操作数据库:CRUD
    1. C(Create):创建
      • 创建数据库:
        • create database 数据库名称;
      • 创建数据库,判断不存在,再创建:
        • create database if not exists 数据库名称;
      • 创建数据库,并指定字符集
        • create database 数据库名称 character set 字符集名;
    2. R(Retrieve):查询
      • 查询所有数据库的名称:
        • show databases;
      • 查询某个数据库的创建语句
        • show create database 数据库名称;
    3. U(Update):修改
      • 修改数据库的字符集
        • alter database 数据库名称 character set 字符集名称;
    4. D(Drop):删除
      • 删除数据库
        • drop database 数据库名称;
      • 判断数据库存在,存在再删除
        • drop database if exists 数据库名称;(数据库的删除会导致对应的所有表数据的删除,因此要注意备份)
    5. 使用数据库
      • 查询当前正在使用的数据库名称
        • select database();
      • 使用数据库
        • use 数据库名称;
  2. 操作表
    1. C(Create):创建
      1. 语法:
        create table 表名(
        列名1 数据类型1 约束条件,
        列名2 数据类型2 约束条件,

        列名n 数据类型n 约束条件
        );
        • 数据库类型:
          1. int:整数类型
            • age int,
          2. double:小数类型
            • salary double(10,2)
          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 表名 like 被复制的表名;
    2. R(Retrieve):查询
      • 查询某个数据库中所有的表名称
        • show tables;
      • 查询表的定义结构
        • desc 表名;
      • 查询创建表的SQL语句
        *show create table 表名 \G;(\G:可选项,含义是:使得记录能够按照字段竖向排列,以便能更好地显示内容较长的记录)
    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 列名;
      6. MySQL的扩展:add/change/modify 都有可选项first/after来修改字段在表中的位置,add默认加在表的最后位置,而change和modify默认是不修改字段位置的
        alert table 表名 add 列名 数据类型 after 列名1;
    4. D(Drop):删除
      • drop table 表名;
      • drop table if exists 表名 ;

DML(数据操纵语言)

对数据库中表记录的操作,分为增删改查。

  1. 添加数据:
    • insert into 表名(列名1,列名2,…列名n) values(值1,值2,…值n);
      • 注意:列名和值要一一对应。
    1. 如果表名后,不定义列名,则默认给所有列添加值:
      insert into 表名 values(值1,值2,…值n);
    2. 除了数字类型,其他类型需要使用引号(单双都可以)引起来
    3. 含可空字段、非空但含有默认值的字段以及自增字段,可以不用在insert后的字段列表里出现;
    4. MySQL语句可以一次性添加多条记录,每条记录之间用逗号相隔;
  2. 删除数据:
    • 语法:delete from 表名 [where 条件]
  • 注意:
    1. 如果不加条件,则删除表中所有记录。
    2. 删除所有记录:
      1. delete from 表名; – 不推荐使用。有多少条记录就会执行多少次删除操作
      2. TRUNCATE TABLE 表名; – 推荐使用,效率更高 先删除表,然后再创建一张一样的表。
        3.MySQL语句支持同时删除多个表中记录:
        delete t1,t2,…tn from t1,t2,…tn [where 条件];(如果from关键字后面使用表别名,则delete后面要对应使用表别名)
  1. 修改数据:
    • 语法: update 表名 set 列名1 = 值1, 列名2 = 值2,… [where 条件];
    • 注意:
    1. 如果不加任何条件,则会将表中所有记录全部修改。
    2. MySQL语句可以同时更新多个表中数据:
      update t1, t2, …tn set t1.field1=expr1, tn.fieldn=exprn [where 条件];
  2. 查询数据:
    *语法:
    1. 将字段全部选出:select * from 表名 [where 条件];
    2. 查询部分字段:select 字段1,字段2,…字段n from 表名[where 条件];
    3. 查询不重复记录:select distinct 字段 from 表名;
    4. 排序:默认是升序,排序字段相同参考第二排序字段,没有的情况下就是无序排序。
    * select * from 表名 [where 条件] [order by field1 [desc\asc], field2[ desc\asc],…fleldn[desc\asc]] [limit start, row];
    * limit: 显示部分,start为位移偏量默认为0,row为显示的行数。
  3. 聚合:
    语法:
    select [field1,field2,…fieldn] fun_name
    from 表名
    [where 条件]
    [group by field1, field2,…fieldn]
    [with rollup]
    [having 条件]
    * fun_name:聚合函数,sum, count(
    ), max, min
    *group by 表示分类聚合的字段
    *with rollup:是否对分类聚合后的结果再进行汇总
    *having :表示对分类后的结果再进行条件过滤,where是在聚合前对记录进行过滤。
  4. 表连接
    • 内连接:仅选出表中相匹配的记录
      语法:select field1,field2…fieldn from t1,t2 where 条件
    • 外连接:会选出其他不匹配的记录
      • 左连接:包含所有的左边表中的记录甚至是右表中不相匹配的记录
        语法:select field1,field2…fieldn from t1 left join t2 where 条件
      • 右连接:包含所有的右边表中的记录甚至是左表中不相匹配的记录
        语法:select field1,field2…fieldn from t1 right join t2 where 条件
  5. 子查询: 查询的条件需要另一个select查询的结果
    * 语法:常用关键字:in、not in、=、!=、exists、not exists等
    注意:
    * 如果子查询的记录数唯一,可以用=替换in
    * 子查询可以转换成表连接
  6. 记录联合:将多表查询的结果合并显示出来
    *语法: select * from t1
    union /union all
    select * from t1

    union /union all
    select * from tn
    *union: 对union all的结果去重显示

DCL(数据控制语言)

主要是给DBA用来管理系统中的对象权限时使用。
1、授权:grant 操作 on 数据库名.表名 to 用户
2、收回权限:revoke 操作 on 数据库名.表名 from 用户

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值