sql语句(Mysql数据库)
mysql -uroot -proot -hlocalhost -P3306 (-u表示用户名,-p密码,-h主机,-P端口号)
查看数据库列表: SHOW DATABASES;
选择数据库: USE 数据库名;
SHOW TABLES;
4.查看表结构:
方式一:SHOW COLUMNS FROM 表名;
方式二:DESCRIBE(DESC) 表名;
SHOW GRANTS ,查看用户权限
SHOW ERROR和SHOW WARNINGS ,显示服务器错误或警告信息
SELECT stu_name
FROM students;
FROM students;
SELECT *
FROM students;
FROM students;
FROM students
LIMIT 5;
----------------------------------------------------------------------
SELECT stu_name --limit关键字实现分页查询(两个参数)
FROM students
LIMIT 0,5;
SELECT stu_name --limit关键字实现分页查询
FROM students
LIMIT 5,5;
FROM students
LIMIT 5 OFFSET 0; --mysql5的新替代方法(取o行开始的5行)
FROM products
ORFER BY prod_name;
-----------------------------------------------------------
SELECT prod_id,pro_price,prod_name --多列排序
FROM products
ORFER BY prod_price,prod_name; --排序顺序按照指定顺序排序,先对prod_price排序,后对prod_name排序,如果prod_price列的所有值都是唯一的,则不会对prod_name排序
---------------------------------------------------------
SELECT prod_id,pro_price,prod_name --多列排序
FROM products
ORFER BY prod_price DESC,prod_name; --指定排序规则(DESC降序,ASC升序,Mysql默认升序排序)
---------------------------------------------------------
ORDER BY 和 LIMIT 组合实现查询一个列的中的最高或最低的值。
找出最珍贵物品的值:
SELECT prod_price
FROM products
PRDER BY prod_price DESC
LIMIT 1;
-------------------------------------------
SELECT prod_price,prod_name
FROM product
WHERER prod_price = 2.5;
-----------------------------------
WHERE字句操作符
操作符 说明
= 等于
<> 不等于
!= 不等于
> 大于
>= 大于等于
< 小于
<= 小于等于
BETWEEN 在指定的两个值之间
----------------------------------------------------------
SELECT prod_price,prod_name
FROM product
WHERER prod_name = 'fuses';
因为Mysql在执行匹配时默认不区分大小写,所以Fuses也会被返回
----------------------------------------------------------
空值检查
查询价格为空值的产品的名称:
SELECT prod_name
FROM prodects
WHERE prod_price IS NULL;
------------------------------------------
SELECT prod_name,prod_price
FROM products
WHERE vend_id in (1002,1003)
ORDER BY prod_name;
SELECT prod_name,prod_price
FROM products
WHERE vend_id = 1002 OR vend_id = 1003
ORDER BY prod_name;
IN操作符的语法更清楚且直观。
使用IN,计算的次序更加容易管理。
IN操作符一般比OR操作符执行更快。
IN最大的优点是可以包含其他SELECT语句,是的能够动态的建立WHERE字句。
SELECT prod_name,prod_price
FROM products
WHERE vend_id NOT IN (1002,1003)
ORDER BY prod_name;
---------------------------------------------------------------------------
LIke 用来只是Mysql说明后面的检索条件是使用通配符
通配符有两种:
% 匹配任意个数的字符
_ 匹配单个字符
from products
where prod_name like '%jes%';
尽量不要在搜索模式的开始处使用,把通配符至于搜索的开始处,搜索起来是最慢的。
检索出列prod_mame包含文本1000的所有的行:
SELECT prod_name
FROM products
WHERE prod_name REGEXP '1000'
ORDER BY prod_name;
SELECT prod_name
FROM products
WHERE prod_name LIKE '%1000%'
ORDER BY prod_name;
FROM products
WHERE prod_name REGEXP '1000|2000|3000'
ORDER BY prod_name;
------------------------------------------------
SELECT prod_name --[] 匹配[]中单个字符
FROM products
WHERE prod_name REGEXP '[123] Ton'
ORDER BY prod_name;
-------------------------------------------------------
SELECT prod_name --[|||] 匹配[]中单个字符,效果如上面
FROM products
WHERE prod_name REGEXP '[1|2|3] Ton' --1 Ton ,2 Ton,3 Ton
ORDER BY prod_name;
---------------------------------------------------------------
SELECT prod_name --注意
FROM products
WHERE prod_name REGEXP '1|2|3 Ton' --这里匹配的是1 ,2,3 Ton
ORDER BY prod_name;
-----------------------------------------------------------------
匹配范围:[3-6]匹配3-6 [a-z]匹配a-z
SELECT prod_name
FROM products
WHERE prod_name REGEXP '[1-5] Ton' --匹配 1 Ton ,2 Ton, 3 Ton, 4 Ton ,5 Ton
ORDER BY prod_name;
---------------------------------------------------------------------------------
匹配特殊字符 . | [] - (注意Mysql使用\\)
SELECT prod_name
FROM prodects
WHERE prod_name REGEXP '\\.' --匹配含有.的行
ORDER BY prod_name;
------------------------------------------------------------
空白元字符
元字符 说明
\\f 换页
\\n 换行
\\r 回车
\\t 制表
\\v 纵向制表
-------------------------------------------------------------
匹配字符类
字符类
类 说明
[:alnum:] 任意字母和数字(同[a-zA-Z0-9])
[:alpha:] 任意字母(同[a-zA-Z])
[:blank:] 空格和制表(同[\\t])
[:cotrl:] ASCII码控制字符(ASCII0-31和127)
[:digit:] 任意数字(同[0-9])
[:graph:] 与print相同,但不包含空格
[:lower:] 任意小写字母(同[a-z])
[:upper:] 任意大写字母
[:print:] 任意可打印字符
[:punct:] 既不在[:alnum:]也不在[:cotrl:]中的字符
[:space:] 包括空格在内的任意空白字符(同[\\t\\f\\r\\n\\v])
[:xdigit:] 任意十六进制数字(同[a-fA-F0-9])
-------------------------------------------------------------
匹配多个实例
重复元字符
元字符 说明
* 0个或多个匹配
+ 一个或多个匹配(相当于{1,})
? 0个或者1个匹配(相当于{0,1})
{n} 指定数目的匹配
{n,} 不少于指定数目的匹配
{n,m} 指定数目的范围(m不超过255)
下面例子匹配:\\( 匹配),[0-9]匹配任意数字,stick?匹配stick和stick(后面有任意字符),\\)匹配 )
SELECT prod_name
FROM products
WHERE prod_name REGEXP '\\([0-9] stick?\\)'
ORDER BY prod_name;
SELECT prod_name
FROM products
WHERE prod_name REGEXP '[[:digit:]{4}]'
ORDER BY prod_name;
--------------------------------------------------------------
定位符
定位元字符
元字符 说明
^ 文本的开始
$ 文本的结束
[[:<:]] 词的开始
[[:<:]] 词的结束
匹配产品名称以数字或者.开头产品
SELECT prod_name
FROM prodducts
WHERE prod_name REGEXP '^[0-9\\.]'
ORDER BY prod_name;
---------------------------------------------------------------
LIKE和REGEXP起类似的作用,但LIKE匹配的是整个串,而REGEXP匹配的是字串
REGEXP加入^ 和 $ 家可以实现与LIKE一样的作用
-----------------------------------------------------------------
sql语句(Mysql数据库)的更多相关文章
- mysql用户管理 常用sql语句 mysql数据库备份恢复
- mysql / pgsql 使用sql语句查询数据库所有表注释已经表字段注释
mysql使用sql语句查询数据库所有表注释已经表字段注释(转载) 场景: 1. 要查询数据库 "mammothcode" 下所有表名以及表注释 /* 查询数据库 ‘mammo ...
- oracle 用sql语句管理数据库
基础sql语句 创建数据库 :create database database_name; 创建表:create table(字段名 字段类型 字段为空约束 ,字段名 字段类型 字段为空约束,,,, ...
- 043:Django使用原生SQL语句操作数据库
Django使用原生SQL语句操作数据库 Django配置连接数据库: 在操作数据库之前,首先先要连接数据库.这里我们以配置 MySQL 为例来讲解. Django 连接数据库,不需要单独的创建一个连 ...
- 2-06使用SQL语句创建数据库3
向现有数据库中添加文件组和数据文件几种方式以及步骤: 第一种:在视图下添加文件组和数据文件. 添加文件组的步骤: 右击你想要添加文件组的数据库点属性,然后点文件组就可以添加. 添加数据文件的步骤: 下 ...
- 使用SQL语句清空数据库所有表的数据
使用SQL语句清空数据库所有表的数据 近来发现数据库过大,空间不足,因此打算将数据库的数据进行全面的清理,但表非常多,一张一张的清空,实在麻烦,因此就想利用SQL语句一次清空所有数据.找到了三种方法进 ...
- 全国省市级联数据sql语句 mysql版
全国省市级联数据sql语句 mysql版 --省级 provincial create table provincial ( provincialID int, provincialName ), p ...
- SQL语句获取数据库中的表主键,自增列,所有列
SQL语句获取数据库中的表主键,自增列,所有列 获取表主键 1:SELECT TABLE_NAME,COLUMN_NAME FROM INFORMATION_SCHEMA.KEY_COLUMN_U ...
- 【转载】C#常用数据库Sqlserver通过SQL语句查询数据库以及表的大小
在Sqlserver数据库中,一般我们查看数据库的大小可以通过查找到数据库文件来查看,但如果要查找数据表Table的大小的话,则不可通过此方法,在Sqlserver数据库中,提供了相应的SQL语句来查 ...
- SQL语句还原数据库并移动文件到指定路径
用SQL语句还原数据库时如果不指定数据库文件的存储路径,则默认把数据文件和日志文件存放到与原数据库相同的文件路径中,这样可能会产生错误,比如执行下面的语句: restore database Smar ...
随机推荐
- jQuery文字“橡皮圈“特效
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- Using 1.7 requires compiling with Android 4.4 (KitKat); currently using
今天编译一个project,我设置为api 14,可是编译报错: Using 1.7 requires compiling with Android 4.4 (KitKat); currently u ...
- linux 学习第十八天学习(DNS分离解析、DHCP配置、邮件服务配置)
DNS分离解析技术 yum install bind-chroot systemctl restart named systemctl enable named vim /etc/named.conf ...
- linux定时任务-crontab
使用场景: 有时候线上服务器挂了,或者一些数据推送不正常,一般来说我们需要做的就是将项目重启运行,或者检查核对出问题的位置,来快速解决,很多时候我们不得不登上服务器来查看,这个对于目前工作日益繁忙的我 ...
- 二、用Delphi10.3 创建一条JSON数据的第二种方法,并格式化输出
一.用Delphi10.3构造一个JSON数据的第二种方法,并格式化输出,代码如下: uses //System.JSON, System.JSON.Types, System.JSON.Writer ...
- 飞控入门之C语言指针回顾
指针 何为指针?来个官方定义:指针是一个值为内存地址的变量(或数据对象). 一.指针的声明 //示例 int *pi; //pi是指向int类型变量的指针 char *pc; // pi是指向char ...
- 基于VHDL的8255可编程并行接口电路设计
一.实验题目名称: 8255可编程并行接口电路设计 二.实验目的.任务和要求: 实验目的:学习掌握基本的数字系统设计方法,建立自顶向下的设计思维,能够使用VHDL语言编写简单的应用IP核,掌握基本的F ...
- Hibernate第三天——表间关系与级联操作
第三天,我们来使用Hibernate进行表之间一对多 多对多关系的操作: 这里我们先利用两个例子进行表关系的回顾: 一对多(重点): 例如分类和商品的关系,一个分类多个商品,一个商品属于一个分类 CR ...
- JS 判断滚动底部并加载更多效果。。。。。。。。。
JS 判断滚动底部并加载更多效果......... <html lang="zh-cn"> <head> <meta http-equiv=" ...
- 仙人掌&圆方树
仙人掌&圆方树 Tags:图论 [x] [luogu4320]道路相遇 https://www.luogu.org/problemnew/show/P4320 [ ] [SDOI2018]战略 ...