iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL SQL使用技巧
  • 342
分享到

MySQL SQL使用技巧

2024-04-02 19:04:59 342人浏览 独家记忆
摘要

须知:sql语言:结构化查询语言,是关系型数据库查询语言的标准,不同的数据库虽然有自己私有扩展,但关键词都支持:(select、update、delete、insert、where)SQ

须知:

sql语言:结构化查询语言,是关系型数据库查询语言的标准,不同的数据库虽然有自己私有扩展,但关键词都支持:(select、update、delete、insert、where)

SQL语句分类:像oracle、MSSQL都是通用的

DDL:数据定义语言(create、alter、drop、rename)

DML:数据库维护语言(select、insert、update、delete)

DCL:数据库控制语言,权限(Grant、revoke)

TCL:事务控制语言(commt、sarepqint):新型的语句

一、数据库增删改查

根据这个表结构以下来操作:

Mysql> select * from user;

+----+----------+------+

| id | name     | pass |

+----+----------+------+

基本操作

1.创建数据库

create database name;

2.删除数据库

drop database name;

3.创建一个用户表

create table user(id int,name varchar(30),pass varchar(30));

4.插入数据

insert into user(id,name,pass) values("1","zhangsan","123");

5.删除一个表

drop table user;

6.查看表字段

desc table user;

7.查看表数据

select * from user;

8.修改表名

rename table user to tab1;

9.更新数据

update user set pass="newpass" where pass=123;  #把密码更新为newpass

update user set id=10,name='lisi' where id=1;   #把id记录的name更新为id10和name为lisi

10.重命名字段名

alter table user change pass newname varchar(30); 

11.表中添加一个字段

alter table user add age int;

12.修改字段

alter table user modify age int no null default 20; #当年龄输入为空时,默认为20岁

13.删除表中的一个字段

alter table user drop age;

14.删除一条记录

delete from user where id=1;

15.查找一条记录

select id,name,pass from user where id=1;

16.删除ID记录

delete from user where id>=3 id<=5;             #删除大于3小于5的id

delete from user where id in(1,3,5);            #删除1,3,5的id

delete from user where id=1 or id=3 or id=5;       #删除1,3,5的id

delete from user where id between 1 and 5;       #删除1至5的id

高级查询

1.返回结果删除重复项

select distinct id from user;

2.查询字段中为NULL

select * from where pass is null;  

select * from where pass is not null; #查询不为NULL的

3.like模糊查询,包含zhang的列出来

select * from user where name like '%zhang%';

select * from user where name like '%zhang%' or name like '%li%';#查找包含zhang或li的列出来

也可以使用正则表达式查询,生产环境一般不用的,因为查询慢,效果一样

select * from user where name regexp 'li';
4.使用order by对查询结果排序(升序/降序),默认是升序

select id,name,pass from user order by id asc/desc;

5.使用limit取出排名前三个

select * from user  order by id desc limit 3;

6.concat函数使用-字符串连接符

mysql> select id,name,pass,concat(id,'_',name) idname from user;

+----+----------+------+------------+

| id | name     | pass | idname     |

+----+----------+------+------------+

|  1 | zhangsan | 123  | 1_zhangsan |

|  2 | lisi     | 123  | 2_lisi     |

|  3 | zhaowu   | 123  | 3_zhaowu   |

+----+----------+------+------------+

7.rand函数随机排序,如随机抽取前三名

select * from user order by rand() limit 3;

8.count统计,如统计多少个id记录

select count(*) count from user; 

#count为自定义显示查询结果后字段名,*为mysql优化后的查询方法,要比直接写入id效率高

select count(id) from user where name='zhangsan'; #统计zhangsan多少条记录

9.sum求和,如统计同消费了多少钱

select sum(id) from user where name='lisi';  #所有id数加在一起

10.avg平均数,如求班级平均分

select avg(id) from user;  

11.max最大值,如得到一个最高分

select max(id) from user;

12.min最小值

select min(id) from user;

13.group by分组聚合

select name,count(id) from user group by name order by desc;  

#使用count来聚合,基于name分组,再order by排序下(一般排名都使用分组聚合)

select name,count(id) count from user group by name having count>=3;

#查询前三名,having是对分组的结果进行筛选,这不能用where,count代表查询结果后显示的字段名

14.普通多表查询(前提:两个表必须有关系)

先创建两个有关系的表:

create table user(id int unsigned auto_increment primary key,name varchar(30),age int);

