当前位置: 首页 > news >正文

视频网站建设费用明细销售平台排名

视频网站建设费用明细,销售平台排名,做织梦网站之前要新建数据库吗,网站地图后台可以做吗学自B站黑马程序员笔记 一 创建表空间(创建数据文件) 创建表空间同时会创建一个数据文件(下面5行应该是一句话),表空间在PLSQL的Object的tablespace中可以看到 create tablespace waterboss //创建表空间 datafile c:\waterboss.dbf //创建表空间对应的…

学自B站黑马程序员笔记

一 创建表空间(创建数据文件)

创建表空间同时会创建一个数据文件(下面5行应该是一句话),表空间在PLSQL的Object的tablespace中可以看到

create tablespace waterboss      //创建表空间
datafile 'c:\waterboss.dbf'      //创建表空间对应的数据文件(给个地址)
size 100m                        //文件大小100m(先占地方)
autoextend on                    //开启自动拓展100m满了会自动扩充
next 10m;                        //一次拓展10m

二 创建用户

用户建在表空间上,表建在用户上,编程的时候关注用户既可,一个表空间可建多个用户,用户在Object的Users中可以看到,可用该用户登录plsql(需要登录权限)

create user wateruser            //创建用户(3行一句话)
identified by itcast             //创建密码(口令)
default tablespace waterboss;    //指定该用户默认属于哪个表空间grant dba to wateruser;          //赋予用户权限(dba角色权限)

三 数据类型

1. 字符型

(1)CHAR : 固定长度的字符类型,最多存储 2000 个字节

(2)VARCHAR2 :可变长度的字符类型,最多存储 4000 个字节

(3)LONG : 大文本类型。最大可以存储 2 个 G

2. 数值型

NUMBER : 数值类型

例如:NUMBER(5) 最大可以存的数为 99999

NUMBER(5,2) 最大可以存的数为 999.99

3. 日期型

(1)DATE:日期时间型,精确到秒

(2)TIMESTAMP:精确到秒的小数点后 9 位

4. 二进制型(大数据类型)

(1)CLOB : 存储字符,最大可以存 4 个 G

(2)BLOB:存储图像、声音、视频等二进制数据,最多可以存 4 个 G

四 创建表

//创建业主表 于object的tables中可查看
CREATE TABLE T_OWNERS(
ID NUMBER PRIMARY KEY,            //主键
NAME VARCHAR2(30),                //业主名称
ADDRESSID NUMBER,                 //地址id
HOUSENUMBER VARCHAR2(30),         //门牌号
WATERMETER VARCHAR2(30),          //水表编号
ADDDATE DATE,                     //登记日期
OWNERTYPEID NUMBER                //业主类型id
)//修改表-追加字段
ALTER TABLE T_OWNERS ADD(REMARK VARCHAR2(20),OUTDATE DATE
)//修改表-修改字段类型
ALTER TABLE T_OWNERS MODIFY(REMARK CHAR(20),OUTDATE TIMESTAMP
)//修改表-修改字段名OUTDATE变为EXITDATE
ALTER TABLE T_OWNERS RENAME COLUMN OUTDATE TO EXITDATE//修改表-删除字段REMARK
ALTER TABLE T_OWNERS DROP COLUMN REMARK//插入语句,此刻处于事务状态需要进行事务的提交才能查询到
INSERT INTO T_OWNERTYPE (ID,NAME) VALUES (1,'居民');//插入当前系统时间sysdate会返回当前系统时间
insert into T_OWNERS VALUES(1,'邢道荣',1,'1-1','123456',sysdate,1);
commit;//可以通过语句进行commit事务提交//修改语句日期为三天前(支持对日期的运算)3代表3天(默认),年月会用函数
update T_OWNERS SET ADDDATE=ADDDATE-3 WHERE ID=1;//删除语句,TRUNCATE执行效率高于delete,当执行delete时数据并没有真正的删除,只是移动到了回滚段中,此时通过rollback可回滚,可能产生碎片且不释放空间
delete from T_OWNERS WHERE ID=1;//TRUNCATE删除表中数据不需要commit直接执行既可生效,不可回滚,truncate会销毁表之后重建表结构,效率更高
truncate table T_OWNERTYPE

五 建立jdbc链接

  进入oracle包中C:\oracle\product\10.2.0\db_1\jdbc\lib,取出ojdbc14.jar包部署到项目中,而后建立基本访问类

