sql部分语法规则总结

数据库:(一个项目建一个库)(学生管理系统)

增:   create database 数据库名 [character set 字符集 collate 字符集校验规则];

删:   drop database 数据库名;

改(字符集):    alter database 数据库名 character set 字符集 [collate 字符集校验规则];

查:   -- 1、show databases; (查看所有数据库)

       -- 2、show create database 数据库名;      (查看单个数据库字符集等信息)

其他:      -- 1、use 数据库名;    (切换库)

              -- 2、select database();      (查看当前所在哪个数据内)

 

数据库-数据库表:(一个实例建一个表)(学生信息表,学生成绩表)

Tips:增删改都是以"alter table表名"开头的.

增:   alter table 表名 add 列名 字段类型(长度) [约束]; (添加表的属性,例如:姓名(列名 字段类型(长度) [约束]),学号(列名 字段类型(长度) [约束]))

删:   alter table 表名 drop 列名;

改:   -- 1、表名:alter table 旧表名 rename to 新表名;

       -- 2、表的字符集:alter table 表名 chatacter set 新字符集 [collate字符集校验规则];

       -- 3、表的列名:alter table 表名 change 旧列名 新列名 字段类型 [约束];

       -- 4、表的列字段、字段长度、约束:alter table 表名 modify 列名 字段(长度) [约束];

查:   -- 1、show tables;       (查看所有表)

       -- 2、desc 表名;         (查看某个表结构)

       -- 3、show create table 表名;   (查看表的字符集等信息)

数据库-数据库表-表记录:(一个对象建一条表记录)(例如:学生张三,11112222,18)

Tips:已经进到表记录操作,表名不用加table修饰.

增(一次只能增加一条表记录):   

       -- 1、给某几列插入数据:insert into 表名(列1,列2,列3…) values(值1,值2,值3…);

       -- 2、给所有列插入数据:insert into 表名values(值1,值2,值3…);

       -- 3、一次性插入多行数据: insert into 表名values(值1,值2,值3…), (值1,值2,值3…), (值1,值2,值3…)…;

删(删除数据是删除一行数据):    delete from 表名 [where 条件];

改(修改数据是修改一列数据):    update 表名 set 列名1=值1,列名2=值2…[where条件];

查:(格式)        select … from 表名 where 条件 group by 字段名 hanving 条件 order by asc/desc;     (注意:where子句不能使用聚合函数,如果现在使用带有聚合函数的条件过滤或者分组后过滤,使用having关键字)

多表

添加外键:

1.创建表的时候添加.(constraint abc可以要可以不要)

2.创建表之后再给某字段添加外键.

删除外键

 

3.多表查询=连接查询(交叉连接+内连接+外连接)+子查询

  • 连接查询:

      1.)交叉连接查询:笛卡尔积,左边每一项跟右边所有项组合形成一张表,不管有没有关系.

                select * from 表1 cross join 表2;

                或select * from 表1,表2;

      2.)内连接查询: 使用inner join…on关键字(inner可以省略),根据关键字匹配,两表某条记录都含有相同关键字,则匹配成功,组合成新表的一条记录.

          a.显式内连接:在sql中使用了inner join…on关键字

             语法:select * from 表1 inner join 表2 on 关联条件;

          b.隐式内连接:在sql中没有使用了inner join关键字

             语法:select * from 表1,表2 where 关联条件;

      3.)外连接查询: 使用left/right outer join…on关键字(outer可以省略)

          a.左外连接:使用left outer join…on关键字,以左表为中心, 根据关键字,用左边每行去匹配右表, 无论匹配是否成功,都为新表的一条新纪录,只是若匹配不到右表,则新表右边为null.

             语法:select * from 表1 left outer join 表2 on 连接条件;

          b.右外连接:使用right outer join…on关键字,同理左连接.

             语法:select * from 表1 right outer join 表2 on 连接条件;

  • 子查询:
    1. 带in的子查询:在给定的结果内查询。
    2. 带exists子查询:如果EXISTS后面的查询结果存在,前面的sql语句才执行。
    3. 带any的子查询:只要符合any后面查询语句中的任何一个结果就行。
    4. 带all的子查询:要符合all后面查询语句中的所有结果才行。

总结:

  1. --编写多表查询语句的一般过程  
  2. --1)、分析句子要涉及到哪些表  
  3. --2)、对应的表中要查询哪些关联字段  
  4. --3)、确定连接条件或筛选条件  
  5. --4)、写成完整的SQL查询语句  

读SQL顺序:

  1. 先跟句512判断句式,是单表还是多表,多表是用什么语法连接
  2. Select(5)from(1)where(2)group by…having(3)order by(4)
  3. 若2处嵌套子查询,按由内到外的原则.

 

 

