MySQL(数据库)基本操作
新增数据库
数据库名字以字母数字下划线组成,不能以数字开头
数据库名字不能用关键字(已经被系统使用的字符)或者保留字(将来系统可能会用到的字符)
语法格式
--双中划线+空格(单行注释),也可以使用#号
数据的增删改查
--创建数据库
create database mydb charset utf8; #创建名为mydb的数据库
--创建关键字数据库
create database database charset utf8;--报错
-- 使用反引号(` `)可以用关键字命名
create database `database` charset utf8;
--创建中文数据库
create database 唐山 charset utf8;
--如果报错解决方案;告诉服务器当前中文的字符集是什么
set names gbk;
在执行 create database 唐山 charset utf8;
--查看所有数据库
show databases;
--创建数据库
create database informationtest charset utf8;
-- 查看指定部分的数据库
--查看一informationtest_开始的数据库(_需要被转义,%匹配多个字符集 _匹配单个字符集)
show databases like ' information_% '; --相当于informationt%
show databases like ' information\_% ';(_需要被转义)
-- 查看数据库的创建语句
show create database mydb;
show create database `database`;-- 关键字需要使用反引号
-- 数据库的修改 数据库名字不可以修改 数据库的修改仅限库选项
-- 修改数据库informationtest 的字符集
alter database informationtest charset GBK;
-- 删除数据库
drop database informationtest; (一次只能删一个)
表的增删改查
-- 新增数据表
create table [if not exists] 表名(
字段名字 数据类型,
……
字段名字 数据类型
) [表选项];(中括号里的可写可不写)
create table if not exists mydb.student(
-- 显示地将student表放到mydb数据库下
name varchar(10),
gender varchar(10),
number varchar(10),
age int
)charset utf8;
-- 创建数据库表
-- 先进入数据库
use mydb;
-- 创建表
create table class(
name varchar(10),
room varchar(10)
)charset utf8;
-- 查看所有表
show tables;
-- 查看部分表(模糊查询)
-- 查看以s结尾的表
show tables like '%s';
-- 查看表的创建语句
show create table student;
show create table student\g -- \g 等价于 ;
show create table student\G -- \G 将查到的结构旋转90度变成纵向
-- 查看表结构
desc class;
describe class;
show columns from class;
--重命名表:student表->my_student
rename table student (旧的)to my_student(新的);
--修改表选项;字符集
alert table my_atudent charset = GBK;
--给学生表增加ID,放到第一个位置
alert table my_student
add column id int
first; #以分号;定位位置
--将学生表中的number学号字段变成固定长度,且放倒第二位(id)之后
alert table my_student modify number char(10) after id;
--修改学生表中的gender字段为sex
alert table my_student change gender sex vachar(10)
--删除学生表中的age年龄字段
alert table my_student drop age;
-- 删除数据表
drop table class(表可以一次删多个,删完不能恢复,要备份)
-- 插入数据
insert into my_student
value(1,'bc20200001','Jim','male'),
(2,'bc20200002','Lily','female');
-- 插入数据:指定的字段列表
insert into my_student(number,sex,name,id) values
('bc20200003','male','syh',3),
('bc20200004','female','zyn',4);
--查看所有数据
select * from my_student;
-- 查看指定字段、指定条件的数据
select id,number,sex,name from my_student
where id=1; -- 查看满足id为1的学生信息
-- 更新数据
update my_student set sex='female' where name='Jim';
-- 删除数据
delete from my_student where sex='male';