sql製表符
㈠ oracle中sql*loader製表符的意思
文本文件是沒有格式的,製表符的意思是告訴oracle,這個前面是一個欄位,後面是另一個欄位,整個一行是一個記錄。這樣導入的數據表才不會亂。
㈡ 如何將帶製表符的文本文件導入到SQL表中
1、啟動SQL企業管理器,選中 表格:1、點擊滑鼠右鍵 2、所以任務 3、導入數據
㈢ sql 如何查詢 空值的欄位
sql查詢空值的欄位寫法:SELECT A.欄位 FROM student A WHERE A.欄位 LIKE'% %' (student為表名)
查詢類似空值的寫法:
1、查詢名稱有退格鍵:select * from t_bd_item_info where charindex(char(8),item_name) > 0 go
2、查詢名稱有製表符tab:select * from t_bd_item_info where charindex(char(9),item_name) > 0 go
3、查詢名稱有換行:select * from t_bd_item_info where charindex(char(10),item_name) > 0 go
4、查詢名稱有回車:select * from t_bd_item_info where charindex(char(13),item_name) > 0 go
5、查詢名稱的空格(前空格、後空格、所有空格):select * from t_bd_item_info where isnull(charindex(' ',item_name),0) > 0go
6、查詢名稱的單引號:select * from t_bd_item_info where charindex(char(39),item_name) > 0 go
7、查詢名稱的雙單引號:select * from t_bd_item_info where charindex(char(34),item_name) > 0 go
(3)sql製表符擴展閱讀
1、處理名稱有退格鍵
update t_bd_item_info set item_name = replace(item_name,char(8),'')
where charindex(char(9),item_name) > 0 go
2、處理名稱有製表符tab
update t_bd_item_info set item_name = replace(item_name,char(9),'')
where charindex(char(9),item_name) > 0 go
3、處理名稱有換行
update t_bd_item_info set item_name = replace(item_name,char(10),'')
where charindex(char(10),item_name) > 0 go
4、處理名稱有回車
update t_bd_item_info set item_name = replace(item_name,char(13),'')
where charindex(char(13),item_name) > 0 go
5、處理名稱的空格(前空格、後空格、所有空格)
update t_bd_item_info set item_name = replace(rtrim(ltrim(item_name)),' ','')
where isnull(charindex(' ',item_name),0) > 0go
6、處理名稱的單引號
update t_bd_item_info set item_name = replace(item_name,char(39),'')
where charindex(char(39),item_name) > 0 go
7、處理名稱的雙單引號
update t_bd_item_info set item_name = replace(item_name,char(34),'')
where charindex(char(34),item_name) > 0 go
㈣ java中用「\t」表示空格,那sql中用什麼表示空格呢,(敲空格不算)
先說Java里\t不是空格,是製表符。
㈤ 怎樣將SQL數據導出到EXCEL中
實現步驟: 1、打開MicroSoft Excel 2000 2、文件(F)→新建(N)→工作簿→ 3、輸入SQL*Loader將Excel數據後,存檔為test.xls, 4、文件(F)→另存為(A)→ 保存類型為:製表符分隔,起名為text.txt,保存到C: 5、須先創建表結構: 連入SQL*Plus,以system/manager用戶登錄, 以下是代碼片段: SQL> conn system/manager 創建表結構 以下是代碼片段: SQL> create table test ( id number,--序號 usernamevarchar2(10),--用戶名 passwordvarchar2(10),--密碼 sj varchar2(20) --建立日期 ); 6、創建SQL*Loader輸入數據Oracle資料庫所需要的文件,均保存到C:,用記事本編輯: 控制文件:input.ctl,內容如下: load data --1、控制文件標識 infile 'test.txt' --2、要輸入的數據文件名為test.txtappend into table test--3、向表test中追加記錄 fields terminated by X'09'--4、欄位終止於X'09',是一個製表符(TAB) (id,username,password,sj) -----定義列對應順序 a、insert,為預設方式,在SQL*Loader將Excel數據裝載開始時要求表為空 b、append,在表中追加新記錄 c、replace,刪除舊記錄,替換成新裝載的記錄 d、truncate,同上 7、在DOS窗口下使用SQL*Loader命令實現數據的輸入 以下是代碼片段: C:>sqlldr userid=system/manager control=input.ctl 默認日誌文件名為:input.log 默認壞記錄文件為:input.bad 如果是遠程對SQL*Loader將Excel資料庫進行導入Oracle資料庫操作,則輸入字元串應改為: 以下是代碼片段: C:>sqlldr control=input.ctl 8、連接到SQL*Plus中,查看是否成功輸入,可比較input.log與原test.xls文
㈥ sql正則表達式常用符號
SQL的查詢語句中,有時會需要引進正則表達式為其復雜搜索指定模式。下面給出一些Regexp在
MYSQL語句中應用(非全部):
1) ^
匹配字元串的開始部分。
mysql> SELECT 'fo\nfo' REGEXP '^fo$'; -> 0mysql> SELECT 'fofo' REGEXP '^fo'; -> 12) $
匹配字元串的結束部分。
mysql> SELECT 'fo\no' REGEXP '^fo\no$'; -> 1mysql> SELECT 'fo\no' REGEXP '^fo$'; -> 03) .
匹配任何字元(包括回車和新行)。
mysql> SELECT 'fofo' REGEXP '^f.*$'; -> 1mysql> SELECT 'fo\r\nfo' REGEXP '^f.*$'; -> 14)
[:character_class:]
在括弧表達式中(使用[和]),[:character_class:]表示與術語類的所有字元匹配的字元類。標準的類名稱是:
alnum
文字數字字元
alpha
文字字元
blank
空白字元
cntrl
控制字元
digit
數字字元
graph
圖形字元
lower
小寫文字字元
print
圖形或空格字元
punct
標點字元
space
空格、製表符、新行、和回車
upper
大寫文字字元
xdigit
十六進制數字字元
它們代表在ctype(3)手冊頁面中定義的字元類。特定地區可能會提供其他類名。字元類不得用作范圍的端點。
mysql> SELECT 'justalnums' REGEXP '[[:alnum:]]+'; -> 1
mysql> SELECT '!!' REGEXP '[[:alnum:]]+'; -> 0
5) [[:<:]], [[:>:]]
這些標記表示word邊界。它們分別與word的開始和結束匹配。word是一系列字字元,其前面和後面均沒有字
字元。字字元是alnum類中的字母數字字元或下劃線(_)。
mysql> SELECT 'a word a' REGEXP '[[:<:]]word[[:>:]]'; -> 1mysql> SELECT 'a xword a' REGEXP
'[[:<:]]word[[:>:]]'; -> 0要想在正則表達式中使用特殊字元的文字實例,應在其前面加上2個反斜杠「\」字元。
MySQL解析程序負責解釋其中一個,正則表達式庫負責解釋另一個。例如,要想與包含特殊字元「+」的字元
串「1+2」匹配,在下面的正則表達式中,只有最後一個是正確的:
mysql> SELECT '1+2' REGEXP '1+2'; -> 0mysql> SELECT '1+2' REGEXP '1\+2'; -> 0mysql> SELECT
'1+2' REGEXP '1\\+2'; -> 1 其他的有關Regexp的語法,可直接參考下表:字元 含意
\ 做為轉意,即通常在"\"後面的字元不按原來意義解釋,如/b/匹配字元"b",當b前面加了反斜桿後/\b/,轉意
為匹配一個單詞的邊界。
-或-
對正則表達式功能字元的還原,如"*"匹配它前面元字元0次或多次,/a*/將匹配a,aa,aaa,加了"\"後,/a\*/將
只匹配"a*"。
^ 匹配一個輸入或一行的開頭,/^a/匹配"an A",而不匹配"An a"
$ 匹配一個輸入或一行的結尾,/a$/匹配"An a",而不匹配"an A"
* 匹配前面元字元0次或多次,/ba*/將匹配b,ba,baa,baaa
+ 匹配前面元字元1次或多次,/ba*/將匹配ba,baa,baaa
? 匹配前面元字元0次或1次,/ba*/將匹配b,ba
(x) 匹配x保存x在名為$1...$9的變數中
x|y 匹配x或y
{n} 精確匹配n次
{n,} 匹配n次以上
{n,m} 匹配n-m次
[xyz] 字元集(character set),匹配這個集合中的任一一個字元(或元字元)
[^xyz] 不匹配這個集合中的任何一個字元
[\b] 匹配一個退格符
\b 匹配一個單詞的邊界
\B 匹配一個單詞的非邊界
\cX 這兒,X是一個控制符,/\cM/匹配Ctrl-M
\d 匹配一個字數字元,/\d/ = /[0-9]/
\D 匹配一個非字數字元,/\D/ = /[^0-9]/
\n 匹配一個換行符
\r 匹配一個回車符
\s 匹配一個空白字元,包括\n,\r,\f,\t,\v等
\S 匹配一個非空白字元,等於/[^\n\f\r\t\v]/
\t 匹配一個製表符
\v 匹配一個重直製表符
\w 匹配一個可以組成單詞的字元(alphanumeric,這是我的意譯,含數字),包括下劃線,如[\w]匹配
"$5.98"中的5,等於[a-zA-Z0-9]
\W 匹配一個不可以組成單詞的字元,如[\W]匹配"$5.98"中的$,等於[^a-zA-Z0-9]。
㈦ sql語句中發現一個\t,表示什麼
這個是個CSV個是的數據,"\t"你可以正常理解為製表符,語句的意思是將"d:/temp.csv"裡面的數據導入到表rqusg_chaxun_users,按照"\t"製表符或者"\n"換行符為分隔符進行數據導入。
㈧ sql中char(9) char(10) char(13)分別代表哪個字元
char(9) 水平製表符
char(10)換行鍵
char(13)回車鍵
解題方法如下:
直接在sql的命令框中輸入以下字元:
print 'A'+char(10)+'B'
print 'A'+char(9)+'B'
print 'A'+char(13)+'B'
然後輸出就可以看到它們代表的含義了,這里有個完整的表格也可以參考一下:
(8)sql製表符擴展閱讀:
char(9) 水平製表符這里 水平製表符即tab鍵
一般char(10)char(13)常常可以連著用,表示0x0A0x0D,即一個完整的回車換行。
而且在使用單獨語句查 select char(9) ,char(10), char(13) 可能會發現全是空白,所以最好這樣輸入類似print 'A'+char(10)+'B'這樣才能看到字元的含義。
㈨ sql問題,如何替換掉字元串里的空格為沒有啊
用REPLACE函數來替換。
SQL欄位中的空字元有2種,空格符和tab製表符(即char(9))。
例:去除 表table 中 col 列的空字元
去除空格符:update table set col = REPLACE(col,' ','')
去除製表符:update table set col = REPLACE(col,CHAR(9),'')