MySql常用命令总结

1:使用SHOW语句找出在服务器上当前存在什么数据库:

mysql> SHOW DATABASES;

2:2、创建一个数据库MYSQLDATA

mysql> CREATE DATABASE MYSQLDATA;

3:选择你所创建的数据库

mysql> USE MYSQLDATA; (按回车键出现Database changed 时说明操作成功!)

4:查看现在的数据库中存在什么表

mysql> SHOW TABLES;

5:创建一个数据库表

mysql> CREATE TABLE MYTABLE (name VARCHAR(20), sex CHAR(1));

6:显示表的结构:

mysql> DESCRIBE MYTABLE;

7:往表中加入记录

mysql> insert into MYTABLE values (”hyq”,”M”);

8:用文本方式将数据装入数据库表中(例如D:/mysql.txt)

mysql> LOAD DATA LOCAL INFILE “D:/mysql.txt” INTO TABLE MYTABLE;

9:导入.sql文件命令(例如D:/mysql.sql)

mysql>use database;

mysql>source d:/mysql.sql;

10:删除表

mysql>drop TABLE MYTABLE;

11:清空表

mysql>delete from MYTABLE;

12:更新表中数据

mysql>update MYTABLE set sex=”f” where name=’hyq’;

 

以下是无意中在网络看到的使用MySql的管理心得,

在windows中MySql以服务形式存在,在使用前应确保此服务已经启动,未启动可用net start mysql命令启动。而Linux中启动时可用“/etc/rc.d/init.d/mysqld start”命令,注意启动者应具有管理员权限。

刚安装好的MySql包含一个含空密码的root帐户和一个匿名帐户,这是很大的安全隐患,对于一些重要的应用我们应将安全性尽可能提高,在这里应把匿名帐户删除、 root帐户设置密码,可用如下命令进行:

use mysql;

delete from User where User=”";

update User set Password=PASSWORD(’newpassword’) where User=’root’;

如果要对用户所用的登录终端进行限制,可以更新User表中相应用户的Host字段,在进行了以上更改后应重新启动数据库服务,此时登录时可用如下类似命令:

mysql -uroot -p;

mysql -uroot -pnewpassword;

mysql mydb -uroot -p;

mysql mydb -uroot -pnewpassword;

上面命令参数是常用参数的一部分,详细情况可参考文档。此处的mydb是要登录的数据库的名称。

在 进行开发和实际应用中,用户不应该只用root用户进行连接数据库,虽然使用root用户进行测试时很方便,但会给系统带来重大安全隐患,也不利于管理技 术的提高。我们给一个应用中使用的用户赋予最恰当的数据库权限。如一个只进行数据插入的用户不应赋予其删除数据的权限。MySql的用户管理是通过 User表来实现的,添加新用户常用的方法有两个,一是在User表插入相应的数据行,同时设置相应的权限;二是通过GRANT命令创建具有某种权限的用 户。其中GRANT的常用用法如下:

grant all on mydb.* to NewUserName@HostName identified by “password” ;

grant usage on *.* to NewUserName@HostName identified by “password”;

grant select,insert,update on mydb.* to NewUserName@HostName identified by “password”;

grant update,delete on mydb.TestTable to NewUserName@HostName identified by “password”;

若 要给此用户赋予他在相应对象上的权限的管理能力,可在GRANT后面添加WITH GRANT OPTION选项。而对于用插入User表添加的用户,Password字段应用PASSWORD 函数进行更新加密,以防不轨之人窃看密码。对于那些已经不用的用户应给予清除,权限过界的用户应及时回收权限,回收权限可以通过更新User表相应字段, 也可以使用REVOKE操作。

下面给出本人从其它资料(www.cn-java.com)获得的对常用权限的解释:

全局管理权限:

FILE: 在MySQL服务器上读写文件。

PROCESS: 显示或杀死属于其它用户的服务线程。

RELOAD: 重载访问控制表,刷新日志等。

SHUTDOWN: 关闭MySQL服务。

数据库/数据表/数据列权限:

ALTER: 修改已存在的数据表(例如增加/删除列)和索引。

CREATE: 建立新的数据库或数据表。

DELETE: 删除表的记录。

DROP: 删除数据表或数据库。

INDEX: 建立或删除索引。

INSERT: 增加表的记录。

SELECT: 显示/搜索表的记录。

UPDATE: 修改表中已存在的记录。

特别的权限:

ALL: 允许做任何事(和root一样)。

USAGE: 只允许登录–其它什么也不允许做。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值