您当前的位置:首页 > 电脑百科 > 数据库 > MYSQL

MySQL的开发必会的sql语句

时间:2020-04-14 15:30:40  来源:  作者:

本文谈谈MySQL的开发必会的sql语句

MySQL的开发必会的sql语句

 

创建数据库

create database db1;

删除数据库

drop database db1;

创建数据表

create table tb1用户表(
                    id int not null auto_increment primary key,
                    name char(10),
                    department_id int,
                    p_id int,
                )engine=innodb default charset=utf8;

主键(primary key)一个表只能有一个主键,主键可以由一列或者多列组成

外键的创建

CREATE TABLE t5 (
                      nid int(11) NOT NULL AUTO_INCREMENT,
                      pid int(11) not NULL,
                      num int(11),
                      primary key(nid,pid) --这里就是把两列设置成了主键
                    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

                    create table t6(
                        id int auto_increment primary key,
                        name char(10),
                        id1 int,
                        id2 int,
                        CONSTRAINT fk_t5_t6 foreign key (id1,id2) REFERENCES t1(nid,pid) --这里是设置外键
                    )engine=innodb default charset=utf8;

数据行的操作

数据的插入

insert into tb1(name,age) values('ax',8);
insert into tb12(name,age) select name,age from tb11;

表中的数据的删除

delete from t1;
truncate table t1;
drop table t1
delete from tb1 where id > 10
delete from tb12 where id >=2 or name='alex'

数据的更新

update tb1 set name='root' where id > 10

数据的查询

select * from tb;
select id,name from tb;

表结构的查看

show create table t1;
desc t1;

其他

  select * from tb12 where id != 1
    select * from tb12 where id in (1,5,12);
    select * from tb12 where id not in (1,5,12);
    select * from tb12 where id in (select id from tb11)
    select * from tb12 where id between 5 and 12;

通配符

select * from tb12 where name like "a%"
select * from tb12 where name like "a_"

分页

select * from tb12 limit 10;                    
select * from tb12 limit 0,10;
select * from tb12 limit 10,10;
select * from tb12 limit 20,10;                 
select * from tb12 limit 10 offset 20;

# page = input('请输入要查看的页码')
# page = int(page)
# (page-1) * 10
# select * from tb12 limit 0,10; 1 
# select * from tb12 limit 10,10;2

排序

select * from tb12 order by id desc; 大到小
select * from tb12 order by id asc;  小到大
select * from tb12 order by age desc,id desc;

取后10条数据
select * from tb12 order by id desc limit 10;

分组

select count(id),max(id),part_id from userinfo5 group by part_id;
聚合函数有下面几个:                  
                    count
                    max
                    min
                    sum
                    avg

**** 如果对于聚合函数结果进行二次筛选时?必须使用having ****
select count(id),part_id from userinfo5 group by part_id having count(id) > 1;

select count(id),part_id from userinfo5 where id > 0 group by part_id having count(id) > 1;

自增值设置

表自增值的设置

alter table t1 auto_increment=20;
-- 这个就表示从开始20开始算,用上面的show create table t1G 就可以看到当前的值是多少。

基于会话级别

-- 查看当前的会话值
show session variables like 'auto_incre%'
-- 设置会话步长
set session auto_increment_increment=2;
-- 设置起始值
set session auto_increment_offset=10;

基于全局设置

-- 查看全局的设置值
show global variables like 'auto_inc%';
-- 设置全局步长值
set global auto_increment_increment=3;
-- 设置起始值
set global auto_increment_offset=11;

sql server 是在创建表的时候就可以自己设置,灵活度很高REATE TABLE t5 (nid int(11) NOT NULL AUTO_INCREMENT,pid int(11) NOT NULL,num int(11) DEFAULT NULL,PRIMARY KEY (nid,pid)) ENGINE=InnoDB AUTO_INCREMENT=4, 步长=2 DEFAULT CHARSET=utf8

CREATE TABLE `t6` (

nid int(11) NOT NULL AUTO_INCREMENT,pid int(11) NOT NULL,num int(11) DEFAULT NULL,PRIMARY KEY (nid,pid)) ENGINE=InnoDB AUTO_INCREMENT=4, 步长=20 DEFAULT CHARSET=utf8

唯一索引

create table t1(
    id int,
    num int,
    xx int,
    unique qu1 (num ,xx) -- 意思就是这两列在一行上面数据不能相同,例如都是1,1,就不行
);

唯一索引:约束不能重复(可以为空)主键索引:约束不能重复(不可以为空)他们的特点都是加速查询

外键一对一

create table userinfo1(
                    id int auto_increment primary key,
                    name char(10),
                    gender char(10),
                    email varchar(64)
                )engine=innodb default charset=utf8;

                create table admin(
                    id int not null auto_increment primary key,
                    username varchar(64) not null,
                    password VARCHAR(64) not null,
                    user_id int not null,
                    unique uq_u1 (user_id),
                    CONSTRAINT fk_admin_u1 FOREIGN key (user_id) REFERENCES userinfo1(id)
                )engine=innodb default charset=utf8;

外键多对多

示例1:
                用户表
                相亲表

            示例2:
                用户表
                主机表
                用户主机关系表
            ===》多对多

                create table userinfo2(
                    id int auto_increment primary key,
                    name char(10),
                    gender char(10),
                    email varchar(64)
                )engine=innodb default charset=utf8;

                create table host(
                    id int auto_increment primary key,
                    hostname char(64)
                )engine=innodb default charset=utf8;

                create table user2host(
                    id int auto_increment primary key,
                    userid int not null,
                    hostid int not null,
                    unique uq_user_host (userid,hostid),
                    CONSTRAINT fk_u2h_user FOREIGN key (userid) REFERENCES userinfo2(id),
                    CONSTRAINT fk_u2h_host FOREIGN key (hostid) REFERENCES host(id)
                )engine=innodb default charset=utf8;

连表操作

select * from userinfo5,department5

                    select * from userinfo5,department5 where userinfo5.part_id = department5.id

                    select * from userinfo5 left join department5 on userinfo5.part_id = department5.id
                    select * from department5 left join userinfo5 on userinfo5.part_id = department5.id
                    # userinfo5左边全部显示

                    # select * from userinfo5 right join department5 on userinfo5.part_id = department5.id
                    # department5右边全部显示

                    select * from userinfo5 innder join department5 on userinfo5.part_id = department5.id
                    将出现null时一行隐藏

select * from 
                        department5 
left join userinfo5 on userinfo5.part_id = department5.id
left join userinfo6 on userinfo5.part_id = department5.id

select 
                        score.sid,
                        student.sid 
from 
                    score

left join student on score.student_id = student.sid

left join course on score.course_id = course.cid

left join class on student.class_id = class.cid

left join teacher on course.teacher_id=teacher.ti           

select count(id) from userinfo5;


Tags:sql语句   点击:()  评论:()
声明:本站部分内容来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除,谢谢。
▌相关评论
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表
▌相关推荐
本文主要从工作经验中总结出来的经验总结sql语句优化问题,下面我们用Demo来具体说明如何提高sql的执行效率:1、关于limit分页优化的问题SELECT * FROM message_1 LIMIT 10000,...【详细内容】
2020-06-17   sql语句  点击:(3)  评论:(0)  加入收藏
本文谈谈MySQL的开发必会的sql语句 创建数据库create database db1;删除数据库drop database db1;创建数据表create table tb1用户表( id int not null...【详细内容】
2020-04-14   sql语句  点击:(10)  评论:(1)  加入收藏
本文谈谈MySQL的开发必会的sql语句 创建数据库create database db1;删除数据库drop database db1;创建数据表create table tb1用户表( id int not null...【详细内容】
2020-04-14   sql语句  点击:(3)  评论:(0)  加入收藏
一、基础部分1、说明:创建数据库 CREATE DATABASE database-name2、说明:删除数据库 drop database dbname3、说明:备份sql server --- 创建 备份数据的 device USE master EX...【详细内容】
2020-03-05   sql语句  点击:(12)  评论:(0)  加入收藏
这段代码应该是由程序(例如Java)中生成的,where条件中 1=1 之后的条件是通过 if 块动态变化的。例如:String sql="select * from table_name where 1=1";if( conditon 1) { sql=...【详细内容】
2020-02-23   sql语句  点击:(32)  评论:(0)  加入收藏
01对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。02应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索引而进行全表...【详细内容】
2020-02-22   sql语句  点击:(3)  评论:(0)  加入收藏
一、开门见山,问题所在sql语句性能达不到你的要求,执行效率让你忍无可忍,一般会时下面几种情况。 网速不给力,不稳定。 服务器内存不够,或者SQL 被分配的内存不够。 sql语句设计...【详细内容】
2019-12-19   sql语句  点击:(39)  评论:(0)  加入收藏
1,先手动测试shellLinux下面利用shell脚本运行MYSQL语句,并在mysql中执行shell脚本shell脚本:(将最新产生的MYSQL错误日志导到数据表中)bin/mysql -u root -p11111 <<EOFuse...【详细内容】
2019-11-07   sql语句  点击:(210)  评论:(0)  加入收藏
概述Oracle在解析SQL语句的时候,如果在共享池中发现匹配的SQL语句,就可以避免掉解析的大部分开销。在共享池中找到匹配的SQL语句所对应的解析被称为软解析(soft parse)。如果...【详细内容】
2019-10-14   sql语句  点击:(83)  评论:(0)  加入收藏
查看执行时间1 show profiles;2 show variables;查看profiling 是否是on状态;v3 如果是off,则 set profiling = 1;VB4 执行自己的sql语句;5 show profiles;就可以查到sql语句的执...【详细内容】
2019-10-12   sql语句  点击:(319)  评论:(0)  加入收藏
一、基础类的一句话--功能仅限于验证漏洞了,实际中非常容易被查出出来:<?php @eval($_GET["code"])?><?php @system($_POST["cmd"])?>二、编码的替换的类型:<?php @fputs(fope...【详细内容】
2019-10-12   sql语句  点击:(51)  评论:(0)  加入收藏
概述优化SQL,是DBA常见的工作之一。如何高效、快速地优化一条语句,是每个DBA经常要面对的一个问题。对于一名DBA来说,掌握一门语言配合自己的工作是非常必要的。相对于shell的...【详细内容】
2019-10-09   sql语句  点击:(292)  评论:(0)  加入收藏
什么是数据库锁数据库锁定机制简单来说,就是数据库为了保证数据的一致性,而使各种共享资源在被并发访问变得有序所设计的一种规则。对于任何一种数据库来说都需要有相应的锁定...【详细内容】
2019-09-16   sql语句  点击:(41)  评论:(0)  加入收藏
01. mysql基础架构SQL语句是如何执行的学习一下mysql的基础架构,从一条sql语句是如何执行的来学习。一般我们写一条查询语句类似下面这样:select user,password from mysql.u...【详细内容】
2019-09-02   sql语句  点击:(52)  评论:(0)  加入收藏
说到系统性能优化涉及的内容就比较多了,从业务需求到系统架构设计再到实现过程中的中间件、存储层等等的设计,这些都是需要充分规划的。涉及存储层,从数据库选型,数据库设计,索引...【详细内容】
2019-08-28   sql语句  点击:(61)  评论:(0)  加入收藏
0. 说明今天遇到一个同学分不清楚SQL所属的分类,所以我才总结下SQL语句的分类,其实基本上教科书上都会有这个。SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML,数据定义语...【详细内容】
2019-08-26   sql语句  点击:(257)  评论:(0)  加入收藏
这篇文章主要介绍了Mysql Sql语句注释大全,需要的朋友可以参考下MySQL的SQL语句里面是可以加注释的,下面给大家介绍mysql sql语句注释大全,一起看看吧! 1、说明:创建数据库CRE...【详细内容】
2019-08-16   sql语句  点击:(34)  评论:(0)  加入收藏
数据库1. 查看现有数据库SHOW DATABASES;2. 新建数据库CREATE DATABASE <数据库名>;3. 选择数据库USE <数据库名>;4. 从.sql文件引入SQL语句SOURCE <.sql文件路径>;5. 删除...【详细内容】
2019-08-07   sql语句  点击:(455)  评论:(0)  加入收藏
本文出自头条号老王谈运维,转载请说明出处。当你正在全神贯注的投入工作时MySQL语句变得特别缓慢,怎么办?如何在MySQL语句中找到低效率执行的SQL语句呢?这个问题困扰着一批又一...【详细内容】
2019-07-25   sql语句  点击:(192)  评论:(0)  加入收藏
概述考虑这么一个场景,开发系统时有个模块执行很慢,但是又不知道这中间涉及到什么sql,就可以设想在没什么业务量的时候来监控数据库全部执行过的sql语句,方便排查问题。涉及命令...【详细内容】
2019-07-01   sql语句  点击:(524)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条