黑马程序员技术交流社区

标题: 【石家庄校区】SQL、JDBC笔记 [打印本页]

作者: 花亦ぃ水无情    时间: 2018-5-9 15:51
标题: 【石家庄校区】SQL、JDBC笔记
本帖最后由 小石姐姐 于 2018-5-11 10:10 编辑

SQL、JDBC笔记
SQL
数据库:
创建数据库语法:
create database 数据库名称 [character set 字符集 collate 字符集校对规则];
    create database (name数据库名字);
   create database (name数据库名字) character set (gbk/utf8) collate_bin;

查看数据库语法:
查看数据库服务器中所有的数据库:show databases;
    show databases;
查看某个数据库的定义信息: show create database 数据库名称;
    show create database (name数据库名字);

修改数据库语法:
alter database 数据库名称 character set 字符集 collate 校对规则;
    alter database (name数据库名字) character set (utf8/gbk);

删除数据库语法:
drop database 数据库名称;
    drop database (name);

切换书库库:use 数据库名称;
    use name;

查看当前正在使用的数据库:
    select database();

对数据库表进行操作
创建表:
语法:create table 表名称(字段名称 字段类型(长度)约束,字段名称 字段类型(长度)约束...);
字段类型:
        一个实体对应一个表,一个实体属性对应表的一个字段。

MySQL中的类型:tinyint/smallint/int/bigint         float        double        bit        
char和varchar类型
char和varchar的区别:
char代表是固定长度的字符或字符串。
        定义类型char(8),向这个字段存入字符串hello,那么数据库使用三个空格将其补全。

varchar代表的是可变长度的字符串。
        定义类型varchar(8), 向这个字段存入字符串hello,那么存入到数据库的就是hello。

date/time/datetime/timestamp
datetime和timestamp区别
datetime就是既有日期又有时间的日期类型,如果没有向这个字段中存值,数据库使用null存入到数据库中
timestamp也是既有日期又有时间的日期类型,如果没有向这个字段中存值,数据库使用当前的系统时间存入到数据库中。

约束:
单表约束的分类:
主键约束:primary key 主键约束默认就是唯一 非空的
唯一约束:unique
非空约束:not null

建表语句:
    create table user'表名称'(
            id'字段名称' int'字段类型' primary key'主键约束' auto_increment'自动递增',
            username'字段名称' varchar(20)'字段类型(长度)' unique'唯一约束',
            password'字段名称' varchar(20)'字段类型(长度)' not null'非空约束',
            birthday'字段名称' date'字段类型'
    );
        
查看表:
查看某个数据库下的所有的表:show tables;
查看某个表的结构信息:desc 表名;

删除表:
删除:drop table 表名;

修改表:
添加列:alter table 表名 add 列名 类型(长度) 约束;
    alter table user add image varchar(10) not null;
修改列类型,长度和约束:alter table 表名 modify 列名 类型(长度) 约束;
    alter table user modify image varchar(20);

删除列:alter table 表名 drop 列名;
    alter table user drop image;

修改列名称:alter table 表名 change 旧的列名 新的列名 类型(长度) 约束;
    alter table user change image age int(20) nut null;

修改表名:rename table 表名 to 新的表名;
    rename table user to name;

修改表的字符集:alter table 表名 characher set 字符集;
    alter table user characher set gbk;

对数据库表的记录进行操作(重点)
添加表的记录
语法:
        1:向表中插入某些列:insert into 表名 (列名1,列名2,列名3...) values(值1,值2,值3...);
        2:向表中插入所有列:insert into 表名 values(值1,值2,值3...)
注意:值得类型是字符串或日期类型,使用单引号引起来
直接向数据库中插入中文记录会出现错误!!!
解决方法:
        show variables like '%character%';  --查看数据库中与字符集相关参数:
        需要将MySQL数据库服务器中的客户端部分的字符集改为gbk。
        找到MySQL的安装路径:my.ini文件,修改文件中[client]下的字符集
        services.msc

修改表的记录
语法:
        update 表名 set 列名=值【where 条件】;
修改某一列的所有值:update user set password='abc';
按条件修改数据:update user set pasword='123' where username='aaa';
按条件修改多个列:update user set password='111',age='21' where username='qqq';

删除表的记录
语法:
        delete from 表名 n delete from 表名 [where 条件];
删除表中的记录有两种做法:
delete from user;
删除所有记录,属于DML语句,一条记录一条记录删除。事务可以作用在DML语句上的
truncate table user;
删除所有记录,属于DDL语句,将表删除,然后重新创建一个结构一样的表。事务不能控制DDL的

查询表的记录
语法:
select [distinct] *|列名 from 表 [条件];
查询所有:select * from exam;
查询某一列:select name from exam;多列加","逗号隔开
去重用  distinct   如:select distinct name from exam;

事物:
事物的特点:原子性        一致性        隔离性        持久性
开启事物:start transaction;
提交事物:commit;
回滚事物:rollback;
事物的隔离级别:
read uncommitted        :脏读,不可重复读,虚读都有可能发生
read committed                :避免脏读。但是不可重复读和虚读是有可能发生
repeatable read                :避免脏读和不可重复读,但是虚读有可能发生。
serializable                :避免脏读,不可重复读,虚读。

JDBC的增删改查:
什么是JDBC:
是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,
它由一组用Java语言编写的类和接口组成。JDBC提供了一种基准,
据此可以构建更高级的工具和接口,使数据库开发人员能够编写数据库应用程序
JDBC操作步骤:
1:注册驱动:Class.forName()
2:获得连接:Connection conn = DriverManger.getConnection(url,username,password)// Connection java.sql包下的
3:编写SQL语句,String sql ="",以前的值的地方用占位符代替  ?就是占位符
4:预编译sql并且获得可执行sql语句的对象PreparedStatement ps = conn.prepareStatemet(String sql)
5:为sql语句设置值,用值代替sql语句中的?   ps.setXXX(int n,值) n:代表第几个问号的意思,n从1开始
6:执行sql语句
        如果是查询:ResutSet rs = ps.executeQuery();
                遍历结果集:
        while(rs.next()){
                rs.getXXX(String columnName)/rs.getObject(String columnName) ;
                //columnName默认是表地段名,如果取了别名,用别名
        }
        如果是增删改:int num = ps.executeUpdate() ;// num 代表影响的行数
7:释放资源









欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2