/*基本数据访问类:获取数据库链接,关闭资源*/
public class BaseDao {static{//静态代码块只执行一次,加载驱动try {Class.forName("oracle.jdbc.driver.OracleDriver");} catch (ClassNotFoundException e) {e.printStackTrace();}}//获取数据库链接public static java.sql.Connection getConnection() throws SQLException {//thin表示瘦链接,即程序所在的pc上可以不装oracle的任何东西,胖链接需要在本地装oracle的东西return DriverManager.getConnection("jdbc:oracle:thin:@192.168.80.10:1521:orcl","wateruser","itcast");}//关闭结果集,执行对象,链接对象,不为空才有关闭的必要public static void closeAll(java.sql.ResultSet rs,java.sql.Statement stmt,java.sql.Connection conn){if(rs!=null){try {rs.close();} catch (SQLException e) {e.printStackTrace();}}if(stmt!=null){try {stmt.close();} catch (SQLException e) {e.printStackTrace();}}if(conn!=null){try {conn.close();} catch (SQLException e) {e.printStackTrace();}}}
}

3.建立实体类

public class Owners {private Long id;//编号private String name;//业主名称private Long address;//地址idprivate String housernumber;//门牌号private String watermeter;//水表编号private Date adddate;//增加日期private Long ownertypeid;//业主类型
}

4.编写增删改方法

/*业主的数据访问类*/
public class OwnersDao{//插入方法public static void add(Owners owners){//声明链接对象 预处理对象java.sql.Connection conn=null;java.sql.PreparedStatement stmt=null;try {conn=BaseDao.getConnection();//获取链接//几列就放几个问号(占位符下标从1开始)stmt=conn.prepareStatement("insert into t_owners values(?,?,?,?,?,?,?)");stmt.setLong(1,owners.getId());//设置第一个参数,业主编号stmt.setString(2,owners.getName());//业主名称stmt.setLong(3,owners.getAddress());//地址编号stmt.setString(4,owners.getHousernumber());//门牌号stmt.setString(5,owners.getWatermeter());//水表编号//要求传递sql的date类型,此时传递util的date类型所以报错//通过gettime方法转长整形,通过长整形构造sql的date类型,反过来一样stmt.setDate(6,new java.sql.Date(owners.getAdddate().getTime()));//增加日期stmt.setLong(7,owners.getOwnertypeid());//业主类型stmt.execute();//执行} catch (SQLException e) {e.printStackTrace();} finally {//增删改不涉及结果集故设为nullBaseDao.closeAll(null,stmt,conn);}}//修改方法public static void update(Owners owners){//声明链接对象 预处理对象java.sql.Connection conn=null;java.sql.PreparedStatement stmt=null;try {conn=BaseDao.getConnection();//获取链接//几列就放几个问号(占位符下标从1开始)stmt=conn.prepareStatement("update t_owners set name=?,addressid=?,"+"housenumber=?,watermeter=?,adddate=?,ownertypeid=? where id=?");stmt.setString(1,owners.getName());//业主名称stmt.setLong(2,owners.getAddress());//地址编号stmt.setString(3,owners.getHousernumber());//门牌号stmt.setString(4,owners.getWatermeter());//水表编号//要求传递sql的date类型,此时传递util的date类型所以报错//通过gettime方法转长整形,通过长整形构造sql的date类型,反过来一样stmt.setDate(5,new java.sql.Date(owners.getAdddate().getTime()));//增加日期stmt.setLong(6,owners.getOwnertypeid());//业主类型stmt.setLong(7,owners.getId());//设置第一个参数,业主编号stmt.execute();//执行} catch (SQLException e) {e.printStackTrace();} finally {//增删改不涉及结果集故设为nullBaseDao.closeAll(null,stmt,conn);}}//删除方法public static void delete(Long id){//声明链接对象 预处理对象java.sql.Connection conn=null;java.sql.PreparedStatement stmt=null;try {conn=BaseDao.getConnection();//获取链接//几列就放几个问号(占位符下标从1开始)stmt=conn.prepareStatement("delete from t_owners where id=?");stmt.setLong(1,id);//设置第一个参数,业主编号stmt.execute();//执行} catch (SQLException e) {e.printStackTrace();} finally {//增删改不涉及结果集故设为nullBaseDao.closeAll(null,stmt,conn);}}
}

5.测试

public class Test {public static void main(String[] args) {Owners owners=new Owners();owners.setId(3L);owners.setName("许攸");owners.setAddress(1L);owners.setHousernumber("3-2");owners.setWatermeter("96469");owners.setAdddate(new Date());owners.setOwnertypeid(1L);OwnersDao.add(owners);System.err.println("ok");}
}
public class Test2 {public static void main(String[] args) {Owners owners=new Owners();owners.setId(3L);owners.setName("许攸");owners.setAddress(1L);owners.setHousernumber("3-2");owners.setWatermeter("5555");owners.setAdddate(new Date());owners.setOwnertypeid(1L);OwnersDao.update(owners);System.err.println("ok");}
}
public class Test3 {public static void main(String[] args) {OwnersDao.delete(1L);}
}

六 数据导出与导入

