csdn博客搬迁

连接数据库:
1、在dos窗口下,进入数据库的安装目录的bin目录下,使用mysqld命令启动数据库服务,或者在计算机的服务里面启动mysql服务
2、另外打开一个dos窗口,进入数据库的安装目录的bin目录下,使用命令连接数据库服务器:mysql -u root -p

一、数据库的创建、修改、备份、恢复

创建一个名称为mydb1的数据库
create database mydb1;
show databases;

创建一个使用utf-8字符集的mydb2数据库。
create database mydb2 character set utf8;

创建一个使用utf-8字符集,并带校对规则的mydb3数据库。
create database mydb3 character set utf8 collate utf8_general_ci;

查看前面创建的mydb2数据库的定义信息
show create database mydb2;

删除前面创建的mydb1数据库
drop database mydb1;

查看服务器中的数据库,并把其中某一个库的字符集修改为gb2312;
alter database mydb2 character set gb2312;
show create database mydb2;

演示恢复和备份
create database tt;
use tt;
create table a
(
    name varchar(20)
);
insert into a(name) values('aaaa');
select * from a;
-----看到a表有数据

对tt作备份操作,启动一个window命令行窗口,进入数据库的安装目录的bin目录下,执行如下命令
mysqldump -uroot -p tt>c:\tt.sql

演示恢复
1.先删除库
drop database tt;

2.恢复tt库(1)
  2.1  为恢复库,要先创建库  create database tt;
  2.2  再恢复tt库 
    use tt; 
    source c:\tt.sql        (source:可以执行一个 sql脚本)

3.恢复tt库(2)
  2.1  为恢复库,要先创建库  create database tt;
  2.2  恢复库   mysql -uroot -proot tt<c:\1.sql;   (window命令)

二、创建表 对表结构进行修改

创建一个员工表
use mydb2;
create table employee
(
    id int,
    name varchar(40),
    sex varchar(4),
    birthday date,
    entry_date date,
    job varchar(40),
    salary decimal(8,2),
    resume text
);

show tables;  查看库的所有表
show create table employee;   查看表的创建细节
desc employee;     看表结构

在上面员工表的基本上增加一个image列。
alter table employee add image blob;

修改job列,使其长度为60。
alter table employee modify job varchar(60);

删除sex列
alter table employee drop sex;

表名改为user。
rename table employee to user;

修改表的字符集为utf-8
alter table user character set utf8;

列名name修改为username
alter table user change column name username varchar(40);

删除表
drop table user;

三、插入语句

使用insert语句向表中插入三个员工的信息。(插入的字符和日期类型数据应该加上单引号)
rename table user to employee;
insert into employee(id,username,birthday,entry_date,job,salary,resume) values(1,'aaa','2015-09-29','1980-09-09','bbb',90,'aaaaa');
select * from employee;

插入数据的细节1(可以不用指明字段,只要插入的值和表的字段完全匹配就行)
insert into employee values(1,'aaa','1980-09-09','1980-09-09','bbb',90,'aaaaa');

插入数据的细节2(可以把每个插入的字段值都加上单引号,mysql拿到数据以后会自动去转换成相应的类型)
insert into employee values('1','aaa','1980-09-09','1980-09-09','bbb','90','aaaaa');
插入数据的时候都用单引号引起来,省的数据报错,如果ID引起来的话,mysql会自动转换类型的。

插入数据的细节3(插入中文)
    要告诉mysql客户端采用gb2312编码
    show variables like 'chara%';
    set character_set_client=gb2312;
    insert into employee(id,username) values('3','张三');
    
    要想查看时不乱码
    show variables like 'chara%';
    set character_set_results=gb2312;
    select * from employee;

四、更新数据

将所有员工薪水修改为5000元。
update employee set salary=5000;

将姓名为’bbb’的员工薪水修改为3000元。
update employee set salary=3000 where username='bbb';

将姓名为’bbb的员工薪水修改为4000元,job改为ccc。
update employee set salary=4000,job='ccc' where username='bbb';

将bbb的薪水在原有基础上增加1000元。
update employee set salary=salary+1000 where username='bbb';

更新要注意的问题
update employee set username='ccc',salary=9000,birthday='1980-09-09',.....................
update  where id=1;
这个地方忘记写where,后果是很严重的。

五、删除表中的记录

删除表中名称为’zs’的记录。
delete from employee where username='bbb';

删除表中所有记录。
delete from employee;

使用truncate删除表中记录。
truncate table employee;

delete 和truncate table的区别
delete是把表中的记录一条一条地删除,truncate是摧毁表结构,再重建表结构

六、查询语句

查询表中所有学生的信息。
select * from student;

查询表中所有学生的姓名和对应的英语成绩。
select name,english from student;

过滤表中重复的英语数据。
select distinct english from student;

在所有学生总分上加10分特长分。
select name,(chinese+english+math)+10 from student;

统计每个学生的总分。
select name,(chinese+english+math) from student;

使用别名表示学生分数。
select name as 姓名,(chinese+english+math)+10 as 总分 from student;
select name 姓名,(chinese+english+math)+10  总分 from student;