create table post(id int unsigned auto_increment primary key,uid int,title varchar(200),content text);

结果一:查询用户发的所有记录

select user.name,post.title,post.content from user,post where user.id=post.uid;

结果二:统计每个用户有多少个记录

select user.name,post.title,post.content count(id) from user,post where user.id=post.uid group by user.name;

15.联表查询(查询成绩)

mysql> select * from tb1;

+------+----------+

| id   | name     |

+------+----------+

|    1 | zhangsan |

|    2 | lisi     |

+------+----------+

mysql> select * from tb2;

+------+-------+

| id   | score |

+------+-------+

|    1 |    80 |

|    2 |    81 |

+------+-------+

mysql> select tb1.name,tb2.score from tb1,tb2 where tb1.id = tb2.id;

+----------+-------+

| name     | score |

+----------+-------+

| zhangsan |    80 |

| lisi     |    81 |

+----------+-------+

二、表字段类型

1.数值

int(size):整型,只能存整数数字,不能为空,默认允许输入null,也可以设置不允许写(not null)

float:浮点型,可以写入整数或浮点数

1.1字段属性

unsigned:无符号,全是整数

zerofill:与长度无关,不够3位时前面补0,默认看不见

null与not null:允许输入null和不允许输入

default:不允许null情况下,当输入空时,则使用默认值

auto_increment:一般自增ID

1.2示例

例如,设置id为自增:

create table user(id int unsigned auto_increment primary key,name varchar(30),pass varchar(30));

primary key:有auto_increment必须设置为主键索引,提供查询速度,再插入就不用写id列了,如果你写了,就以你写的为准,继续自增。

例如,创建一个表,当输入性别为空时,默认则为男:

create table user2(id int unsigned auto_increment primary key,name varchar(30),sex varchar(5) not null default "nan");

查看字段信息:

mysql> desc user2;

+-------+------------------+------+-----+---------+----------------+

| Field | Type             | Null | Key | Default | Extra          |

+-------+------------------+------+-----+---------+----------------+

| id    | int(10) unsigned | NO   | PRI | NULL    | auto_increment |

| name  | varchar(30)      | YES  |     | NULL    |                |

| sex   | varchar(5)       | NO   |     | nan     |                |

+-------+------------------+------+-----+---------+----------------+

3 rows in set (0.00 sec)

2.字符串

char(size):占用size的字节,但查询速度快,最大支持255个字符

varchar(size):存多少占多少,剩点空间,最大支持65535个字符

text:支持65535字节

longtext:支持42亿字节

3.日期类型(有的会使用int类型来存时间戳)

以下是官方说法占用的字节,但实际会有不符。

date:年月日,占用3个字节

time:时分秒,占用3个字节

datetime:年月日时分秒,占用8个字节

year:年,占用1个字节

三、用户管理

1.设置Mysql密码

方法一:set passWord=password('newpass');

方法二:update user set password=password('newpass') where user='root';

方法三:grant all on *.* to 'root'@'localhost' identified by 'newpass';

再刷新:flush privileges;

2.创建用户并授权

grant all privileges on *.* to 'user'@'localhost' identified by 'pass';

*.*:对应的是数据库/表的权限

localhost:只允许本地访问,也可以设置%为所有访问

3.撤销用户权限

revoke all privileges on *.* from 'root'@'localhost' identified by 'pass';

四、数据库字符集

1.查看服务器基本信息\s

1
您可能感兴趣的文档:

--结束END--

本文标题: MySQL SQL使用技巧

