zoukankan      html  css  js  c++  java
  • Mysql

    1、SQL简介

       数据库(DataBase,DB):指长期保存在计算机的存储设备上,按照一定规则组织起来,可以被各种用户或应用共享的数据集合。(文件系统)  

      数据库管理系统(DataBase Management System,DBMS):指一种操作和管理数据库的大型软件,用于建立、使用和维护数据库,对数据库进行统一管理和控制,以保证数据库的安全性和完整性。用户通过数据库管理系统访问数据库中的数据。

      数据库软件应该为数据库管理系统,数据库是通过数据库管理系统创建和操作的。

      数据库:存储、维护和管理数据的集合。

    2、数据在数据库中的存储方式

    列:字段

    行:一条记录(实体)

    public class User{
        private int id;
      private String name;
      private int age;
    
    }

    3、SQL概述 

      SQL:Structure Query Language。(结构化查询语言)

      各数据库厂商都支持ISO的SQL标准。普通话

      各数据库厂商在标准的基础上做了自己的扩展。方言

    4、Sql的分类  

      DDL**(Data Definition Language):数据定义语言,用来定义数据库对象:库、表、列等; CREATE、 ALTER、DROP

      DML***(Data Manipulation Language):数据操作语言,用来定义数据库记录(数据);    INSERT、 UPDATE、 DELETE

      DCL(Data Control Language):数据控制语言,用来定义访问权限和安全级别;

      DQL*****(Data Query Language):数据查询语言,用来查询记录(数据)。SELECT

      * 注意:sql语句以;结尾

    4.1 DDL:操作数据库、表、列等 

      使用关键字:CREATE、ALTER、DROP

    4.1.1 操作数据库

      创建:

     

    create database mydb1;
    Create database mydb2 character set gbk;
    Create database mydb3 character set gbk COLLATE gbk_chinese_ci;

       查询:   

        

        查看当前数据库服务器中的所有数据库:show databases; 

        查看前面创建的mydb2数据库的定义信息:Show  create  database mydb2;

        删除前面创建的mydb3数据库:Drop database mydb3;

      修改: 

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

        alter database mydb2 character set utf8;

      其他:   

         查看当前使用的数据库:

        select database();

        切换数据库:

          use mydb2;

     4.1.2 操作数据库表

      

      常用的数据类型:   

        int:整型

        double:浮点型,例如double(5,2)表示最多5位,其中必须有2位小数,即最大值为999.99;

        char:固定长度字符串类型; char(10)  'abc'

        varchar:可变长度字符串类型;varchar(10) 'abc'

        text:字符串类型;

        blob:字节类型;

        date:日期类型,格式为:yyyy-MM-dd;

        time:时间类型,格式为:hh:mm:ss

        timestamp:时间戳类型 yyyy-MM-dd hh:mm:ss  会自动赋值

        datetime:日期时间类型 yyyy-MM-dd hh:mm:ss

      当前数据库中的所有表:

      SHOW TABLES;

      查看表的字段信息:

      DESC employee;

      在上面员工表的基本上增加一个image列:

      ALTER TABLE employee ADD image blob;

      修改job列,使其长度为60:

      ALTER TABLE employee MODIFY job varchar(60);

      删除image列,一次只能删一列:

      ALTER TABLE employee DROP image;

      表名改为user:

      RENAME TABLE employee TO user;

      查看表格的创建细节:

      SHOW CREATE TABLE user;

      修改表的字符集为gbk:

      ALTER TABLE user CHARACTER SET gbk;

      列名name修改为username:

      ALTER TABLE user CHANGE name username varchar(100);

      删除表

      DROP TABLE user ;

     4.2 DML操作(重要

      查询表中的所有数据 

       SELECT * FROM 表名;

      DML是对表中的数据进行增、删、改的操作。不要与DDL混淆了。

       INSERT 、UPDATE、 DELETE

      小知识:

      在mysql中,字符串类型和日期类型都要用单引号括起来。'tom'  '2015-09-04'

      空值:null

    4.2.1 插入操作:INSERT

      语法: INSERT INTO 表名(列名1,列名2 ...)VALUES(列值1,列值2...);

      注意:列名与列值的类型、个数、顺序要一一对应。

      可以把列名当做java中的形参,把列值当做实参。

      值不要超出列定义的长度。

      如果插入空值,请使用null

      插入的日期和字符一样,都使用引号括起来。

      

    练习 :
    create table emp(
        id int,
        name varchar(100),
        gender varchar(10),
        birthday date,
        salary float(10,2),
        entry_date date,
        resume text
    );
    
    INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume)
    VALUES(1,'zhangsan','female','1990-5-10',10000,'2015-5-5-','good girl');
    
    INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume)
    VALUES(2,'lisi','male','1995-5-10',10000,'2015-5-5','good boy');
    
    INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume)
    VALUES(3,'wangwu','male','1995-5-10',10000,'2015-5-5','good boy');
    
    批量插入:
    INSERT INTO emp VALUES
    (4,'zs','m','2015-09-01',10000,'2015-09-01',NULL),
    (5,'li','m','2015-09-01',10000,'2015-09-01',NULL),
    (6,'ww','m','2015-09-01',10000,'2015-09-01',NULL);

    4.2.2 修改操作:UPDATE

      语法:UPDATE 表名 SET 列名1=列值1,列名2=列值2 。。。 WHERE 列名=值

    练习:
    将所有员工薪水修改为5000元。
    UPDATE emp SET salary=5000 
    将姓名为’zs’的员工薪水修改为3000元。
    UPDATE emp SET salary=3000 WHERE name=’zhangsan’;
    将姓名为’aaa’的员工薪水修改为4000元,job改为ccc。
     UPDATE emp SET salary=4000,gender='female' WHERE name='lisi';
    将wu的薪水在原有基础上增加1000元。
     UPDATE emp SET salary=salary+1000 WHERE gender='male';

     4.2.3 删除操作 DELETE 

      语法 : DELETE FROM 表名 【WHERE 列名=值】

       练习 :

      删除表中名称为’zs’的记录。

      DELETE FROM emp WHERE name=‘zs’;

      删除表中所有记录。

      DELETE FROM emp;

      使用truncate删除表中记录。

      TRUNCATE TABLE emp;

        DELETE 删除表中的数据,表结构还在;删除后的数据可以找回

      TRUNCATE 删除是把表直接DROP掉,然后再创建一个同样的新表。

      删除的数据不能找回。执行速度比DELETE快。

    4.3 DQL操作

      DQL数据查询语言 (重要)

       数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端。

       查询返回的结果集是一张虚拟表。

      查询关键字:SELECT 

       语法: SELECT 列名 FROM表名 

        【WHERE --> GROUP BY -->HAVING--> ORDER BY】

    语法:
      SELECT selection_list /*要查询的列名称*/
      FROM table_list /*要查询的表名称*/
      WHERE condition /*行条件*/
      GROUP BY grouping_columns /*对结果分组*/
      HAVING condition /*分组后的行条件*/
      ORDER BY sorting_columns /*对结果分组*/
      LIMIT offset_start, row_count /*结果限定*/

      查询练习:

    1、基础查询

      1.1 查询所有列

    SELECT * FROM stu;

      1.2 查询指定列

    SELECT sid, sname, age FROM stu;

    2、条件查询

      2.1 条件查询介绍

      条件查询就是在查询时给出WHERE子句,在WHERE子句中可以使用如下运算符及关键字:

    • =、!=、<>、<、<=、>、>=;
    • BETWEEN…AND; 
    • IN(set);
    • IS NULL; IS NOT NULL
    • AND;
    • OR;
    • NOT;

       2.2  查询性别为女,并且年龄50的记录

    SELECT * FROM stu WHERE gender='female' AND ge<50;

      2.3 查询学号为S_1001,或者姓名为liSi的记录

    SELECT * FROM stu WHERE sid ='S_1001' OR sname='liSi';

      2.4 查询学号为S_1001,S_1002,S_1003的记录

    SELECT * FROM stu WHERE sid IN ('S_1001','S_1002','S_1003');

      2.5 查询学号不是S_1001,S_1002,S_1003的记录

    SELECT * FROM tab_student WHERE s_number NOT IN ('S_1001','S_1002','S_1003');

         2.6 查询年龄为null的记录

    SELECT * FROM stu WHERE age IS NULL;

      2.7 查询年龄在20到40之间的学生记录 

    SELECT * FROM stu WHERE age>=20 AND age<=40;

             或者:

    SELECT * FROM stu WHERE age BETWEEN 20 AND 40;

     2.8 查询性别非男的学生记录

    SELECT * FROM stu WHERE gender!='male';
    或者
    SELECT * FROM stu WHERE gender<>'male';
    或者
    SELECT * FROM stu WHERE NOT gender='male';

    2.9 查询姓名不为null的学生记录

    SELECT * FROM stu WHERE sname IS NOT NULL;
    或者
    SELECT * FROM stu WHERE NOT sname IS NULL;

      

  • 相关阅读:
    02 小白新一天
    集合排序
    匿名内部类-Lambda表达式
    设计模式之适配器设计
    设计模式之代理设计
    设计模式之工厂设计
    依赖倒转原则
    多态及练习题
    在一个类中调用另外一个类
    对象的三大特性之封装
  • 原文地址:https://www.cnblogs.com/2-NARUTO-2/p/7976686.html
Copyright © 2011-2022 走看看