mysql简单实用命令

2017-09-24  本文已影响0人  Bury丶冬天

数据库结构相关SQL语句

create database my_demo_db;
show create database my_demo_db;
show variables like 'character%';
set names gbk;
set names utf8;
drop database my_demo_db;
alter database my_demo_db character set utf8;
select database();

表结构相关的SQL语句

create table tablename(
    列名 类型(长度),
    列名 类型(长度),
    列名 类型(长度),
    列名 类型(长度)
) character set utf8;
desc tablename;
primary key auto_increment
unique
not null
alter table tablename add 列名 类型(长度) 约束;
alter table tablename modify 列名 类型(长度) 约束;
alter table tablename chage 旧列名 新列名 类型(长度) 约束;
alter table tablename drop 列名;
rename table 旧表名 to 新表名;
drop table tablename;
show tables;

表数据操作

insert into tablename (列名1,列名2,....) values('值1','值2',....);//数字不要加 '
insert into tablename values(所有值);//自动增长的列写null
update tablename set 列名=值,列名=值 where binary 条件;
delete from tablename where 条件;
delete from tablename;//原理是一行一行的删
start transaction;//开启事物

rollback;//回滚
//原理是.先删除表结构,再创建表结构,删除后不可回滚,性能高于delete from tablename;
truncate tablename;

select数据查询操作

select * from tablename;
select 列名,列名 from tablename;
select 列名,distinct列名 from tablename;
select 列名运算表达式 from 表名;
select 列名 as 别名 from 表名;//as可以省略
 select * from where 条件;
select * from tablename where 列名 <> 100;//列名不等于100
select * from tablename where 列名 between 80 and 100;//列名>80 and 列名<100
select * from tablename where 列名 in(70,80,90);//列名值是70或80或90的条目
select * from tablename where 列名 like 'a%';//a开始,后面多位任意
select * from tablename where 列名 like 'a_b';//a _一位任意
select * from tablename where 列名 is null;
//查询列名是null的所有数据;null取值1/2 位于1(true)和0(false)之间
//任何表达式在与null进行逻辑运算就是null
//and先执行
select * from tabelname order by 列名 asc|desc;//默认asc升序
select count(*) from tablename;
select count(*) from tablename where 条件;
select sum(列名) from tablename;//sum在进行求和时  null不进行运算
select avg(列) from tablename;//null也是不参与运算
select max(列) from tablename;
select 列名 from tabelname group by 列名;

数据库的备份和恢复

cmd>mysqldump -u root -p 数据库名字 > c:\mydatabase.bak
//1.首先创建一个空数据库
mysql>create database mydb;
//方法一
mysql>source 备份文件;
//方法二
cmd>mysql -u root -p 数据库名 < 数据库备份文件

多表设计

外键约束,一张表一个字段引用另一张表的主键

alter table tablename add foreign key (字段) references 另一张表(id);
上一篇 下一篇

猜你喜欢

热点阅读