MYSQL操作

Posted 大梦千古

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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);

 

以上是关于MYSQL操作的主要内容,如果未能解决你的问题,请参考以下文章

VSCode自定义代码片段——git命令操作一个完整流程

如何在片段中填充列表视图?

VSCode自定义代码片段15——git命令操作一个完整流程

VSCode自定义代码片段15——git命令操作一个完整流程

从mysql的片段中加载ListView

连接MySQL出现错误:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)(代码片段