通过sql语句对MySql数据库的基本操作
一、数据库的基本操作
CREATE DATABASE mybookstore;
DROP DATABASE mybookstore;
二、表的基本操作
1、创建表
insert into 表名(字段名1,字段名2) values(值1,值2);
CREATE TABLE student(
id INT,
`name` VARCHAR(50)
);
2、删除表
delete from 表名 where语句;
DROP TABLE student;
3、修改表
update 表名 set 字段名1=字段值,字段名2=字段值 where语句
update dept set dept_name='人事部门' where id=4
4、查询表
select 字段名1,字段名2 from 表名 where语句
SELECT * FROM stu WHERE id=3;
三、表查询关键字
1、关键字使用及SQL语句顺序
select 列名1,列名2...
from 表1
join 表2
on 连接条件
where 过滤条件
group by 分组条件1,分组条件2
having 聚合函数过滤
order by 排序列1,排序列2
limit 分页
2、执行顺序:from—>on—>join—>where—>group by—>with—>having—>select—>distinct—>order by —>limit
四、约束
1、主键[primary key ]:可以唯一的表示一行数据,可以快捷的检索到一条数据!(唯一、非空、可以被引用)
2、自增:auto_increment:自增仅仅适用于数值类型的值!
3、非空:not null :表示当前字段值不能为null
4、唯一:unique:表示当前字段值必须是唯一的
5、注意一点:约束必须放在列名类型后面,至于多个约束的顺序无所谓!
6、外键:
外键关联指的是将一个表中的列和另一个表的主键进行关联!
1)一对一
经典案例:夫妻
/*一对一:夫妻*/
CREATE TABLE husband(
id INT PRIMARY KEY AUTO_INCREMENT,
`name` VARCHAR(20) NOT NULL
); INSERT INTO husband VALUES(1,'张三');
INSERT INTO husband VALUES(2,'王五'); CREATE TABLE wife(
id INT PRIMARY KEY AUTO_INCREMENT,
`name` VARCHAR(20) NOT NULL,
FOREIGN KEY(id) REFERENCES husband(id)
);
INSERT INTO wife VALUES(1,'李四');
INSERT INTO wife VALUES(2,'赵六');
INSERT INTO wife VALUES(1,'李静'); /*由于一对一约束,此行插入失败*/
2)一对多[多对一]
通常是在多的一端关联一的主键!通常将外键建在多的一端!
经典案例:部门表与员工表 dept& emp
/*一对多:员工-部门*/
DROP TABLE dept;
CREATE TABLE dept(
id INT PRIMARY KEY AUTO_INCREMENT,
dept_name VARCHAR(10) NOT NULL UNIQUE
);
INSERT INTO dept VALUES(NULL,'开发部门'); DROP TABLE emp;
CREATE TABLE emp(
id INT PRIMARY KEY AUTO_INCREMENT,
`name` VARCHAR(30) NOT NULL UNIQUE,
dept_id INT ,
FOREIGN KEY(dept_id) REFERENCES dept(id)
);
INSERT INTO emp VALUES(NULL,'张三',1);
INSERT INTO emp VALUES(NULL,'李四',1);
INSERT INTO emp VALUES(NULL,'王五',1);
3)多对多
经典案例:教师 学生
/*多对多:教师-学生*/
CREATE TABLE teacher(
id INT PRIMARY KEY AUTO_INCREMENT,
`name` VARCHAR(20) NOT NULL
);
INSERT INTO teacher VALUES(NULL,'李老师');
INSERT INTO teacher VALUES(NULL,'刘老师');
INSERT INTO teacher VALUES(NULL,'王老师'); CREATE TABLE student(
id INT PRIMARY KEY AUTO_INCREMENT,
`name` VARCHAR(20) NOT NULL
);
INSERT INTO student VALUES(NULL,'严涛');
INSERT INTO student VALUES(NULL,'杨涛');
INSERT INTO student VALUES(NULL,'邹梦洁'); CREATE TABLE tea_stu(
tea_id INT,
stu_id INT,
FOREIGN KEY(tea_id) REFERENCES teacher(id),
FOREIGN KEY(stu_id) REFERENCES student(id)
);
INSERT INTO tea_stu VALUES(1,1);
INSERT INTO tea_stu VALUES(1,2);
INSERT INTO tea_stu VALUES(1,3);
INSERT INTO tea_stu VALUES(2,1);
INSERT INTO tea_stu VALUES(2,1);
五、连接方式
横向连接:join on
纵向连接:union、union all,对应的字段列数、类型必须一致
union all不包含去重功能,而union会自动去重
通过sql语句对MySql数据库的基本操作的更多相关文章
- 如何用SQL语句实现Mysql数据库的备份与还原
以前一直做android客户端的项目,根本没有开发asp.net mvc的开发,现阶段做了一个模块,参数设置,以及数据库的备份与还原.其需求如下: 参数设置 本项参数设置为对自动数据备份进行设置,管理 ...
- 使用SQL语句修改Mysql数据库字符集的方法
使用SQL语句修改Mysql数据库字符集的方法 修改库: alter database [$database] character set [$character_set] collate [$c ...
- Linux centosVMware mysql用户管理、常用sql语句、mysql数据库备份恢复
一.mysql用户管理 grant all on *.* to 'user1'@‘127.0.0.1’ identified by 'mimA123'; 创建user1用户 使用user1登录 /us ...
- sql语句(Mysql数据库)
Mysql数据库的sql语句: 一.基本操作 1.连接数据库 mysql -uroot -proot -hlocalhost -P3306 (-u表示用户名,-p密码,-h主机,-P端口号) 2.选择 ...
- MySQL用户管理、常用sql语句、MySQL数据库备份恢复
1.MySQL用户管理 给远程登陆用户授权:grant all on *.* to 'user1'@'127.0.0.1' identified by '123456' (这里的127.0.0.1是指 ...
- SQL语句对MySQL数据库的操作之对数据库层面的操作
一.数据库内部存储结构 字段->数据表->数据库->MySQL服务器 二.登录及退出数据库 mysql -h服务器地址 -u用户名 -p密码(这样的登录形式并不安全) mysql - ...
- SQL语句,mysql数据库
sql语句,把一张表里的数据,和特定数据(固定常量)新插入另一张表 ,,, from wm_jobpoint INSERT INTO wm_department(departmentcode,depa ...
- Python使用sql语句对mysql数据库多条件模糊查询
1 def find_worldByName(c_name,continent): 2 print(c_name) 3 print(continent) 4 sql = " SELECT * ...
- SQL语句大全(mysql,sqlserver,oracle)
SQL语句大全 --语句功能--数据操作SELECT --从数据库表中检索数据行和列-selectINSERT --向数据库表添加新数据行-insertDELETE --从数据库表中删除数据行-del ...
随机推荐
- Chrome_01_点击 Google搜索结果在新的页面打开
方法一:Ctrl + 左键 Chrome浏览器中,通过 Ctrl + 左键 ,是在新标签中打开的,通过 Shift + 左键 ,是在新窗口中打开的. 方法二: 1.登录 Google 2.进入下面的设 ...
- django--mysql配置
配置mysql的过程中出现了许多错误,通过以下配置,解决问题: python3不能直接调用MySQLdb,所以需要安装pymysql,并在jango项目文件__init__.py中加入: import ...
- cocos2d-x 中 xml 文件读取
实现类 CXmlParse 啥也不说了 直接上硬货 believe yourself 一看就明白 CXmlParse.h #ifndef __C_XML_PARSE__ #define __C ...
- 微信非全屏播放设置(仅Iphone)
由于微信X5内核强制视频全屏,用X5自带内核播放,一般内嵌视频打开播放就会被全屏. ihpone里面可以通过设置 x-webkit-airplay="true" webkit-pl ...
- freeMarker(十二)——模板语言补充知识
学习笔记,选自freeMarker中文文档,译自 Email: ddekany at users.sourceforge.net 1.特殊变量参考 特殊变量是由FreeMarker引擎自己定义的变量. ...
- FFMPEG实现的转码程序
本例子是由FFEMPG的doc/example例子transcode.c修改而来,可以根据需求任意转换音视频的编码. 原来的例子的作用更类似于remux,并没有实现转码的功能,只是实现了格式转换,比如 ...
- bzoj 3533: [Sdoi2014]向量集 线段树维护凸包
题目大意: http://www.lydsy.com/JudgeOnline/problem.php?id=3533 题解: 首先我们把这些向量都平移到原点.这样我们就发现: 对于每次询问所得到的an ...
- MySQL5.7出现Your password has expired. To log in you must change it using a client that supports expir
今天晚上本来想写bootstrap-fileinput插件集成fastdfs的文章,但是刚启动idea里面的QiYuAdmin就出现了错误: Your password has expired. To ...
- 人物-IT-马云:马云
ylbtech-人物-IT-马云:马云 马云 (阿里巴巴集团创始人) 马云,男,汉族,中共党员,1964年9月10日生于浙江省杭州市,祖籍浙江省嵊州市谷来镇, 阿里巴巴集团主要创始人,现担任阿里巴巴集 ...
- Python知识点: os.popen
用例:f = os.popen("%s %s %s" % ("pkg-config", " ".join(args), mod)) pope ...