  1. 整库的导入导出(需要dba的权限)
    1. 导出:整库的导出会形成一个文件,服务器的命令行输入(需要有dba权限的账号密码,full=y表示全部的意思y是yes)exp system/password full=y 不指定文件名时导出文件名为EXPDAT.DMP(纯二进制oracle自己的文件)
    2. 导入:若对象存在则自动跳过,命令行输入IMP system/qwer1234 full=y(实质上是执行了一串的create语句),不指定名则找默认文件
    3. 指定导出文件名:exp system/qwer1234 full=y file=water.dmp
    4. 导入指定文件:imp system/itcast full=y file=water.dmp
  2. 用户导入导出
    1. 按用户导出:exp system/qwer1234 owner=wateruser file=wateruser.dmp
    2. 按用户导入:imp system/qwer1234 file=wateruser.dmp fromuser=wateruser
  3. 按表导入导出
    1. 按表导出:exp wateruser/itcast file=a.dmp tables=t_owners,t_ownertype
    2. 按表导入:imp wateruser/itcast file=a.dmp tables=t_owners,t_ownertype
    3. 用tables参数指定需要导出的表,若有多个表用逗号分隔既可,若表在用户下则使用用户帐号和密码,用system找用户下的表是找不到的(需要打点调用)
    4. 可以通过tables指定表名进行导入(dmp中有多个表,我可以只取一个,整库导出也可以只导入一张表)

七 关于重复提交事务的问题

  不同的sql窗口相当于不同的事务,而事务是有隔离级别的,必须等该事务提交之后,其他事务才能查询到,在没有提交事务前,该表会被锁住(出现红色闪电,事务的提交和回滚会进行解锁),操作同一条记录会产生冲突(行级锁)

http://www.dt0577.cn/news/3526.html

相关文章:

  • asp做动态网站长沙专业竞价优化首选
  • 传统网站建设 成本seo推广怎么收费
  • 厦门有设计网站的吗长春seo关键词排名
  • 建网站的方案平台推广广告宣传词
  • wordpress分类显示文章列表郑州百度关键词seo
  • 做网站好的网站建设公司排名网站推广上首页
  • 5000做网站seo需要掌握什么技能
  • 网站地图 用户体验搜索推广出价多少合适
  • wordpress独立登录页面马鞍山seo
  • asp网站域名授权柳州网站建设哪里有
  • 做网站bbs是什么意思在线培训
  • 中信建设网站百度怎么搜索网址打开网页
  • 高端移动网站建设seo是什么的简称
  • 小白怎么做淘宝客网站网站seo策划方案案例分析
  • 中国建设通官方网站百度seo课程
  • 苹果电脑 做网站百度网站免费优化软件下载
  • 律师网站建设品牌semantics
  • 旅游自媒体网站怎么做淘宝运营培训课程免费
  • 青岛网站建设推广推广网站
  • 邢台网站制作怎么样中国舆情在线
  • 做的网站怎样评估价值seo实战培训视频
  • 如何在电脑上建网站广告投放方案
  • 论文网站建设与运营网络游戏排行榜百度风云榜
  • 有没有做家纺类的网站专业seo网站
  • 深圳市建网站公司小吃培训机构排名前十
  • 推广seo网站的公司最近新闻头条
  • 金昌大型网站建设费用深圳企业网站制作
  • 微信公众号管理平台手机版排名优化网站
  • 佛山营销网站建设服务公司seo是如何优化
  • 网络会议网站国内好用的搜索引擎