zoukankan      html  css  js  c++  java
  • MYSQL操作

    Database操作
    show databases;#列出所有的服务器上的数据库alter create database if not exists test;#创建一个数据库
    create database xx; drop database fk;#删除数据库 show tables from databasexx;#显示一个数据库中的表 use databasexx;使用数据库

      

    Table操作
      create table   tablename
     ( ID varchar(5),
      name varchar(20),
     dept_name  varchar(20),
    primary key(dept_name));
       
        create table  tablename2
    (  course_id  varchar(5),
      dept_name varchar(20),
    credits numeric(2,0),
    primary key(course_id),
    foreign key(dept_name) references tabename(dept_name));
    
    create table tablename3
    (  ID varchar(5),
      dept_name varchar(20),
      course_id varchar(5),
    primary key(ID,dept_name,course_id),
    foreign key(dept_name)references tablename(dept_name),
    foreign key(course_id)references tablename2(course_id));
    外键必须表明引用那个表中的那个属性

      级联更新

    foreign key(a) references b on delete on action on update cascade;
    关系表的级联更新: on update cascade
    on delete cascade 是级联删除的意思
    意思是 当你更新或删除主键表时,那么外键表也会跟随一起更新或删除
    修改表中数据
     update tablename  set  building='sss' where dept_name='asd';

      

      

    create table tb_dept(
    Id int primary key auto_increment,#部门编号 整形 主键 自增长
    Name varchar(18),#部门名称
    description varchar(100)#描述
    );

    show tables from test;

    desc tb_dept;#查看表信息

    show create table tb_dept;

    use test;
    #员工表
    create table tb_emp(
    id int primary key auto_increment,#auto_increment只是MySQL特有的
    Name varchar(18),
    sex varchar(2),
    age int,
    address varchar(200),
    email varchar(100)
    );

    drop table tb_dept;
    #修改列类型
    #注意:不是任何情况下都可以去修改的,
    #只有当字段只包含空值时才可以修改。
    alter table tb_emp modify sex varchar(4);
    #增加列
    alter table tb_emp add tel varchar(12);
    #删除列
    alter table tb_emp drop tel;
    alter table tb_emp drop column tel;
    #列改名
    alter table tb_emp change Name emp_Name varchar(18);
    #更改表名
    alter table tb_emp rename emp;
    rename table emp to tb_emp;

    insert into dept_emp (Name,sex,age,address,email)values('','','','','');

    #约束
    #是在表上强制执行地数据校验规则,主要用于保证数据库地完整性
    /*
    not null
    unique 唯一键tb_depttb_dept
    primary key
    foreign key 外键
    check 检查
    */

    create table tb_emp(
    id int primary key auto_increment,
    Name varchar(18),
    sex varchar(2) default'男' check(sex='男'or sex='女'),#表级写法check 在mysql中不起作用
    age int,
    address varchar(200),
    email varchar(100) unique,
    dept_id int,#references tb_dept(id) #表级写法外键不起作用
    constraint foreign key fk_emp(dept_id) references tb_dept(id)
    );

    #创建表之后在添加
    alter table tb_emp add constraint foreign key fk_emp(dept_id) references tb_dept(id);

     

  • 相关阅读:
    JQuery实现Ajax应用
    访问本地json文件因跨域导致的问题
    python_控制台输出带颜色的文字方法
    查询数据量大时,你会选择关联表查询还是循环中依个查询? up
    自己动手写SQL字符串分解函数Split up
    关于Access数据库执行Update语句后,不报错,但影响行数总是返回0的问题...... up
    TCP和UDP的区别
    Linxu系统下怎么安装vim编辑器
    网络编程 委托
    学习POS的数据包分析
  • 原文地址:https://www.cnblogs.com/Demonfeatuing/p/9028443.html
Copyright © 2011-2022 走看看