查询姓名为王五的学生成绩
select * from student where name='王五';

查询英语成绩大于90分的同学
select * from student where english>'90';

查询总分大于200分的所有同学
select name from student where (chinese+english+math)>200;

查询英语分数在 80-90之间的同学。
select name from student where english>80 and english<90;
select name from student where english between 80 and 90;  == select name from student where english>=80 and english<=90;

查询数学分数为89,90,91的同学。
select * from student where math in(89,90,91);

查询所有姓李的学生成绩。
select * from student where name like '李%';
select * from student where name like '李_';

查询数学分>80,语文分>80的同学。
select * from student where math>80 and chinese>80;

对数学成绩排序后输出。
select name,math from student order by math;

对总分排序后输出,然后再按从高到低的顺序输出
select name 姓名,(chinese+english+math) 总分 from student order by (chinese+english+math) desc;
select name 姓名,(chinese+english+math) 总分 from student order by 总分 desc;

对姓李的学生成绩排序输出
select * from student where name like '李%' order by (chinese+english+math) desc;

统计一个班级共有多少学生?
select count(name) from student;
select count(*) from student;

统计数学成绩大于90的学生有多少个?
select count(*) from student where math>80;

统计总分大于250的人数有多少?
select count(*) from student where (chinese+english+math)>250;

关于 count的函数的细节 (count只统计有值的行,当统计列时,如果列值为空则不统计该列)

统计一个班级数学总成绩?
select sum(math) from student;

统计一个班级语文、英语、数学各科的总成绩
select sum(chinese),sum(english),sum(math) from student;

统计一个班级语文、英语、数学的成绩总和
select sum(chinese+english+math) from student;

统计一个班级语文成绩平均分
select sum(chinese)/count(*) from student;

统计一个班级语文成绩平均分
select avg(chinese) from student;

求一个班级总分平均分
select avg(chinese+math+english) from student;

求班级最高分和最低分
select max(chinese+math+english),min(chinese+math+english) from student;

对订单表中商品归类后,显示每一类商品的总价
select product,sum(price) from orders group by product;

查询购买了几类商品,并且每类总价大于100的商品
select product from orders group by product having sum(price)>100;

where和having的区别
两者都可用于过滤,但是where后面不能跟合计函数,having可以跟合计函数,一般和group by结合使用

七、定义约束

定义主键约束(每一个表必须有一个主键列,不允许为空,必须插入)
create table student
(
    id int  primary key,
    name varchar(40)
);

定义主键自动增长(程序员不用管定义为主键自动增长的字段,由数据库统管理,注意当删除了一条记录后再插入一条记录自动增长的字段会跳过之前出现过的值,因为已经加到那个值了,会

继续添加)
create table student
(
    id int  primary key auto_increment,
    name varchar(40)
);

定义唯一约束(该字段的值不能重复,如名字不能重复)
drop table student;
create table student
(
    id int primary key auto_increment,
    name varchar(40) unique
);

定义非空约束(该字段的值不能为空)
drop table student;
create table student
(
    id int primary key auto_increment,
    name varchar(40) unique not null
);

定义外键约束
create table husband
(
    id int primary key,
    name varchar(40)
);

create table wife
(
    id int primary key,
    name varchar(40),
    husband_id int,
    constraint husband_id_FK foreign key(husband_id) references husband(id)
);

八、在实际开发中数据库表的设计方案

一对多或多对一的对象存到数据库时,表的设计方案
部门和员工
create table department
(
    id int primary key,
    name varchar(40)
);

create table employee
(
    id int primary key,
    name varchar(40),
    salary decimal(8,2),
    department_id int,
    constraint department_id_FK foreign key(department_id) references department(id)
);

多对多对象的表的设计(老师和学生)
create table teacher
(
    id int primary key,
    name varchar(40),
    salary decimal(8,2)
);

create table student
(
    id int primary key,
    name varchar(40)
);

create table teacher_student
(
    teacher_id int,
    student_id int,
    primary key(teacher_id,student_id),
    constraint teacher_id_FK foreign key(teacher_id) references teacher(id),
    constraint student_id_FK foreign key(student_id) references student(id)    
);

一对一的对象的数据库设计
create table person
(
    id int primary key,
    name varchar(40)
);

create table idcard
(
    id int primary key,
    city varchar(40),
    constraint id_FK foreign key(id) references person(id)    
);

自连接的表
create table person
(
    id int primary key,
    name varchar(40),
    parent_id int,
    constraint parent_id_FK foreign key(parent_id) references person(id)
);

