SQL数据库的使用:创建表结构

一、mysql的安装与卸载
  1. 启动关闭数据库

  2. 登入数据库

二、sql语言的介绍和分类
  1. 什么是sql语言:
    结构化查询语言 是数据库操作和程序设计的语言 可以通过sql语句对数据库进行任何操作
  2. sql的分类:
    1. DDL:数据定义语言 定义数据库和数据表
    2. DML:数据操作语言 操作数据库数据的增加 修改 删除
    3. DQL:数据查询语言 查询数据库中的数据的
    4. DCL:数据控制语言 主要是对数据库的用户 角色  权限的等的控制作用
三、定义数据库和定义数据表(DDL)
  1. 创建数据库
    1. 语法:create database 数据库名称 [character set 编码] [collate 排序规则]
    2. 示例:create database android character set utf8 collate utf8_general_ci
  2. 查看数据
    1:show databses :查看所有数据库列表

    2:show create database 数据库名称 ://查看数据库的创建语句

  3. 修改数据库(主要是修改数据库的编码)
    1. 语法:alter database 数据库名称 [character set 编码]
    2. 示例:alter database android character set gbk

  4. 删除数据库
    语法:drop database 数据库名称
    1. 示例:drop database android;

  5. 切换数据库
    语法:use 数据库名称
    1. 示例:use android

  6. 查看当前所在的数据库
    1. 示例:select database()

四、定义数据表
  1. 创建数据表
    1. 语法:create table 表名称(字段名称 数据类型 [约束],字段名称 数据类型 [约束],字段名称 数据类型 [约束]);
    2. 示例:create table user(id int,name varchar(20),age int);



    1. 数据类型

      1. mysql的数据类型与java中数据类型的对应关系
      2. mysql java
      3. int int/Integer
      4. double double/Double
      5. decimal BigDecimal
      6. char String
      7. varchar String
      8. text String
      9. blob byte[]
      10. date Date(java.sql)
      11. time Time(java.sql)
      12. timestamp Timestamp(java.sql)

    2. 约束:就是约束某个字段下的数据具有一定特点/唯一/非空...
      1. 主键约束:代表这一个字段是唯一性标识 特点:非空唯一
        1. 主键约束语法:primary key
        2. 示例:id int primary key
        3. 如果主键是数字的话 可以将这个主键定义成自增长
        4. 自增长语法:auto_increment
        5. 示例:id int primary key auto_increment

      2. 唯一性约束:代表某个字段下的数据必须唯一
        1. 语法:unique
        2. 示例:idcard varchar(18) unique

      3. 非空约束:约束某个字段下的数据不能为空
        1. 语法:not null
        2. 示例:name varchar(20) not null

      4. 默认约束:某个字段下的数据如果不插入 会给一个默认值
        1. 语法:default 默认值
        2. 示例:age int default 80 / name varchar(20) defaut 'zhangsan'
      5. 示例
        要求:
        1. 创建一个张表user,该表具有以下字段:
        2. id int 主键 自动增长
        3. username 字符串 长度20 非空
        4. password 字符串 长度20 非空
        5. gender 字符串 长度10
        6. age 整型 默认25
        7. email 字符串 长度50 唯一 非空
        8. salary 浮点型 最大8位其中两位小数
        9. state 整型 默认0
        10. role 字符串 长度10 默认值 VIP
        11. registTime 时间戳
        代码:
        1. create table user(id int primary key auto_increment,username varchar(20) not null,password varchar(20) not null,gender varchar(10),age int default 25,email varchar(50) not null unique,salary double(8,2),state int default 0,role varchar(10) default 'vip',regisTime timestamp )

  2. 查看数据表
    1. 显示所有表
      代码:show tables;

    2. show create table 表名称;//查看表创建语句
      代码:show create table user;

    3. desc 表名称

    4. 修改表
      1. 修改表名称
        语法:rename tbale 旧表名称 to 新表名称
        1. rename table user to myuser;

      2. 修改表的编码
        语法:alter table 表名称 character set 编码
        1. alter table myuser character set gbk;

    5. 修改表的字段
      1. 添加新字段(add):语法:alter table 表名称 add 字段名 类型
        1. alter table myuser add idcard varchar(20) not null;
         
      2. 修改字段类型(modify ):语法:alter table 表名称 modify 字段名称 类型[null,key,defaule这些都可以选择修改];
        1. alter table myuser modify idcard int;
         
      3. 修改字段名及类型(change):语法:alter table 表名称 change 旧字段 新字段 数据类型
        1. alter table myuser change idcard sfz int not null;

      4. 删除表内字段(drop):语法:alter table 表名称 drop 字段
        1. alter table myuser drop sfz;

    6. 删除表
      语法:drop table 表名称
      1. drop table myuser;





posted @ 2016-01-01 19:11  蓝蝶岳  阅读(2635)  评论(0编辑  收藏  举报