1. 求sql语法
SQL语言快速入门(一)
SQL是英文Structured Query Language的缩写,意思为结构化查询语言。
SQL语言的主要功能就是同各种数据库建立联系,进行沟通。按照ANSI(美国国家标准协会)的规定,SQL被作为关系型数据库管理系统的标准语言。SQL语句可以用来执行各种各样的操作,例如更新数据库中的数据,从数据库中提取数据等。目前,绝大多数流行的关系型数据库管理系统,如Oracle, Sybase, Microsoft SQL Server, Access等都采用了SQL语言标准。虽然很多数据库都对SQL语句进行了再开发和扩展,但是包括Select, Insert, Update, Delete, Create, 及Drop在内的标准的SQL命令仍然可以被用来完成几乎所有的数据库操作。下面,我们就来详细介绍一下SQL语言的基本知识。
数据库表格
一个典型的关系型数据库通常由一个或多个被称作表格的对象组成。数据库
中的所有数据或信息都被保存在这些数据库表格中。数据库中的每一个表格都具有
自己唯一的表格名称,都是由行和列组成,其中每一列包括了该列名称,数据类型
,以及列的其它属性等信息,而行则具体包含某一列的记录或数据。以下,是一个
名为天气的数据库表格的实例。
城市 最高气温 最低气温
北京 10 5
上海 15 8
天津 8 2
重庆 20 13
该表格中“城市”,“最高气温”和“最低气温”就是三个不同的列
,而表格中的每一行则包含了具体的表格数据。
数据查询
在众多的SQL命令中,select语句应该算是使用最频繁的。Select语句主要被用来对数据库进行查询并返回符合用户查询标准的结果数据。Select语句的语法格式如下:
select column1 [, column2,etc] from tablename
[where condition];
([] 表示可选项)
Select语句中位于Select关键词之后的列名用来决定那些列将作为查询结果返回。用户可以按照自己的需要选择任意列,还可以使用通配符“*”来设定返回表格中的所有列。
Select语句中位于from关键词之后的表格名称用来决定将要进行查询操作的目
标表格。
Select语句中的where可选从句用来规定哪些数据值或哪些行将被作为查询结果返回或显示。在where条件从句中可以使用以下一些运算符来设定查询标准:
= 等于
> 大于
< 小于
>= 大于等于
<= 小于等于
不等于
除了上面所提到的运算符外,LIKE运算符在where条件从句中也非常重要。
LIKE运算符的功能非常强大,通过使用LIKE运算符可以设定只选择与用户规定格式相同的记录。此外,我们还可以使用通配符“%”用来代替任何字符串。举例如下:
Select firstname, lastname, city
from employee
where firstname LIKE ‘E%’;
(注意,字符串必须被包含在单括号内)
上述SQL语句将会查询所有名称以E开头的姓名。或者,通过如下语句:
Select * from employee
where firstname = ‘May’;
查询所有名称为May的行。
SQL语言快速入门(二)
创建表格
SQL语言中的create table语句被用来建立新的数据库表格。Create table
语句的使用格式如下:
create table tablename
(column1 data type,
column2 data type,
column3 data type);
如果用户希望在建立新表格时规定列的限制条件,可以使用可选的条件
选项:
create table tablename
(column1 data type [constraint],
column2 data type [constraint],
column3 data type [constraint]);
举例如下:
create table employee
(firstname varchar(15),
lastname varchar(20),
age number(3),
address varchar(30),
city varchar(20));
简单来说,创建新表格时,在关键词create table后面加入所要建立的表格
的名称,然后在括号内顺次设定各列的名称,数据类型,以及可选的限制条件
等。注意,所有的SQL语句在结尾处都要使用“;”符号。
使用SQL语句创建的数据库表格和表格中列的名称必须以字母开头,后面
可以使用字母,数字或下划线,名称的长度不能超过30个字符。注意,用户在
称时不要使用SQL语言中的保留关键词,如select, create, insert等,作为表格或
列的名称。
数据类型用来设定某一个具体列中数据的类型。例如,在姓名列中只能采
用的数据类型,而不能使用number的数据类型。
SQL语言中较为常用的数据类型为:
char(size):固定长度字符串,其中括号中的size用来设定字符串的最大
度。Char类型的最大长度为255字节。
varchar(size):可变长度字符串,最大长度由size设定。
number(size):数字类型,其中数字的最大位数由size设定。
Date:日期类型。
number(size,d):数字类型,size决定该数字总的最大位数,而d则用于
设定该数字在小数点后的位数。
最后,在创建新表格时需要注意的一点就是表格中列的限制条件。所谓限
制条件就是当向特定列输入数据时所必须遵守的规则。
例如,unique这一限制条件要求某一列中不能存在两个值相同的记录,所有
记录的值都必须是唯一的。除unique之外,较为常用的列的限制条件
还包括not, null和primary key等。Not null用来规定表格中某一列的值
不能为空.Primary key则为表格中的所有记录规定了唯一的标识符。
向表格中插入数据
SQL语言使用insert语句向数据库表格中插入或添加新的数据行。Insert语
句的使用格式如下:
insert into tablename
(first_column,...last_column)
values (first_value,...last_value);
例如:
insert into employee
(firstname, lastname, age, address, city)
values (‘Li’, ‘Ming’, 45, ‘No.77 Changan Road’, ‘Beijing”);
简单来说,当向数据库表格中添加新记录时,在关键词insert into后面输
入所要添加的表格名称,然后在括号中列出将要添加新值的列的名称。最后
,在关键词values的后面按照前面输入的列的顺序对应的输入所有要添加的
记录值。
更新记录
SQL语言使用update语句更新或修改满足规定条件的现有记录。
Update语句的格式为:
update tablename
set columnname = newvalue [, nextcolumn = newvalue2...]
where columnname OPERATOR value [and|or column OPERATOR value];
例如:
update employee
set age = age+1
where first_name= ‘Mary’and last_name= ‘Williams’;
使用update语句时,关键一点就是要设定好用于进行判断的where条件
从句。
删除记录
SQL语言使用delete语句删除数据库表格中的行或记录。Delete语句的
格式为:
delete from tablename
where columnname OPERATOR value [and|or column OPERATOR value];
例如:
delete from employee
where lastname = May;
简单来说,当需要删除某一行或某个记录时,在delete from关键词之
后输入表格名称,然后在where从句中设定删除记录的判断条件。注意,
如果用户在使用delete语句时不设定where从句,则表格中的所有记录将
全部被删除。
删除数据库表格
在SQL语言中使用drop table命令删除某个表格以及该表格中的所有记
录。Drop table命令的使用格式为:
drop table tablename;
例如:
drop table employee;
如果用户希望将某个数据库表格完全删除,只需要在drop table命令后
输入希望删除的表格名称即可。Drop table命令的作用与删除表格中的所有
记录不同。删除表格中的全部记录之后,该表格仍然存在,而且表格中列
的信息不会改变。而使用drop table命令则会将整个数据库表格的所有信息
全部删除。
以上,我们对SQL语言主要的命令和语句进行了较为详细的介绍。应该说SQL语句的语法结构和风格还是相当简单和直观的,只要用户结合实践多加练习,一定会在短期内迅速掌握。
SQL语言快速入门(三)
我们日常使用SQL语言的工作过程中,使用最多的还是从已经建立好的数据库中查询信息。下面,我们就来详细介绍一下如何使用SQL语言实现各种数据库查询操作。
SELECT…FROM
为方便讲解,我们在数据库中创建名为Store_Information的如下数据表。
Store_Information
Store_Name Sales Date
Los Angeles 00 Jan-10-2000
San Diego 0 Jan-11-2000
Los Angeles 0 Jan-12-2000
Boston 0 Jan-12-2000
SQL语言中用于数据库查询的最简单的命令就是SELECT…FROM,语法格
式为:
SELECT \"column_name\" FROM \"table_name\"
例如,如果我们希望查询Store_Information数据表中所有的商店名称时,可
以使用如下命令:
SELECT store_name FROM Store_Information
查询结果显示为:
Store_Name
Los Angeles
San Diego
Los Angeles
Boston
如果用户希望一次查询多个字段,可以将所要查询的字段名称依次加入
SELECT关键字之后,中间用“,”隔开即可。
DISTINCT
SELECT关键字支持用户查询数据表中指定字段的所有数据,但是这样有时
就会不可避免的出现重复信息。如果用户希望只查询那些具有不同记录值的信
息的话,可以使用SQL语言的DISTINCT关键字。语法格式如下:
SELECT DISTINCT \"column_name\"
FROM \"table_name\"
例如,我们可以使用以下命令查询Store_Information数据表具有不同记录值
的所有记录。
SELECT DISTINCT Store_Name FROM Store_Information
查询结果如下:
Store_Name
Los Angeles
San Diego
Boston
WHERE
除了选择具有不同记录值的记录之外,有时我们可能还会需要根据某些条
件对数据库中的数据进行查询。例如,我们可能需要查询Store_Information数
据表中销售额超过1000美圆的商店。为此,我们可以使用SQL语言的WHERE
关键字设定查询条件。语法格式如下:
SELECT \"column_name\"
FROM \"table_name\"
WHERE \"condition\"
由此,我们可以使用如下命令查询销售额超过1000美圆的商店信息:
SELECT store_name FROM Store_Information WHERE Sales > 1000
查询结果显示为:
store_name
Los Angeles
运算函数
现在,我们已经了解到在使用SQL语言进行数据库查询操作时可以通过对
数值的判断设定灵活的查询条件。为了增强对运算的支持能力,SQL提供了众
多实用的运算函数供广大用户使用。例如,我们可以直接在SQL命令中调用
SUM或AVG这两个分别用于计算总数和平均数的函数。语法格式如下:
SELECT \"function type\"(\"column_name\")
FROM \"table_name\"
如果我们希望查询Store_Information数据表中所有商店的总销售额的话,可
以使用如下命令:
SELECT SUM(Sales) FROM Store_Information
查询结果显示为:
SUM(Sales)
50
COUNT
除了SUM和AVG函数之外,COUNT函数是SQL语言中另一个较为常用
的运算函数。COUNT函数可以用来计算数据表中指定字段所包含的记录数目。
语法格式为:
SELECT COUNT(\"column_name\")
FROM \"table_name\"
例如,如果我们希望查询Store_Information数据表中的有关商店的记录条数
时,可以使用如下命令:
SELECT COUNT(store_name)
FROM Store_Information
查询结果显示为:
Count(store_name)
4
COUNT函数可以和DISTINCT关键字一起使用从而可以查询数据表中指定
字段中所有具有不同记录值的记录数目.例如,如果我们希望查询Store_Information
数据表中不同商店的数目时,可以使用如下命令:
SELECT COUNT(DISTINCT store_name)
FROM Store_Information
查询结果显示为:
Count(DISTINCT store_name)
3
GROUP BY
下面我们来进一步看一下SQL语言中的集合函数。上文中,我们曾使用
SUM函数计算所有商店的销售总额,如果我们希望计算每一家商店各自的总销
售额时该怎么办呢?要实现这一目的我们需要做两件事:首先,我们需要查询
商店名称和销售额两个字段;然后,我们使用SQL语言的GROUP BY命令将
销售额按照不同的商店进行分组,从而计算出不同商店的销售总额。GROUP
BY命令的语法格式为:
SELECT \"column_name1\", SUM(\"column_name2\")
FROM \"table_name\"
GROUP BY \"column_name1\"
我们可以使用如下命令实现上述查询目的:
SELECT store_name, SUM(Sales)
FROM Store_Information
GROUP BY store_name
查询结果显示为:
store_name SUM(Sales)
Los Angeles 00
San Diego 0
Boston 0
小注:
GROUP BY关键字一般应用于同时查询多个字段并对字段进行算术运
算的SQL命令中。
HAVING
用户在使用SQL语言的过程中可能希望解决的另一个问题就是对由sum或
其它集合函数运算结果的输出进行限制。例如,我们可能只希望看到Store_
Information数据表中销售总额超过1500美圆的商店的信息,这时我们就需要使
用HAVING从句。语法格式为:
SELECT \"column_name1\", SUM(\"column_name2\")
FROM \"table_name\"
GROUP BY \"column_name1\"
HAVING (arithematic function condition)
(GROUP BY从句可选)
由此,我们可以使用如下命令实现上述查询目的:
SELECT store_name, SUM(sales)
FROM Store_Information
GROUP BY store_name
HAVING SUM(sales) > 1500
查询结果显示为:
store_name SUM(Sales)
Los Angeles 00
小注:
SQL语言中设定集合函数的查询条件时使用HAVING从句而不是
WHERE从句。通常情况下,HAVING从句被放置在SQL命令的结尾处。
ALIAS
下面,我们重点介绍一下如何在SQL命令中设定别名。SQL语言中一般使
用两种类型的别名,分别为字段别名和数据表别名。简单的说,使用字段别名
可以帮助我们有效的组织查询的输出结果。例如,上文所列举的多个实例中,
当我们计算商店销售总额时,显示结果中就会出现SUM(sales)。虽然SUM(sales)
并不会对我们理解查询结果带来不便,但是如果我们需要在查询中使用多项复
杂运算时,显示结果就不会这么直观了。如果这时我们使用字段别名就会极大
的提高查询结果的可读性。
对于数据表别名,我们可以通过将别名直接放置在FROM从句中数据表名
称的后面设定。数据表别名在我们下面将要讲述的连接多个数据表进行查询的
操作中极为有用。
字段和数据表别名的语法格式如下:
SELECT \"table_alias\".\"column_name1\" \"column_alias\"
FROM \"table_name\" \"table_alias\"
即别名都直接放置在各自对应名称的后面,中间用空格分开。
以Store_Information数据表为例,我们可以在GROUP BY一节中所使用的
SQL命令中设置如下字段和数据表别名:
SELECT A1.store_name \ "Store\", SUM(Sales) \"Total Sales\"
FROM Store_Information A1
GROUP BY A1.store_name
查询结果显示为:
Store Total Sales
Los Angeles 00
San Diego 0
Boston 0
连接多个数据表
最后,我们来看一下如果使用SQL语言连接多个数据表,实现对多个数据
表的查询。为方便讲解,我们在数据库中分别创建了两个名为Store_Information
和Region的数据表。
Store_Information
Store_Name Sales Date
Los Angeles 00 Jan-10-2000
San Diego 0 Jan-11-2000
Los Angeles 0 Jan-12-2000
Boston 0 Jan-12-2000
Region
Region_Name Store_Name
East Boston
East New York
West Los Angeles
West San Diego
下面,我们就来看一下通过数据表的连接实现按不同区域查询销售额。
我们注意到在名为Region的数据表中包含区域和商店两个字段信息,而在名为
Store_Information的数据表中则包含每一家商店的销售信息。因此,为了得到按
区域划分的销售信息,我们需要将两个不同数据表的信息结合在一起进行查询.
通过对上述两个数据表的分析,我们发现每个数据表中都包含一个名为
Store_Name的字段,因此,我们可以使用如下命令实现查询目的:
SELECT A1.region_name REGION, SUM(A2.Sales) SALES
FROM Region A1, Store_Information A2
WHERE A1.store_name = A2.store_name
GROUP BY A1.region_name
查询结果显示为:
REGION SALES
East 0
West 50
说明:
上述查询命令的前两行用于指定所要查询的目标字段,分别为Region数据
表中的Region_Name字段和Store_Information数据表中Sales字段的记录值总
数。这里,我们设定两个字段的别名分别为REGION和SALES,两个数据表的
别名分别为A1和A2。如果我们只使用字段别名而不设定数据表别名的话,上
述SQL命令的第一行就变成如下形式:
SELECT Region.Region_Name REGION, SUM(Store_Information.Sales) SALES
由此我们可以看出有效的使用数据表别名,可以极大的简化对多个数据表
进行操作的SQL命令。
上述查询命令的第3行为WHERE从句,正是该从句设定了两个数据表的
连接条件。因为我们希望确保Region数据表中的Store_Name字段能够与
Store_Information数据表中的同名字段相对应,所以我们规定两个字段的记录
值应当相等。在连接多个数据表时,一定要准确设定数据表的连接条件,如果
WHERE从句设定不正确,则可能导致查询结果中出现众多不相关的数据 .
2. SQL 语句
如果确定要用SQL语句完成这个动作,则比较复杂,还必需表有一个唯一关键字段才可以。假设此字段为ID
我们分段做这个语句:
语句1、首先找出物料编号,最新入库价所在行的ID,如果ID是自动增长,或者越晚则ID越大则简单,找最大ID就是最后的入库单价,如果不是这样,要根据时间找最后的入库单价,更麻烦点
(1)、ID与入库时间成比例的:
select ID from (SELECT 物料编码,max(ID) as ID FROM table_name GROUP BY 物料编码)
(2)、ID与入库时间没关系的(程序编写的ID)
select ID from table_name a,(SELECT 物料编码,max(入库时间) as 入库时间 FROM table_name GROUP BY 物料编码) b where a.物料编码=b.物料编码 and a.入库时间=b.入库时间)
语句2、根据ID先找出最后入库单价
select 物料编码,入库单价 from table_name where ID in(语句1)
语句3、类似语句1,找出紧接上次的入库价数据的ID,在语句1的基础上,但增加一个条件ID not in(语句1)来排除最新入库价,就得到上次价
语句4、类似语句2,使用ID in(语句3),得到物料编码、紧接上次价;
语句5、连接语句2、4,on条件使用物料编码相同就可以得到最后的结果了。
注意,最后写好语句5,则一个语句就得到结果了。
3. SQL 语句
介绍sql语句如何使用函数
4. 求帮写一个sql查询语句
首先A表和B表没有直接关系,所以关联查询的时候无法同时查询,换句话说你给的表结构不是很对,可以先了解下我这个图,总结:两个表要有相同的字段才能进行关联查询,完全没有关系的话查询是没有意义的
2.如果你有我发的图中类似的表结构,那么可以进行关联查询,比如
select b.姓名,a.年级,a.班级 from a表,b表 where a.年级=b.年级 and/or a.班级=b.年级
上边语句其实是有一些数据冗余问题的,因为表结构设计的不是很好,但是关联查询重点是需要两个表内有相同含义字段的,这个清楚就好理解很多了。
你说的班级=1,只需要在where条件里加上相应的 a.班级=1即可,根据表设计的字段类型,如果是数值型就直接=1,如果是字符型=‘1’。条件不难,但是表结构要规划好,我再给你一个具体的比较好的表图如下
以上3表关联查询
select b.姓名,a.年级,c.班级 from a表,b表,c表 where a.学号=1 and a.年级=b.序号 and a.班级=c序号
注意上边的语句,a.年级=b.序号 和a.班级=c.序号 因为B表学员表中存的是序号,所以要对应A和C表里的序号值做条件相等判断,但是返回值(select后你可以看到的)是具体的汉字内容
5. 求一个SQL语句的答案
第一步:把三张表inner join关联,查询出所有学生的所有课程的所有得分。
请点击输入图片描述
第二步:把第一步的结果,进行“行->列”的转换,此时有group by和聚合函数的使用。
请点击输入图片描述
第三步:把第二部的结果进行筛选,筛选的条件是:数据库和数据结构的得分都不为空,表示既选择了数据库课程又选择了数据结构课程,数据库的得分要 大于 数据结构的得分。
请点击输入图片描述
6. Sql语句?
介绍sql语句如何使用函数
7. 经典sql语句
baidu、google是很好的学习搜索引擎,
推荐一下新手学习SQL的基础技术,在baidu搜索以下内容:
“一网打尽”通用SQL数据库的查询语句
实例讲解SQL Server中"Update"的用法
三种数据库利用SQL语句进行高效果分页
深入讲解SQL Server数据库的嵌套子查询
实现跨多个表格的数据进行组合的SQL语句
深入讲解SQL Union和Union All的使用方法
还有一些基本的语法这里也简单介绍一下,希望对你有用:
学习SQL应知道的动态SQL语句基本语法
1 、普通SQL语句可以用Exec执行
eg: Select * from tableName
Exec('select * from tableName')
Exec sp_executesql N'select * from tableName' -- 请注意字符串前一定要加N
2、字段名,表名,数据库名之类作为变量时,必须用动态SQL
eg:
declare @fname varchar(20)
set @fname = 'FiledName'
Select @fname from tableName -- 错误,不会提示错误,但结果为固定值FiledName,并非所要。
Exec('select ' + @fname + ' from tableName') -- 请注意 加号前后的 单引号的边上加空格
当然将字符串改成变量的形式也可
declare @fname varchar(20)
set @fname = 'FiledName' --设置字段名
declare @s varchar(1000)
set @s = 'select ' + @fname + ' from tableName'
Exec(@s) -- 成功
exec sp_executesql @s -- 此句会报错
declare @s Nvarchar(1000) -- 注意此处改为nvarchar(1000)
set @s = 'select ' + @fname + ' from tableName'
Exec(@s) -- 成功
exec sp_executesql @s -- 此句正确
3、输出参数
declare @num int,
@sqls nvarchar(4000)
set @sqls='select count(*) from tableName'
exec(@sqls)
--如何将exec执行结果放入变量中?
declare @num int,
@sqls nvarchar(4000)
set @sqls='select @a=count(*) from tableName '
exec sp_executesql @sqls,N'@a int output',@num output
select @num
此外,如果想要在SQL语句 字符串中使用 单引号 '' 可以 使用 ''''
8. 常用SQL语句,看这篇就够了
本文主要以 Mysql 数据库为基础,对常用 SQL 语句进行一次深度总结,由于篇幅较长,难免会有些遗漏的地方,欢迎网友批评指出!
具体内容主要有以下几个部分:
创建数据库比较简单,在创建的时候直接指定字符集、排序规则即可!
例子:
数据库修改库名的有三种方法,如果是 MyISAM 存储引擎,那么可以直接去数据库目录 mv 就可以了,如果是 Innodb 完全不行,会提示相关表不存在。
这个语法在 mysql-5.1.7 中被添加进来,到了 mysql-5.1.23 又去掉了,官方不推荐,会有丢失数据的危险!
思路是先创建一个新库,之后将旧库的数据导入到新库,即可完成修改库名!
当然这种方法虽然安全,但是如果数据量大,会比较耗时,同时还需要考虑到磁盘空间等硬件成本。
例子:
直接跑一个 shell 脚本!
其中 p123456 , p 是 password 的简称, 123456 表示数据库密码值!
删除库,比较简单,直接删除即可!
或者
MySQL 主要有以下几种运算符:
运算符描述实例 +加法select 1+2; 结果为3 -减法select 1-2; 结果为-1 *乘法select 2*3; 结果为6 /除法select 6/3; 结果为2 %取余select 10%3; 结果为1
说明: 在除法运算和模运算中,如果除数为0,将是非法除数,返回结果为NULL 。
SELECT 语句中的条件语句经常要使用比较运算符。通过这些比较运算符,可以判断表中的哪些记录是符合条件的。比较结果为真,则返回 1,为假则返回 0,比较结果不确定则返回 NULL。
运算符描述实例 =等于select * from t_user where user_id = 1 查询用户ID为1的信息 !=不等于select * from t_user where user_id != 1 查询用户ID不为1的信息 >大于select * from t_user where user_id > 1 查询用户ID大于1的信息 >=大于select * from t_user where user_id >= 1 查询用户ID大于等于1的信息 大于select * from t_user where user_id =1 and user_id <=100 NOT BETWEEN AND不在两值之间select * from t_user where user_id not between 1 and 100 查询用户ID不在1和100之间的信息,类似user_id 100 IN在集合中select * from t_user where user_id in ('1','2') 查询用户ID为 1 或者 2 的信息 NOT IN不在集合中select * from t_user where user_id not in ('1','2') 查询用户ID不为 1 和 2 的信息 LIKE模糊匹配,%表示0个或者多个匹配select * from t_user where user_name like '%张%' 查询用户姓名包含张的信息 IS NULL为空select * from t_user where user_name is null 查询用户姓名为空的信息 IS NOT NULL不为空select * from t_user where user_name not is null 查询用户姓名不为空的信息
说明: mysql中,IN 语句中参数个数是不限制的。不过对整段 sql 语句的长度有了限制,最大不超过 4M !
逻辑运算符用来判断表达式的真假。如果表达式是真,结果返回 1。如果表达式是假,结果返回 0。
运算符描述实例 NOT 或 !逻辑非select not 1; 结果为0 AND逻辑与select 2 and 0; 结果为0 OR逻辑或select 2 or 0; 结果为1 XOR逻辑异或select null or 1; 结果为1
位运算符是在二进制数上进行计算的运算符。位运算会先将操作数变成二进制数,进行位运算。然后再将计算结果从二进制数变回十进制数。
运算符描述实例 &按位与select 3&5; 结果为1 I按位或select 3I5; 结果为7 ^按位异或select 3I5; 结果为7 ^按位异或select 3^5; 结果为6 ~按位取反select ~18446744073709551612; 结果为3 >>按位右移select 3>>1; 结果为1 <按位左移select 3<<1; 结果为6
优先级(从高到底)运算符 1! 2-(负号),~(按位取反) 3^(按位异或) 4*,/(DIV),%(MOD) 5+,- 6>>,=,!=,>,IN,IS NULL,LIKE,REGEXP 10BETWEEN AND,CASE,WHEN,THEN,ELSE 11NOT 12&&,AND 13XOR 14II,OR 15=(赋值运算),:=
说明: 在无法确定优先级的情况下,可以使用圆括号 () 来改变优先级,并且这样会使计算过程更加清晰 。
视图(view)是一种虚拟存在的表,是一个逻辑表,本身并不包含数据。作为一个select语句保存在数据字典中的。
参数说明:
基本格式:
创建视图示例:
删除视图是指删除数据库中已存在的视图,删除视图时,只能删除视图的定义,不会删除数据,也就是说不动基表:
删除示例:
函数描述实例 char_length(s)返回字符串 s 的字符长度select char_length("hello") as content; concat(s1,s2...sn)字符串 s1,s2 等多个字符串合并为一个字符串select concat("hello ", "world") as content; format(x,n)将数字 x 进行格式化,到小数点后 n 位,最后一位四舍五入select format(500.5634, 2) as content; lower(s)将所有字母变成小写字母select lower('HELLO'); current_timestamp()返回当前日期和时间select current_timestamp(); DATE_FORMAT(date,format)格式化时间或者日期select DATE_FORMAT(current_timestamp(),"%Y-%m-%d %H:%i:%s"); IFNULL(v1,v2)如果 v1 的值不为 NULL,则返回 v1,否则返回 v2select IFNULL(null,'hello word');
参数说明:
参数说明:
参数说明:
参数说明:
示例:
参数说明:
参数说明:
创建一个查询用户信息的存储过程示例:
输出结果:
删除示例:
触发器是与表有关的数据库对象,在满足定义条件时触发,并执行触发器中定义的语句集合。
定义语法
参数说明:
示例,创建了一个名为trig1的触发器,一旦在 t_user 表中有插入动作,就会自动往 t_time 表里插入当前时间。
创建有多个执行语句的触发器语法
示例如下:
一旦插入成功,就会执行 BEGIN ...END 语句!
所有触发器信息都存储在information_schema数据库下的triggers表中,可以使用SELECT语句查询,如果触发器信息过多,最好通过TRIGGER_NAME字段指定查询。
示例如下:
删除触发器之后最好使用上面的方法查看一遍。
触发器尽量少的使用,因为不管如何,它还是很消耗资源,如果使用的话要谨慎的使用,确定它是非常高效的:触发器是针对每一行的;对增删改非常频繁的表上切记不要使用触发器,因为它会非常消耗资源。
在 MySQL 中,可以有如下几种途径实现唯一值:
在mysql中,一般我们可以给某个主键字段设置为自增模式,例如:
这种模式,在单库单表的时候,没啥问题,但是如果要对 test_db 表进行分库分表,这个时候问题就来了,如果水平分库,这个时候向 test_db_1 、 test_db_2 中插入数据,就会出现相同的 ID !
当然,为了避免出现这种情况,有的大神就自己单独创建了一张自增序列表,单独维护,这样就不会出现在分表的时候出现相同的ID!
实现过程也很简单!
这方案,某种情况下解决了分表的问题,但是如果分库还是会出现相同的ID!
UUID 基于 16 进制,由 32 位小写的 16 进制数字组成,如下:
比如 d0c754a8-178e-11eb-ae3d-2a7bea22ed3d 就是一个典型的 UUID。
在 MySQL 的 UUID() 函数中,前三组数字从时间戳中生成,第四组数字暂时保持时间戳的唯一性,第五组数字是一个 IEEE 802 节点标点值,保证空间唯一。
使用 UUID() 函数,可以生成时间、空间上都独一无二的值。据说只要是使用了 UUID,都不可能看到两个重复的 UUID 值。当然,这个只是在理论情况下。
使用方法也很简单,在 sql 可以直接当成函数调用即可!
在 MySQL 5.1 之后的版本,提供 UUID_SHORT() 函数,生成一个 64 位无符号整数,在java中可以用 Long 类型接受。另外,需要注意的是,server_id 的范围必须为 0-255 ,并且不支持 STATEMENT 模式复制,否则有可能会产生重复的ID
同时,需要注意的是, UUID_SHORT() 返回的是 unsigned long long 类型,在字段类型设置的时候,一定要勾选 无符号 类型,否则有可能生成的ID超过 Long 类型最大长度!
说明:
在给其他授权前,请先用管理员账户登录!
注意:用以上命令授权的用户不能给其它用户授权,如果想让该用户可以授权,用以下命令!
在结尾加上 WITH GRANT OPTION 就可以了!
可以使用如下命令,来一键设置 root 用户的密码,同时拥有所有的权限并设置为远程访问!
如果想关闭 root 用户远程访问权限,使用如下命令即可!
最后使用如下命令,使其生效!
创建用户并进行授权,也可以使用如下快捷命令!
最后需要注意的是:mysql8,使用强校验,所以,如果密码过于简单,会报错,密码尽量搞复杂些!
本文主要围绕 Mysql 中常用的语法进行一次梳理和介绍,这些语法大部分也同样适用于其他的数据库,例如 oracle、sqlserver、postgres 等等,在数据操作栏,除了分页函数以外,基本都是通用的!