Mysql基本查询、视图、索引、触发器
基本查询
1.修改
String sql="update smbms_user set userCode=?,userName=? where id=?";
2.删除用户
String sql="delete from smbms_user where id=?";
3.登录
select * from user where userName=#{userName} and userPassword=#{userPassword}
4.模糊查询
select * from smbms_bill WHERE productName like "%米%"
5.处理年龄
SELECT floor(DATEDIFF(NOW(),birthday)/365) as age, u.*,r.roleName as userRoleName from smbms_user as u,smbms_role as r WHERE u.userRole = r.id
6.查news表格,要求按主题生活(topic表格,有生活,娱乐等)分类,按创建时间降序查询,并取前5条
SELECT * from news WHERE ntid=1 ORDER BY ncreateDate ASC LIMIT 0,6;
7.查全部新闻按降序排序,并取前5条
SELECT * from easybuy_news ORDER BY createTime DESC LIMIT 0,5;
8.通过用户的id来查地址
select * from easybuy_user_address where userId=#{id}
9.插入
INSERT INTO ebook_category(id,name) VALUES(2,"oracle");
INSERT INTO ebook_entry(id,categoryId,title,summary,uploaduser,createdate) VALUES(2,1,"美食","美食摘要","tome",NOW());
10.创表
create table product(
pid int(4) primary key auto_increment,
name VARCHAR(20),
catalog_name varchar(20),
price int(10),
picture varchar(20) );
sql语句-视图
#视图。就是一个虚拟表,便于我们对数据进行处理。对视图的DML操作会改变基表数据,但不能改变基表结构,如加字段
为什么要使用视图:
<1>安全原因:限制数据的访问(如:社会保险基金表,可以使用视图只显示姓名和地址,而不显示社会的保险号和工资)
<2>减少复杂的slq语句查询,一般是用查询结果集返回作为视图
例:
create view empnew_view as select eid,ename,salary from emp //创建视图
select * from empnew_view; //查询视图
insert into empnew_view(eid,ename,salary) values(99,'qi1qi',66) //DML操作
update emp set ename="qiqi1" where eid=88 //DML操作
delete from emp where eid=88 //DML操作
DESC v;
#索引,方便我们的快速查找,方便我们快速查找,对SQL非常有帮助,并不是所有字段都用索引,
//前提,这个字段经常被当做查询对象操作,是一个表里面不是索引越多越好,根据你的具体,项目来设置,一张表里面与其他表有关系重合的,不适合加索引
#查看所有所有 index
SHOW INDEX FROM result;
TABLE 表 第二个字段0不可以重复,1代表可以重复
第三个参数:索引名字 第四个是索引下标,从1开始 第五个:字段名 第六个:排序规则, 默认是a
sql语句-触发器
//创建一个空部门表
CREATE TABLE emp(
eid INT(4),
ename VARCHAR(20),
epwd VARCHAR(20),
edate DATE
);
ALTER TABLE emp ADD salary DOUBLE(5,2);
INSERT INTO emp(eid,ename,epwd) VALUES (1,"aa","123");
#创建绩效表
CREATE TABLE jixiao(
jname VARCHAR(20),
jmoney DOUBLE(5,2)
);
#创建触发器:就相当于你的闹钟,在插入数据之前执行,当emp表插入数据的时候,另一个jixiao表也同时插入数据
CREATE TRIGGER t_money BEFORE INSERT ON emp FOR EACH ROW
INSERT INTO jixiao VALUES(new.ename,new.salary*0.5);
#创建触发器2:
CREATE TRIGGER t_mo BEFORE INSERT ON emp FOR EACH ROW
UPDATE emp SET money=new.money;
INSERT INTO emp(eid,ename,salary) VALUES(11,"ee",20);
UPDATE jixiao SET money=1;
SELECT * FROM jixiao;
#删除触发器
DROP TRIGGER t_money;
#展示触发器
SHOW TRIGGERS;
sql语句---索引
//创建一个主键索引(唯一,不能为空,不一定是INT)
ALTER TABLE emp ADD PRIMARY KEY(eid);
SHOW INDEX FROM emp;
//唯一索引(主键索引在一张表里只能有一个,唯一索引可以有多个);
#创建唯一索引,#在添加唯一索引时,乱码添加不成功
ALTER TABLE emp ADD UNIQUE(ename);
#删除索引
ALTER TABLE emp DROP INDEX ename;
#全局索引作用:便于我们快速查找到某一行
ALTER TABLE emp ADD INDEX(epwd);
Mysql基本查询、视图、索引、触发器的更多相关文章
- mysql八:视图、触发器、事务、存储过程、函数
一 视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,可以将该结果集当做表来使用. 使用视图我们可以把查询过程中的 ...
- Oracle-序列-存储过程-视图-索引-触发器
课程介绍 1. 约束(掌握) 2. 序列(掌握) 3. 索引(掌握) 4. 视图(掌握) 5. 存储过程(掌握) 6. 自定义函数(掌握) 7. 触发器(掌握) 数据库对象的命名规则 1.对象名称必须 ...
- mysql七:视图、触发器、事务、存储过程、函数
阅读目录 一 视图 二 触发器 三 事务 四 存储过程 五 函数 六 流程控制 一 视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名 ...
- Mysql(七):视图、触发器、事务、存储过程、函数
一 视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,可以将该结果集当做表来使用. 使用视图我们可以把查询过程中的 ...
- mysql数据库之视图、触发器
视图 概念:通过查询得到的一张虚拟表,然后保存下来就是视图 视图的好处:如果要频繁使用某张虚拟表,那么就可以保存为视图,以后查找就直接拿这个视图就会非常方便 视图语法规则: create view t ...
- 关于阿里云Mysql分页查询不走索引的问题
需要修改阿里云中的MYSQL 配置参数 : eq_range_index_dive_limit 阿里云上默认是 10 , 这个参数 表示 in 查询 条件超过 10 个 就不走索引,走全表扫描.如果我 ...
- MySQL高级查询之索引创建、删除、增加、修改、慢sql、explain解释sql
day04数据库 昨日知识点回顾 1.单表操作 1.单表的操作 条件查询的优先级别: where > group by >having > order by > limit; ...
- mysql延迟查询, 覆盖索引使用例子
引用自 'mysql高性能' 5.3.6章节 不能使用覆盖索引的情况 : 解决办法 :
- MySQL like查询使用索引
在使用msyql进行模糊查询的时候,很自然的会用到like语句,通常情况下,在数据量小的时候,不容易看出查询的效率,但在数据量达到百万级,千万级的时候,查询的效率就很容易显现出来.这个时候查询的效率就 ...
- MySQL知识补充(表字段操作、视图、触发器、事物、存储过程、内置函数、流程控制、索引、慢查询)
今日内容概要 表字段操作补充(掌握) 视图(了解) 触发器(了解) 事务(掌握) 存储过程(了解) 内置函数(了解) 流程控制(了解) 索引(熟悉) 内容详细 1.表字段操作补充 # 1.添加表字段 ...
随机推荐
- ECMA262学习笔记(一)
Question1:怎样理解ECMAScript对象? Answer:ECMAScript对象是属性的集合,每个属性又有零个或者多个特性(如:writable).属性是持有其他对象.原始值.函数的容器 ...
- 线程池ThreadPoolExecutor源码分析
在阿里编程规约中关于线程池强制了两点,如下: [强制]线程资源必须通过线程池提供,不允许在应用中自行显式创建线程.说明:使用线程池的好处是减少在创建和销毁线程上所消耗的时间以及系统资源的开销,解决资源 ...
- 密码与安全新技术专题之AI与密码
20189217 2018-2019-2 <密码与安全新技术专题>第五周作业 课程:<密码与安全新技术专题> 班级: 1892 姓名: 李熹桥 学号:20189214 上课教师 ...
- css响应式
<meta name="viewport" content="width=devicw-width,initial-scale=1.0"> 响应式图 ...
- SAS 分组与排序
SAS 分组与排序 SAS对数据集进行操作时,经常需要在SET.MERGE.MODIFY或 UPDATE语句中使用分组数据.使用分组数据最基本的方法是使用BY 语句,其基本形式如下: BY 变量列表; ...
- VMware Workstation:安装windows xp系统
https://blog.csdn.net/nicergj/article/details/83651603
- Git和Eclipse的使用、上传、部署
https://www.jianshu.com/p/812717c740a2 https://blog.csdn.net/lynn_Kun/article/details/73740400 https ...
- Appium系列文章(1)获取appPackage和appActivity
appPackage和appActivity 进行appium自动化测试非常重要的两个参数,我们所测试的APP不同,这两个参数肯定也是不一样的.那如何快速的获取这APP的这两个参数呢? 通过cmd命令 ...
- Lab keepalived
[root@node1 keepalived]#cat keepalived.conf ! Configuration File for keepalived global_defs { notifi ...
- windows和ubuntu下git commit提交后如何保存和退出,回到命令行
问题一: windows下git commit后会进入vim界面,不知道怎么操作 解决办法: 1.输入小写字母i,此时进入编辑模式,可以输入你想输入的内容 2.按下esc键,此时退出编辑模式,输入英文 ...