⑴ 新手求sql 建表語句 ,各位大神幫幫忙啊。
create table tablename(
num int --序號
,客戶姓名 varchar2(30)
,證件類型 varchar2(10)
,證件號碼 varchar2(255)
,市 varchar2(255)
,縣區 varchar2(255)
,小區街道 varchar2(255)
,樓宇名稱 varchar2(255)
,單元 varchar2(10)
,層數 varchar(10)
,室 varchar2(10)
,模型號碼 varchar2(255)
,機器號 varchar2(255)
,機器類型varchar2(255)
,主從機 varchar2(255)
,當月出賬金額(元) number
,調賬優惠金額(元) number
)
⑵ 如何用sql更改表的列的數據類型和添加新列和約束
如何用sql更改表的列的數據類型和添加新列和約束
--修改插入標題
--A.添加新列
ALTER TABLE 表名 ADD 列名 VARCHAR(20)
--B.修改列名
EXEC sp_rename 'dbo.表名.列名', '新列名', 'COLUMN'
--知識點衍生
--1.刪除列
ALTER TABLE 表名 DROP COLUMN column_b
--2.更改列的數據類型
ALTER TABLE 表名 ALTER COLUMN 列 DECIMAL (5, 2)
--3.添加包含約束的列(唯一約束)
ALTER TABLE 表 ADD 列 VARCHAR(20) NULL
CONSTRAINT 約束名 UNIQUE
--4.添加一個未驗證的check約束
ALTER TABLE 表 WITH NOCHECK
ADD CONSTRAINT 約束名 CHECK (列 > 1)
--5.在現有列中添加一個DEFAULT約束
ALTER TABLE 表
ADD CONSTRAINT 約束名
DEFAULT 50 FOR 列名
--6.刪除約束
ALTER TABLE 表 DROP CONSTRAINT 約束名
--7.更改排序規則
ALTER TABLE 表
ALTER COLUMN 列 varchar(50) COLLATE Latin1_General_BIN
--8.修改表名
EXEC sp_rename 'dbo.表名', '新表名'
--9.重命名索引
EXEC sp_rename N'dbo.表名.索引名', N'新索引名', N'INDEX'
⑶ 在sql語句里怎麼轉數據類型
alter
table
表名
alter
column
列名
新的數據類型[(長度)]
null或not
null
例:alter
table
教師
alter
column
辦公室
char(20)
not
null
default
"辦公室"
把寫好的句子放到執行其他sql語句的地方比如execute(sql)這樣的地方,執行一次就行,然後改回來。
⑷ SQL的數據類型
【三】SQL的數據類型(表的欄位類型)
3.1 四種基本的常用數據類型(表的欄位類型)
1、字元型,2、數值型,3、日期型,4、大對象型
3.1.1 字元型:
字元類型char和varchar2的區別
SCOTT@ prod> create table t1(c1 char(10),c2 varchar2(10));
SCOTT@ prod> insert into t1 values('a','ab');
SCOTT@ prod> select length(c1),length(c2) from t1; char和varchar2默認以byte為計算單位
LENGTH(C1) LENGTH(C2)
---------- ----------
10 2
3.1.2 數值型:
3.1.3 日期型:
系統安裝後,默認日期格式是DD-MON-RR, RR和YY都是表示兩位年份,但RR是有世紀認知的,它將指定日期的年份和當前年份比較後確定年份是上個世紀還是本世紀(如表)。
當前年份 指定日期 RR格式 YY格式
------------------------------------------------------------------------------
1995 27-OCT-95 1995 1995
1995 27-OCT-17 2017 1917
2001 27-OCT-17 2017 2017
2013 27-OCT-95 1995 2095
3.1.4 LOB型:
大對象是10g 引入的,在11g中又重新定義,在一個表的欄位里存儲大容量數據,所有大對象最大都可能達到4G。CLOB,NCLOB,BLOB都是內部的LOB類型,沒有LONG只能有一列的限制。
保存圖片或電影使用BLOB最好、如果是小說則使用CLOB最好。雖然LONG、RAW也可以使用,但LONG是oracle將要廢棄的類型,因此建議用LOB。
雖說將要廢棄,但還沒有完全廢棄,比如oracle 11g里的一些視圖如dba_views,對於text(視圖定義)仍然沿用了LONG類型。
Oracle 11g重新設計了大對象,推出SecureFile Lobs的概念,相關的參數是db_securefile,採用SecureFile Lobs的前提條件是11g以上版本,ASSM管理等,符合這些條件的。BasicFile Lobs也可以轉換成SecureFile Lobs。較之過去的BasicFile Lobs, SecureFile Lobs有幾項改進:
1)壓縮,2)去重,3)加密。
當create table定義LOB列時,也可以使用LOB_storage_clause指定SecureFile Lobs或BasicFile Lobs,而LOB的數據操作則使用Oracle提供的DBMS_LOB包,通過編寫PL/SQL塊完成LOB數據的管理。
3.2 數據類型的轉換
3.2.1 轉換的需求
什麼情況下需要數據類型轉換
1)如果表中的某欄位是日期型的,而日期又是可以進行比較和運算的,這時通常要保證參與比較和運算的數據類型都是日期型。
2)當對函數的參數進行抽(截)取、拼接,或運算等操作時,需要轉換為那個函數的參數要求的數據類型。
3)製表輸出有格式需求的,可將date類型,或number類型轉換為char類型
4)轉換成功是有條件的,有隱性轉換和顯性轉換兩種方式
3.2.2隱性類型轉換:
是指oracle自動完成的類型轉換。在一些帶有明顯意圖的字面值上,可以由Oracle自主判斷進行數據類型的轉換。
一般規律:
①比較、運算或連接時:
SQL> select empno,ename from emp where empno='7788'
empno本來是數值類型的,這里字元'7788'隱性轉換成數值7788
SQL> SELECT '12.5'+11 FROM al;
將字元型『12.5』運轉成數字型再求和
SQL> SELECT 10+('12.5'||11) FROM al;
將數字型11隱轉成字元與『12.5』合並,其結果再隱轉數字型與10求和
②調用函數時
SQL> select length(sysdate) from al;
將date型運轉成字元型後計算長度
③向表中插入數據時
create table scott. t1 (id int,name char(10),birth date);
insert into scott.t1 values('123',456,'2017-07-15');
按照欄位的類型進行隱式轉換
3.2.3 顯性類型轉換
即強制完成類型轉換(推薦),有三種形式的數據類型轉換函數:
TO_CHAR
TO_DATE
TO_NUMBER
1)日期-->字元
SQL> select ename,hiredate, to_char(hiredate, 'DD-MON-YY') month_hired from emp
where ename='SCOTT';
ENAME HIREDATE MONTH_HIRED
---------- ------------------- --------------
SCOTT 1987-04-19 00:00:00 19-4月 -87
fm壓縮空格或左邊的'0'
SQL> select ename, hiredate, to_char(hiredate, 'fmyyyy-mm-dd') month_hired from emp
where ename='SCOTT';
ENAME HIREDATE MONTH_HIRED
---------- ------------------- ------------
SCOTT 1987-04-19 00:00:00 1987-4 19
其實DD-MM-YY是比較糟糕的一種格式,因為當日期中天數小於12時,DD-MM-YY和MM-DD-YY容易造成混亂。
以下用法也很常見:
SQL> select to_char(hiredate,'yyyy') FROM emp;
SQL> select to_char(hiredate,'mm') FROM emp;
SQL> select to_char(hiredate,'dd') FROM emp;
SQL> select to_char(hiredate,'DAY') FROM emp;
2)數字-->字元:9表示數字,L本地化貨幣字元
SQL> select ename, to_char(sal, 'L99,999.99') Salary from emp where ename='SCOTT';
ENAME SALARY
---------- --------------------
SCOTT 3,000.00
以下四個語句都是一個結果:
SQL> select to_char(1890.55,'$99,999.99') from al;
SQL> select to_char(1890.55,'$0G000D00') from al;
SQL> select to_char(1890.55,'$99G999D99') from al;
SQL> select to_char(1890.55,'$99G999D00') from al; 9和0可用,其他數字不行
3)字元-->日期
SQL> select to_date('1983-11-12', 'YYYY-MM-DD') tmp_DATE from al;
4)字元-->數字:
SQL> SELECT to_number('$123.45','$9999.99') result FROM al;
使用to_number時如果使用較短的格式掩碼轉換數字,就會返回錯誤。不要混淆to_number和to_char轉換。
SQL> select to_number('123.56','999.9') from al;
報錯:ORA-01722: 無效數字
練習:建立t1表,包括出生日期,以不同的日期描述方法插入數據,顯示小於15歲的都是誰
SQL> create table t1 (id int,name char(10),birth date);
insert into t1 values(1,'tim',sysdate);
insert into t1 values(2,'brian',sysdate-365*20);
insert into t1 values(3,'mike',to_date('1998-05-11','yyyy-mm-dd'));
這一句也可以寫成insert into t1 values(3,'mike',to_date('1998-05-11')),因為'1998-05-11'是和當前日期格式匹配的。
insert into t1 values(4,'nelson',to_date('15-2月-12','dd-mon-rr'));
SQL> select * from t1;
ID NAME BIRTH
---------- ---------- -------------------
1 tim 2016-02-25 17:34:00
2brian 1996-03-01 17:34:22
3 mike 1998-05-11 00:00:00
4 nelson 2012-02-15 00:00:00
SQL> select name||'的年齡是'||to_char(months_between(sysdate,birth)/12,99) age from t1
where months_between(sysdate,birth)/12<15;
AGE
-------------------------
tim 的年齡是 0
nelson 的年齡是 4
the end !!!
@jackman 共築美好!