您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

第十三天3月7日之MySQL基础

2024/5/10 4:14:07发布36次查看
一、sql sql:structured query language的缩写 结构化查询语言 sql工业标准:由ansi(iso(国际标准委员会international standard orgnation)核心成员) 按照工业标准编写的sql能运行在任何数据库上。 方言:只能运行在特定数据库上的sql语句叫做方言。 工业标
一、sql
sql:structured query language的缩写
结构化查询语言
sql工业标准:由ansi(iso(国际标准委员会international standard orgnation)核心成员)
按照工业标准编写的sql能运行在任何数据库上。
方言:只能运行在特定数据库上的sql语句叫做方言。
工业标准和方言:普通话和浙江话。
二、sql语言的组成:
ddl:数据定义语言 data definition language
dml:数据操作语言 data manipulation language
dql:数据查询语言 data query language
tpl:事务处理语言 transaction process language
dcl:数据控制语言
ccl:指针控制语言
三、基本知识
java定义的类---------------表的结构
java对象-------------------表中的记录
mysql:非windows环境下是严格区分大小写的。
约定:关键字都采用小写。多个单词组成用_分割。
四、ddl
作用:定义数据库和表结构等的语句。
关键字:create alter drop truncate(摧毁)
练习:
1、ddl之数据库操作
创建一个名称为mydb1的数据库。
mysql>create database mydb1;
查看有哪些数据库
mysql>show databases;
查看创建数据库的具体细节
mysql>show create database mydb1;
创建一个使用gbk字符集的mydb2数据库。
mysql>create database mydb2 characterset gbk;
创建一个使用gbk字符集,并带校对规则的mydb3数据库。
mysql>create database mydb3 characterset gbk collate gbk_chinese_ci;
删除前面创建的mydb3数据库
mysql>drop database mydb3;
查看服务器中的数据库,并把mydb2的字符集修改为utf8;
mysql>alter database mydb2 character setutf8;
2、ddl之表结构
选择一个库
mysql>use mydb1;
创建一个员工表
mysql>create table employee(
idint,
namevarchar(200),
gendervarchar(200),
birthdaydate,
entry_datedate,
jobvarchar(200),
salaryfloat(8,2),
resumetext
);
显示当前库中的所有表
mysql>show tables;
查看表的结构
mysql>desc employee;
查看表的创建细节
mysql>show create table employee;
在上面员工表的基本上增加一个image列。
mysql>alter table employee add imageblob;
修改job列,使其长度为60。
mysql>alter table employee modify jobvarchar(60);
删除image列。
mysql>alter table employee drop image;
表名改为user。
mysql>rename table employee to user;
修改表的字符集为utf8
mysql>alter table user character setutf8;
列名name修改为username
mysql>alter table user change nameusername varchar(100);
五、dml:data manipulationlanguage
用于向数据库表中插入、删除、修改数据
常用关键字:insert updatedelete
在mysql中,字符串和日期时间类型,要使用单引号引起来。
特殊值:null
练习:
使用insert语句向user表中插入三个员工的信息。
mysql>insert into user(id,username,gender,birthday,entry_date,job,salary,resume) values(1,'wangdongxue','female','1991-09-08','2014-02-17','ceo',100000,'beautygirl');
mysql>insert into user values(2,'wangdong','male','1990-09-08','2014-02-17','cto',100000,'strong man');
mysql>insert into user values (3,'查显成','男性','1988-09-08','2014-02-17','ufo',100000,'帅锅');
查看表中的所有记录
mysql>select * from user;
查看库的所有的编码:
mysql>show variables like'character_set%';
character_set_client:指示客户端使用的字符集
mysql>set character_set_client=gbk; 通知服务器,客户端使用的是gbk字符集
character_set_results:指示显示的结果集使用的字符集
mysql>setcharacter_set_results=gbk; 通知服务器,客户端接受的结果使用的字符集为gbk
将所有员工薪水修改为5000元。
mysql>update user set salary=5000;
将姓名为’查显成’的员工薪水修改为3000元。
mysql>update user set salary=3000 whereusername='查显成';
将姓名为’wangdong’的员工薪水修改为4000元,job改为ceo。
mysql>update user setsalary=4000,job='ceo' where username='wangdong';
将王冬雪的薪水在原有基础上增加1000元。
mysql>update user set salary=salary+1000where username='wangdongxue';
删除表中名称为’查显成’的记录。
mysql>delete from user where username='查显成';
删除表中所有记录。(dml语句)
mysql>delete from user; #一条一条的删除
使用truncate删除表中记录。 (ddl语句)
mysql>truncate user; #删除整张表,重建的表结构
六、dql数据查询语言
查询
关键字:select
查询表中所有学生的姓名和对应的英语成绩。(投影查询)
mysql>select name,english from student;
过滤表中重复数据。
mysql>select distinct english fromstudent;
在所有学生数学分数上加10分特长分。
mysql>select name,math+10 from student;
统计每个学生的总分。
mysql>select name,chinese+english+mathfrom student;
使用别名表示学生分数。
mysql>select name as姓名,chinese+english+math总分 from student;
查询姓名为王五的学生成绩
mysql>select * from student where;
查询英语成绩大于90分的同学
mysql>select * from student whereenglish>90;
查询总分大于200分的所有同学
mysql>select * from student where(chinese+english+math)>200;
模糊查询的pattern: _ 表示匹配一个字符 % 匹配任意字符
查询英语分数在 80-90之间的同学。
mysql>select name,english from studentwhere english between 80 and 90;
查询数学分数为89,90,91的同学。
mysql>select name,math from studentwhere math in(89,90,91);
查询所有姓李的学生成绩。
mysql>select * from student where namelike '李%';
查询数学分>80,语文分>80的同学。
mysql>select * from student wheremath>80 and chinese>80;
满足where条件的记录才会显示,逻辑运算的结果true。
对数学成绩排序后输出。
mysql>select name,math from studentorder by math;
对总分排序后输出,然后再按从高到低的顺序输出
mysql>select name,chinese+math+english总分 from student order by总分 desc;
注意:order是关键字。把关键字当做普通标示符对待,使用``(不是单引号,反引号)引起来
对姓李的数学学生成绩排序输出
mysql>select name,math from studentwhere name like '李%' order by math desc;
分页查询
查询前3条记录
limit m,n; m开始记录的索引(从0开始),n一次要查询的条数
mysql>select * from student limit 0,3;
七、数据的完整性
数据完整性是为了保证插入到数据中的数据是正确的,它防止了用户可能的输入错误。
1、域完整性(列完整性)
指数据库表的列(即字段)必须符合某种特定的数据类型或约束
id int(11):该字段必须是整数,,长度不能超过11
name varchar(100) not null:不能为null
username varchar(100) unique:有的话必须唯一
2、实体完整性(记录完整性)
规定表的一行(即每一条记录)在表中是唯一的实体
主键约束:primary key
id int primary key; id就是主键(不能为null,而且是唯一的)
或者
id int,
primary key(id)
mysql:主键可以自动增长。auto_increment(主键的值由mysql数据来管理和维护)。oracle中没有自动增长。
create table t2(
id int primary keyauto_increment,//auto_increment是方言,不是标准,只有mysql中有。
name varchar(100)
);
3、参照完整性(引用完整性):外键 foreign key (多表情况)
一对多、多对多、一对一
remote:远程意思
collation校对意思
charset字符集意思
manipulation操作
mysql:
时间戳:赋值了没用,不赋值就是把当前值给字段(数据库中)
clob(存放文本数据)能存的,bolb(存放二进制文件)就能存。
engine引擎:innodb:表示支持事务,安装时自己选择的
1.域完整性
not null 可以是空字符串,但不没能没有
unique可以为空,有的话必须唯一
2.order by后面的字段必须出现在select后面即投影字段的后面吗?不是必须的
+------------+--------------+------+-----+---------+-------+
| id | int(11) | yes | |null | |
| name | varchar(200) | yes | | null | |
| gender | varchar(200) | yes | | null | |
| birthday | date | yes | |null | |
| entry_date | date | yes | | null | |
| job | varchar(200) | yes | | null | |
| salary | float(8,2) | yes | |null | |
| resume | text | yes | | null | |
| image | blob | yes | |null | |
+------------+--------------+------+-----+---------+-------+
9 rows in set (0.01 sec)
mysql> alter table employee modify jobvarchar(60);
query ok, 0 rows affected (0.08 sec)
records: 0 duplicates: 0 warnings: 0
mysql> desc employee;
+------------+--------------+------+-----+---------+-------+
| field | type | null | key |default | extra |
+------------+--------------+------+-----+---------+-------+
| id | int(11) | yes | |null | |
| name | varchar(200) | yes | | null | |
| gender | varchar(200) | yes | | null | |
| birthday | date | yes | |null | |
| entry_date | date | yes | | null | |
| job | varchar(60) | yes | |null | |
| salary | float(8,2) | yes | |null | |
| resume | text | yes | |null | |
| image | blob | yes | |null | |
+------------+--------------+------+-----+---------+-------+
9 rows in set (0.01 sec)
mysql> alter table employee
-> drop image;
query ok, 0 rows affected (0.18 sec)
records: 0 duplicates: 0 warnings: 0
mysql> desc employee;
+------------+--------------+------+-----+---------+-------+
| field | type | null | key |default | extra |
+------------+--------------+------+-----+---------+-------+
| id | int(11) | yes | | null | |
| name | varchar(200) | yes | | null | |
| gender | varchar(200) | yes | | null | |
| birthday | date | yes | |null | |
| entry_date | date | yes | | null | |
| job | varchar(60) | yes | |null | |
| salary | float(8,2) | yes | |null | |
| resume | text | yes | |null | |
+------------+--------------+------+-----+---------+-------+
8 rows in set (0.01 sec)
mysql> alter table employee
-> to user;
error 1064 (42000): you have an error inyour sql syntax; check the manual that
corresponds to your mysql server versionfor the right syntax to use near 'to us
er' at line 2
mysql> rename table employee
-> to user;
query ok, 0 rows affected (0.15 sec)
mysql> show tables;
+-----------------+
| tables_in_mydb1 |
+-----------------+
| user |
+-----------------+
1 row in set (0.00 sec)
mysql> show create table user;
+-------+-----------------------------------------------------------------------
--------------------------------------------------------------------------------
--------------------------------------------------------------------------------
--------------------------------------------------------------------------------
----+
| table | create table
|
+-------+-----------------------------------------------------------------------
--------------------------------------------------------------------------------
--------------------------------------------------------------------------------
--------------------------------------------------------------------------------
----+
| user | create table `user` (
`id` int(11) default null,
`name` varchar(200) default null,
`gender` varchar(200) default null,
`birthday` date default null,
`entry_date` date default null,
`job` varchar(60) default null,
`salary` float(8,2) default null,
`resume` text
) engine=innodb default charset=utf8 |
+-------+-----------------------------------------------------------------------
--------------------------------------------------------------------------------
--------------------------------------------------------------------------------
--------------------------------------------------------------------------------
----+
1 row in set (0.00 sec)
mysql> alter table user character setutf8;
query ok, 0 rows affected (0.03 sec)
records: 0 duplicates: 0 warnings: 0
mysql> alter table user change nameusername varchar(100);
query ok, 0 rows affected (0.07 sec)
records: 0 duplicates: 0 warnings: 0
mysql> insert into user values(2,'wangdong','male','1990-09-08','2014-02-17','c
to',100000,'strong man');
query ok, 1 row affected (0.07 sec)
mysql> insert into user values(1,'wangdongxue','male','1990-09-08','2014-02-17'
,'cto',100000,'strong man');
query ok, 1 row affected (0.05 sec)
mysql> insert into user values(1,'wangdongxue','male','1990-09-08','2014-02-17'
,'cto',100000,'strong man');
query ok, 1 row affected (0.00 sec)
mysql> insert into user values(1,'wangdongxue','male','1990-09-08','2014-02-17'
,'cto',100000,'strong man');
query ok, 1 row affected (0.07 sec)
mysql> select * from user;
+------+-------------+--------+------------+------------+------+-----------+----
--------+
| id | username | gender |birthday | entry_date | job | salary | res
ume |
+------+-------------+--------+------------+------------+------+-----------+----
--------+
| 2 | wangdong | male | 1990-09-08 | 2014-02-17 | cto | 100000.00 | str
ong man |
| 1 | wangdongxue | male |1990-09-08 | 2014-02-17 | cto |100000.00 | str
ong man |
| 1 | wangdongxue | male |1990-09-08 | 2014-02-17 | cto |100000.00 | str
ong man |
| 1 | wangdongxue | male | 1990-09-08| 2014-02-17 | cto | 100000.00 | str
ong man |
+------+-------------+--------+------------+------------+------+-----------+----
--------+
4 rows in set (0.06 sec)
mysql> insert into user values (3,'查显成','男性','1988-09-08','2014-02-17','ufo
',100000,'帅锅');
error 1366 (hy000): incorrect string value:'xb2xe9xcfxd4xb3xc9' for colum
n 'username' at row 1
mysql> show variables like'character_set%';
+--------------------------+----------------------------------------------------
-----+
| variable_name | value
|
+--------------------------+----------------------------------------------------
-----+
| character_set_client | utf8
|
| character_set_connection | utf8
|
| character_set_database | utf8
|
| character_set_filesystem | binary
|
| character_set_results | utf8
|
| character_set_server | utf8
|
| character_set_system | utf8
|
| character_sets_dir | d:program filesmysqlmysql server5.1sharechars
ets |
+--------------------------+----------------------------------------------------
-----+
8 rows in set (0.07 sec)
mysql> set character_set_client=gbk;
query ok, 0 rows affected (0.07 sec)
mysql> select * from user;
+------+-------------+--------+------------+------------+------+-----------+----
--------+
| id | username | gender |birthday | entry_date | job | salary | res
ume |
+------+-------------+--------+------------+------------+------+-----------+----
--------+
| 2 | wangdong | male | 1990-09-08 | 2014-02-17 | cto | 100000.00 | str
ong man |
| 1 | wangdongxue | male |1990-09-08 | 2014-02-17 | cto |100000.00 | str
ong man |
| 1 | wangdongxue | male |1990-09-08 | 2014-02-17 | cto |100000.00 | str
ong man |
| 1 | wangdongxue | male |1990-09-08 | 2014-02-17 | cto |100000.00 | str
ong man |
+------+-------------+--------+------------+------------+------+-----------+----
--------+
4 rows in set (0.00 sec)
mysql> insert into user values (3,'汤柳清','男性','1988-09-08','2014-02-17','ufo
',100000,'帅锅');
query ok, 1 row affected (0.02 sec)
mysql> select * from user;
+------+-------------+--------+------------+------------+------+-----------+----
--------+
| id | username | gender |birthday | entry_date | job | salary | res
ume |
+------+-------------+--------+------------+------------+------+-----------+----
--------+
| 2 | wangdong | male | 1990-09-08 | 2014-02-17 | cto | 100000.00 | str
ong man |
| 1 | wangdongxue | male |1990-09-08 | 2014-02-17 | cto | 100000.00| str
ong man |
| 1 | wangdongxue | male |1990-09-08 | 2014-02-17 | cto |100000.00 | str
ong man |
| 1 | wangdongxue | male |1990-09-08 | 2014-02-17 | cto |100000.00 | str
ong man |
| 3 |鏌ユ樉鎴? | 鐢锋
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product