本文链接: https://www.lsjlt.com/news/36736.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Mysql中写sql的技巧
    这篇文章将为大家详细讲解有关Mysql中写sql的技巧,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。前言每一个好习惯都是一笔财富,本文分SQL后悔药, SQL性能优化,S...
    99+
    2024-04-02
  • SQL数据库的使用技巧
    本篇内容主要讲解“SQL数据库的使用技巧”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“SQL数据库的使用技巧”吧!应该使用哪种方法创建用户?  创建用户有几种方...
    99+
    2024-04-02
  • MS SQL使用技巧有哪些
    这篇文章主要介绍MS SQL使用技巧有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!判断某个表中是否存在某列if exists (select * from sysco...
    99+
    2024-04-02
  • MYSQL sql的技巧与避坑
    文章目录 1.使用union还是or2.可以为NULL字段的逻辑判断3.in和exists的选择4.if和case的使用5.删除表中重复的记录,只保留id最小的6.字符串函数7.group_concat 批量连接8.rli...
    99+
    2023-08-16
    mysql sql 数据库
  • SQL中INSERT语句的使用技巧
    以下是一些在使用INSERT语句时的技巧:1. 指定要插入数据的列:可以在INSERT语句中指定要插入数据的列,这样可以确保插入的数...
    99+
    2023-09-22
    SQL
  • PL/SQL DEVELOPER 使用的技巧有哪些
    今天就跟大家聊聊有关PL/SQL DEVELOPER 使用的技巧有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1,登录后默认自动选中My Ob...
    99+
    2024-04-02
  • mysql sql优化的技巧有哪些
    以下是一些MySQL SQL优化的常见技巧: 使用索引:为频繁使用的列创建索引,以提高查询性能。可以使用EXPLAIN语句来分析查...
    99+
    2024-04-09
    mysql
  • MySQL的使用技巧有哪些
    这篇文章主要介绍“MySQL的使用技巧有哪些”,在日常操作中,相信很多人在MySQL的使用技巧有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL的使用技巧有哪些”...
    99+
    2024-04-02
  • MySQL中的使用技巧有哪些
    这篇文章主要介绍“MySQL中的使用技巧有哪些”,在日常操作中,相信很多人在MySQL中的使用技巧有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL中的使用技巧有...
    99+
    2024-04-02
  • 分享MySQL中锁的使用技巧
    MySQL 锁的使用技巧分享随着数据库应用的日益广泛,对数据库的并发控制和数据完整性要求也越来越高。在MySQL数据库中,锁是一种重要的并发控制手段,可以有效地保护数据的完整性和一致性。本文将对MySQL锁的使用技巧进行详细分享,并提供具体...
    99+
    2023-12-21
    MySQL 技巧
  • sql左连接和右连接的使用技巧
    这篇文章主要介绍“sql左连接和右连接的使用技巧”,在日常操作中,相信很多人在sql左连接和右连接的使用技巧问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”sql左连接和右连接...
    99+
    2024-04-02
  • SQL查询的技巧
    这篇文章主要介绍SQL查询的技巧,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1、行列转换问题:假设有张学生成绩表(tb)如下:想变成(得到如下结果): 代码:WITH t...
    99+
    2024-04-02
  • 如何使用SQL查询视图,Postico使用技巧分享~
    Postico凭借着简单易用的操作界面深受专业人员和新手的喜爱,小编也整理一点小技巧分享给大家,通过一次编辑多行节省时间,是你工作的好帮手,快来一起看看吧~ 如何使用SQL查询视图,Postico使用技...
    99+
    2024-04-02
  • kindle3使用技巧
    开关机: 滑动开关键到右面,停住,等几秒就关机了,开机也是一样操作。 3G上网: 按照网上的帖子在Amazon注册之后,浏览网页的时候却出现了这个提示: Due to local restrictions, web browsi...
    99+
    2023-01-31
    使用技巧
  • PyChram使用技巧
    1、打开当前文件路径 project-->右键-->Show in Explorer 2、修改字体大小 a、工作台字体: file-->setting-->editor-->colors&fonts...
    99+
    2023-01-30
    使用技巧 PyChram
  • thickbox使用技巧
    以下是一些使用Thickbox的技巧:1. 引入Thickbox库:在网页的头部引入Thickbox的CSS和JavaScript文...
    99+
    2023-09-08
    thickbox
  • MySQL特殊函数使用技巧梳理
    目录1. group_concat2. char_length3.locate4.replace5.now6.insert into … select7.in...
    99+
    2023-05-20
    mysql特殊函数 mysql特有函数 mysql特有语句
  • MySQL 中行列转换的SQL技巧有哪些
    这篇文章给大家分享的是有关MySQL 中行列转换的SQL技巧有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。行列转换常见场景 由于很多业务表因为历史原因或者性能原因,都使用...
    99+
    2024-04-02
  • PyCharm使用小技巧
    本文部分内容参考了明宇李前辈的博客,原文请阅读 Pycharm的配置(背景颜色,字体,解释器等); 鼠标滑轮控制字体大小 部分参考了墨颜前辈的博客,原文请阅读 用鼠标滑轮控制代码字体大小; 感谢各位前辈的分享。除此之外,其余均为自己平时使...
    99+
    2023-01-31
    小技巧 PyCharm
  • mysql存储过程有哪些使用技巧
    mysql存储过程有哪些使用技巧?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!mysql存储过程使用技巧有:1、创建带in...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作