sql数据库⽰例,适合初学者
⼀、数据库概述
数据库(DataBase,DB):指长期保存在计算机的存储设备上,按照⼀定规则组织起来,可以被各种⽤户或应⽤共享的数据集合。(⽂件系统)
数据库管理系统(DataBase Management System,DBMS):指⼀种操作和管理数据库的⼤型软件,⽤于建⽴、使⽤和维护数据库,对数据库进⾏统⼀管理和控制,以保证数据库的安全性和完整性。⽤户通过数据库管理系统访问数据库中的数据。
数据库软件应该为数据库管理系统,数据库是通过数据库管理系统创建和操作的。
数据库:存储、维护和管理数据的集合。
⼆、数据库的安装与配置
* 安装
* 参照图解
* ⼀路下⼀步
* 配置
* 参照图解
* 到选择字符集时停
登录Mysql:
mysql -u root -p abc
* 卸载
1.停⽌mysql服务net stop mysql 启动mysql服务net start mysql
2.卸载mysql
3.到mysql 安装⽬录下的my.ini datadir="C:/ProgramData/MySQL/MySQL Server 5.5/Data/"
* 修改密码
运⾏cmd
* 安装成功了打开cmd --> mysql -uroot -p你的密码
* 修改mysql root⽤户密码
1) 停⽌mysql服务运⾏输⼊services.msc 停⽌mysql服务
或者cmd --> net stop mysql
2) 在cmd下输⼊mysqld--skip-grant-tables 启动服务器光标不动(不要关闭该窗⼝)
3) 新打开cmd 输⼊mysql -u root -p 不需要密码
use mysql;
update user set password=password('abc') WHERE User='root';
4) 关闭两个cmd窗⼝在任务管理器结束mysqld 进程
5) 在服务管理页⾯重启mysql 服务
密码修改完成
数据库中⼀⾏记录与对象之间的关系。
列:字段
⾏:⼀条记录(实体)
public class User{
private int id;
private String name;
private int age;
}
三、sql概述
SQL:Structure Query Language。(结构化查询语⾔)
SQL被美国国家标准局(ANSI)确定为关系型数据库语⾔的美国标准,后来被国际化标准组织(ISO)采纳为关系数据库语⾔的国际标准。
各数据库⼚商都⽀持ISO的SQL标准。普通话
各数据库⼚商在标准的基础上做了⾃⼰的扩展。⽅⾔
四、Sql的分类
DDL**(Data Definition Language):数据定义语⾔,⽤来定义数据库对象:库、表、列等;
CREATE、ALTER、DROP
DML***(Data Manipulation Language):数据操作语⾔,⽤来定义数据库记录(数据);
INSERT、UPDA TE、DELETE
DCL(Data Control Language):数据控制语⾔,⽤来定义访问权限和安全级别;
DQL*****(Data Query Language):数据查询语⾔,⽤来查询记录(数据)。
SELECT
* 注意:sql语句以;结尾
4.1 DDL:操作数据库、表、列等
使⽤的关键字:CREATE、ALTER、DROP
* 4.1.1操作数据库
创建
c reate database mydb1;
Create database mydb2 character set gbk;
Create database mydb3 character set gbk COLLATE gbk_chinese_ci;
查询
查看当前数据库服务器中的所有数据库
show databases;
查看前⾯创建的mydb2数据库的定义信息
Show create database mydb2;
删除前⾯创建的mydb3数据库
Drop database mydb3;
修改
查看服务器中的数据库,并把mydb2的字符集修改为utf8;
alter database mydb2 character set utf8;
删除
drop database mydb3;
* 其他:
查看当前使⽤的数据库
select database();
切换数据库
use mydb2;
* 4.1.2操作数据表
* 语法:
create table 表名(
字段1 字段类型,
字段2 字段类型,
...
字段n 字段类型
)
;
* 常⽤数据类型:
int:整型
double:浮点型,例如double(5,2)表⽰最多5位,其中必须有2位⼩数,即最⼤值为999.99;char:固定长度字符串类型;char(10) 'abc '
varchar:可变长度字符串类型;varchar(10) 'abc'
text:字符串类型;
blob:字节类型;
date:⽇期类型,格式为:yyyy-MM-dd;
time:时间类型,格式为:hh:mm:ss
timestamp:时间戳类型yyyy-MM-dd hh:mm:ss 会⾃动赋值
datetime:⽇期时间类型yyyy-MM-dd hh:mm:ss
当前数据库中的所有表
SHOW TABLES;
查看表的字段信息
DESC employee;
在上⾯员⼯表的基本上增加⼀个image列。
ALTER TABLE employee ADD image blob;
修改job列,使其长度为60。
ALTER TABLE employee MODIFY job varchar(60);
删除image列,⼀次只能删⼀列。
ALTER TABLE employee DROP image;
表名改为user。
RENAME TABLE employee TO user;
查看表格的创建细节
SHOW CREATE TABLE user;
修改表的字符集为gbk
ALTER TABLE user CHARACTER SET gbk;
列名name修改为username
ALTER TABLE user CHANGE name username varchar(100);
删除表
DROP TABLE user ;
4.2 DML操作(重要)
查询表中的所有数据
SELECT * FROM 表名;
DML是对表中的数据进⾏增、删、改的操作。不要与DDL混淆了。
INSERT 、UPDATE、DELETE
⼩知识:
在mysql中,字符串类型和⽇期类型都要⽤单引号括起来。'tom' '2015-09-04' 空值:null 4.2.1插⼊操作:INSERT:
语法:INSERT INTO 表名(列名1,列名2 ...)V ALUES(列值1,列值2...);
注意:列名与列值的类型、个数、顺序要⼀⼀对应。
可以把列名当做java中的形参,把列值当做实参。
值不要超出列定义的长度。
如果插⼊空值,请使⽤null
插⼊的⽇期和字符⼀样,都使⽤引号括起来。
练习:
create table emp(
id int,
name varchar(100),
gender varchar(10),
birthday date,
salary float(10,2),
entry_date date,
resume text
);
INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume)
V ALUES(1,'zhangsan','female','1990-5-10',10000,'2015-5-5-','good girl'); INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume)
V ALUES(2,'lisi','male','1995-5-10',10000,'2015-5-5','good boy');
INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume)
V ALUES(3,'wangwu','male','1995-5-10',10000,'2015-5-5','good boy');
批量插⼊:
INSERT INTO emp V ALUES
(4,'zs','m','2015-09-01',10000,'2015-09-01',NULL),
(5,'li','m','2015-09-01',10000,'2015-09-01',NULL),
(6,'ww','m','2015-09-01',10000,'2015-09-01',NULL);
4.2.2 修改操作UPDATE:
语法:UPDATE 表名SET 列名1=列值1,列名2=列值2 。。。WHERE 列名=值练习:
将所有员⼯薪⽔修改为5000元。
UPDA TE emp SET salary=5000
sql容易学吗将姓名为’zs’的员⼯薪⽔修改为3000元。
UPDA TE emp SET salary=3000 WHERE name=’ zhangsan’;
将姓名为’aaa’的员⼯薪⽔修改为4000元,job改为ccc。
UPDATE emp SET salary=4000,gender='female' WHERE name='lisi';
将wu的薪⽔在原有基础上增加1000元。
UPDATE emp SET salary=salary+1000 WHERE gender='male';
4.2.3 删除操作DELETE:
语法:DELETE FROM 表名【WHERE 列名=值】
练习:
删除表中名称为’zs’的记录。
DELETE FROM emp WHERE name=‘zs’;
删除表中所有记录。
DELETE FROM emp;
使⽤truncate删除表中记录。
TRUNCATE TABLE emp;
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论