Mysql系列一:SQL入门的更多相关文章

  1. MySQL系列(七)--SQL优化的步骤

    前面讲了如何设计数据库表结构.存储引擎.索引优化等内存,这篇文章会讲述如何进行SQL优化,也是面试中关于数据库肯定会被问到的, 这些内容不仅仅是为了面试,更重要的是付诸实践,最终用到工作当中 之前的M ...

  2. mysql系列-⼀条SQL查询语句是如何执⾏的?

    ⼀条SQL查询语句是如何执⾏的? ⼤体来说,MySQL 可以分为 Server 层和存储引擎层两部分 Server 层 Server 层包括连接器.查询缓存.分析器.优化器.执⾏器等,涵盖 MySQL ...

  3. mysql系列3 SQL语法基础

    1.创建数据库(语法) 2.创建(数据库)表(语法) 复制新的空表举个例子: mysql> use course;Reading table information for completion ...

  4. 二:MySQL系列之SQL基本操作(二)

    本篇主要介绍SOL语句的基本操作,主要有分为 连接数据库,创建数据库.创建数据表.添加数据记录,基本的查询功能等操作. 一.针对数据库的操作 -- 1.连接数据库 mysql -uroot -p my ...

  5. 三:MySQL系列之SQL查询

    本篇主要介绍使用SQL查询数据库的操作,包括条件查询.排序.聚合函数.分组.分页.连接查询.自关联.子查询等命令操作. 首先我们先创建一个数据库.数据表.插入字段: --------这部分在上篇以及介 ...

  6. mysql之SQL入门与提升(二)

    在mysql之SQL入门与提升(一)我们已经有了些许基础,今天继续深化 先造表 SET NAMES utf8;SET FOREIGN_KEY_CHECKS = 0; -- -------------- ...

  7. MySQL入门——MySQL数据库和SQL语言

    MySQL入门——MySQL数据库和SQL语言 摘要:本文主要了解了MySQL关系型数据库和SQL语言的基本知识. MySQL数据库 简介 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB ...

  8. 无法复现的“慢”SQL《死磕MySQL系列 八》

    系列文章 四.S 锁与 X 锁的爱恨情仇<死磕MySQL系列 四> 五.如何选择普通索引和唯一索引<死磕MySQL系列 五> 六.五分钟,让你明白MySQL是怎么选择索引< ...

  9. mysql 开发进阶篇系列 1 SQL优化(show status命令)

    一.概述 随着上线后,数据越来越多,很多sql语句开始显露出性能问题,本章介绍在mysql中优化sql语句的方法.  1.  通过show status 命令了解各种sql的执行频率 通过show [ ...

随机推荐

  1. 潭州课堂25班:Ph201805201 WEB 之 HTML 第一课 (课堂笔记)

    什么是HTML 超文本标记语言(HyperText Markup Language,简称 HTML) HTML 是一门标记语言,标记语言由一套标记标签组成, 学习 HTML,其实就是学习标签 HTML ...

  2. webpack 练习笔记

    1, 创建项目 webpack mkdir webpack 2, 初始化项目 npm init 3, 全局安装webpack npm install webpack -g 4, 使用 // 创建静态文 ...

  3. 网站SSL证书在线检测

    网站SSL证书在线检测 http://web.chacuo.net/netsslcheck OpenSSL命令行工具的证书操作 http://blog.csdn.net/a351945755/arti ...

  4. 查看linux系统硬盘目录占用大小

    http://jingyan.baidu.com/article/3aed632e198ae870108091b4.html   du -sh /* 先看看根目录下面 du -sh /usr/* du ...

  5. Unity Shader-后处理:Bloom全屏泛光

    一.简介   今天来学习一下全屏Bloom效果,有时候也叫Glow效果,中文一般叫做“全屏泛光”,这是一种可以模拟出HDR的全屏后处理效果,但是实现原理与HDR相差很远,效果比HDR差一些,但是比HD ...

  6. shell自动补全功能:bash和zsh

    首要一点:shell有多种,比如bash.zsh.csh.ksh.sh.tcsh等 因此,制作自动补全功能时,要先搞清楚,你使用的是哪种shell,各个shell制作方法是不同的,网上大部分介绍的是关 ...

  7. 【Little Demo】左右按钮tab选项卡双切换

    通过前一篇文章 从简单的Tab标签到Tab图片切换 的说明,相关效果也就可以实现了. 1.左右按钮tab选项卡双切换 很明显,左右两个按钮是 absolute 布局,另外就是内容部分和Tab标签部分. ...

  8. 【Javascript Demo】图片瀑布流实现

    瀑布流就是像瀑布一样的网站——丰富的网站内容,特别是绚美的图片会让你流连忘返.你在浏览网站的时候只需要轻轻滑动一下鼠标滚轮,一切的美妙的图片精彩便可呈现在你面前.瀑布流网站是新兴的一种网站模式——她的 ...

  9. [Python设计模式] 第8章 学习雷锋好榜样——工厂方法模式

    github地址:https://github.com/cheesezh/python_design_patterns 简单工厂模式 v.s. 工厂方法模式 以简单计算器为例,对比一下简单工厂模式和工 ...

  10. MDX Step by Step 读书笔记(七) - Performing Aggregation 聚合函数之 Max, Min, Count , DistinctCount 以及其它 TopCount, Generate

    MDX 中最大值和最小值 MDX 中最大值和最小值函数的语法和之前看到的 Sum 以及 Aggregate 等聚合函数基本上是一样的: Max( {Set} [, Expression]) Min( ...