DDL数据库操作库 表 列(DDL的操作是对数据库及表的设计上的操作(创建数据库、创建表、增加/修改表中的字段等))
进入数据库 mysql -u root -p
数据库操作
1.创建数据库
create database 数据库名;
查看一下创建的数据(默认字符集UTF8)
show create database mydb1;
指定数据库字符集
Create database mydb2 character set gbk;
查看数据库支持的字符集
show character set;
设置对应的校验规则
Create database mydb3 character set gbk COLLATE gbk_chinese_ci;
2.查询数据库
查看当前数据库服务器中的所有数据库
show databases;
查看前面创建的mydb2数据库的定义信息
Show create database mydb2;
3.修改数据库(alter)
修改字符集为utf8
alter database 库名 character set 要修改的编码格式;
4.删除数据库
删除前面创建的mydb3数据库
Drop database mydb3;
5.其他:
查看当前使用的数据库
select database();
切换数据库
use mydb2;
6.退出数据库
quit;
表操作
常用数据类型:
int:整型
double:浮点型,例如double(6,2)表示最多5位,其中必须有2位小数,即最大值为999.99;
char:固定长度字符串类型; char(10) 10个字节 'wanglong_ _'
varchar:可变长度字符串类型;varchar(10) 'w'
text:字符串类型; 大数据文本 最大4M
blob:字节类型;保存音频 保存图片
date:日期类型,格式为:yyyy-MM-dd;
Time: 时间类型 mm:hh:ss
1.创建表
语法:
create table 表名(
字段1 字段类型,
字段2 字段类型,
...
字段n 字段类型
);
2.查询表
查询所有数据表
show tables;
查看建表语句
show create table tbname
查看表结构
desc tbname
查看表的创建细节
show create table 表名;
3.修改表
增加字段
alter table 表名 add 列名 类型;
删除字段
alter table 表名 drop 列名 ;
修改表名
Rename table 老名 to 新名;
修改字段
只修改字段的类型 alter table 表名 modify 列名 类型;
修改字段名及类型 alter table 表名 change 老列名 新列名 类型;
4.删除表
drop table 表名;
DML操作(操作表数据)
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,'张三','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);
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’;
将姓名为’zs’的员工薪水修改为4000元,gender改为f。
UPDATE emp SET salary=4000,gender='f' WHERE name='zs';
将wu的薪水在原有基础上增加1000元。
UPDATE emp SET salary=salary+1000 WHERE gender='male';
3.删除操作(Delete)
语法 : DELETE FROM 表名 【WHERE 列名=值】
DQL查询操作
DQL数据查询语言 (重要)
数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端。
查询返回的结果集是一张虚拟表。
查询关键字:SELECT
语法: SELECT 列名1,列名2 FROM 表名 (查询多列用逗号隔开)
1.查询所有列 使用: *(星号)
2.条件查询介绍
条件查询就是在查询时给出WHERE子句,在WHERE子句中可以使用如下运算符及关键字:
=、!=、<>、<、<=、>、>=; (!= 和 <> 一样)
BETWEEN…AND; 范围查询 age BETWEEN 18 AND 30;
IN(set); 固定的范围之内 用逗号隔开
IS NULL;(是空)
IS NOT NULL(不是空)
AND;(与)
OR;(或)
NOT; (非)
3.字段控制查询
去除重复记录(两行或两行以上记录中系列的上的数据都相同),例如emp表中sal字段就存在相同的记录。当只查询emp表的sal字段时,那么会出现重复记录,那么想去除重复记录,需要使用DISTINCT:
SELECT DISTINCT 字段 FROM emp;
查看雇员的月薪与佣金之和
因为sal和comm两列的类型都是数值类型,所以可以做加运算。如果sal或comm中有一个字段不是数值类型,那么会出错。
SELECT *,sal+comm FROM emp;
注意:任何数值和null值相加 都是null值
本文详细介绍了MySQL中DDL(数据定义语言)与DML(数据操纵语言)的实际应用,包括创建、修改和删除数据库及表的操作,以及数据的插入、更新和删除等关键技能。
1696

被折叠的 条评论
为什么被折叠?



