|
2009年2月18日
1. Change to aliyun repository 2. Chinese input method sudo apt-get install ibus-pinyin
#remmeber to logout and re-logon to change system 'Region&Language' setting 3. Shadowsocks and genpac sudo apt install -y shadowsocks-libev
#sudo vi /etc/shadowsocks-libev/shadowsock.json { "server":"x.x.x.x", "server_port":xx, "local_port":1080, "password":"xxxxx", "timeout":60, "method":"aes-256-cfb" }
nohup ss-local -c /etc/shadowsocks-libev/shadowsock.json >/dev/null 2>&1 & sudo apt install phython-pip sudo -H pip install genpac
如果pip error "TypeError: unsupported operand type(s) for -=: 'Retry' and 'int'" sudo python -m pip install --upgrade --force pip
mkdir pac cd pac touch user-rules.txt
genpac --pac-proxy "SOCKS5 127.0.0.1:1080" --gfwlist-proxy="SOCKS5 127.0.0.1:1080" --output="autoproxy.pac" --gfwlist-url="https://raw.githubusercontent.com/gfwlist/gfwlist/master/gfwlist.txt" --user-rule-from="user-rules.txt" 配置系統自動代理為: /home/xxx/pac/autoproxy.pac 4. JDK8
https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html download and setup environment variable manually
5.gcloud
http://ubuntuhandbook.org/index.php/2014/10/google-cloud-sdk-made-into-canonical-partners-repository/
官方說明: http://source.android.com/source/initializing.html
環境:
Ubuntu 12.04 64bit
JDK6(installation: http://www.gaggl.com/2012/04/installing-java6-jdk-on-ubuntu-12-04/)
$ make -v
GNU Make 3.81
Copyright (C) 2006 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.
There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A
PARTICULAR PURPOSE.
This program built for x86_64-pc-linux-gnu
$ python -V
Python 2.7.3
android 當前 mainfest version: 4.2
按照官方說明從下載到運行emulator,沒有nexus,所以沒做實際機器燒錄。步驟請根據官方說明做,以下只列出過程遇到的問題: 1.repo sync 經常出現斷線,網上有很多參考辦法,我是每次忽略這些錯誤,直到運行完畢退出,我再重新運行: repo sync -f 知道所有代碼下載完畢(4.2的有16G) 2.每次跑emulator都要cd到代碼目錄先進行環境初始化 source build/envsetup.sh lunch full-eng 3.emulator出錯 $ emulator emulator: WARNING: system partition size adjusted to match image file (229 MB > 200 MB)
Spring 聲明式事務讓我們從復雜的事務處理中得到解脫。使得我們再也無需要去處理獲得連接、關閉連接、事務提交和回滾等這些操作。再也無需要我們在與事務相關的方法中處理大量的 try… catch … finally 代碼。 我們在使用 Spring 聲明式事務時,有一個非常重要的概念就是事務屬性。事務屬性通常由事務的傳播行為,事務的隔離級別,事務的超時值和事務只讀標志組成。我們在進行事務劃分時,需要進行事務定義,也就是配置事務的屬性。 Spring 在 TransactionDefinition 接口中定義這些屬性 , 以供 PlatfromTransactionManager 使用 , PlatfromTransactionManager 是 spring 事務管理的核心接口。 l getTimeout() 方法,它返回事務必須在多少秒內完成。 l isReadOnly() , 事務是否只讀,事務管理器能夠根據這個返回值進行優化,確保事務是只讀的。 l getIsolationLevel() 方法返回事務的隔離級別,事務管理器根據它來控制另外一個事務可以看到本事務內的哪些數據。 在 TransactionDefinition 接口中定義了五個不同的事務隔離級別: l ISOLATION_DEFAULT 這是一個 PlatfromTransactionManager 默認的隔離級別,使用數據庫默認的事務隔離級別 . 另外四個與 JDBC 的隔離級別相對應 l ISOLATION_READ_UNCOMMITTED 這是事務最低的隔離級別,它充許別外一個事務可以看到這個事務未提交的數據。這種隔離級別會產生臟讀,不可重復讀和幻像讀。 例如 : Mary的原工資為 1000, 財務人員將 Mary 的工資改為了 8000 ,但未提交事務 與此同時, Mary正在讀取自己的工資 Mary 發現自己的工資變為了 8000 ,歡天喜地! 而財務發現操作有誤,而回滾了事務 ,Mary 的工資又變為了 1000. 像這樣 ,Mary 記取的工資數 8000 是一個臟數據。 l ISOLATION_READ_COMMITTED 保證一個事務修改的數據提交后才能被另外一個事務讀取。另外一個事務不能讀取該事務未提交的數據。這種事務隔離級別可以避免臟讀出現,但是可能會出現不可重復讀和幻像讀。 l ISOLATION_REPEATABLE_READ 這種事務隔離級別可以防止臟讀,不可重復讀。但是可能出現幻像讀。它除了保證一個事務不能讀取另一個事務未提交的數據外,還保證了避免下面的情況產生 ( 不可重復讀 ) 。 在事務 1 中, Mary 讀取了自己的工資為 1000, 操作并沒有完成 在事務 2 中,這時財務人員修改了 Mary 的工資為 2000, 并提交了事務 . 在事務 1 中,Mary 再次讀取自己的工資時,工資變為了 2000 在一個事務中前后兩次讀取的結果并不致,導致了不可重復讀。 使用 ISOLATION_REPEATABLE_READ 可以避免這種情況發生。 l ISOLATION_SERIALIZABLE 這是花費最高代價但是最可靠的事務隔離級別。事務被處理為順序執行。除了防止臟讀,不可重復讀外,還避免了幻像讀。 目前工資為 1000 的員工有 10人。 事務 1, 讀取所有工資為 1000 的員工。 共讀取 10 條記錄 這時另一個事務向 employee表插入了一條員工記錄,工資也為 1000 事務 1 再次讀取所有工資為 1000 的員工 共讀取到了 11 條記錄,這就產生了幻像讀。 ISOLATION_SERIALIZABLE 能避免這樣的情況發生。但是這樣也耗費了最大的資源。 getPropagationBehavior () 返回事務的傳播行為,由是否有一個活動的事務來決定一個事務調用。 在 TransactionDefinition 接口中定義了七個事務傳播行為: l PROPAGATION_REQUIRED 如果存在一個事務,則支持當前事務。如果沒有事務則開啟一個新的事務。 使用 spring 聲明式事務, spring 使用 AOP 來支持聲明式事務,會根據事務屬性,自動在方法調用之前決定是否開啟一個事務,并在方法執行之后決定事務提交或回滾事務。 單獨調用 methodB 方法 相當于 Spring 保證在 methodB 方法中所有的調用都獲得到一個相同的連接。在調用 methodB 時,沒有一個存在的事務,所以獲得一個新的連接,開啟了一個新的事務。 單獨調用 MethodA 時,在 MethodA 內又會調用 MethodB. 執行效果相當于 調用 MethodA 時,環境中沒有事務,所以開啟一個新的事務 . 當在 MethodA 中調用MethodB 時,環境中已經有了一個事務,所以 methodB 就加入當前事務。 l PROPAGATION_SUPPORTS 如果存在一個事務,支持當前事務。如果沒有事務,則非事務的執行。但是對于事務同步的事務管理器, PROPAGATION_SUPPORTS 與不使用事務有少許不同。 單純的調用 methodB 時, methodB 方法是非事務的執行的。 當調用 methdA時 ,methodB 則加入了 methodA 的事務中 , 事務地執行。 l PROPAGATION_MANDATORY 如果已經存在一個事務,支持當前事務。如果沒有一個活動的事務,則拋出異常。 當單獨調用 methodB 時,因為當前沒有一個活動的事務,則會拋出異常 throw new IllegalTransactionStateException("Transaction propagation ''mandatory'' but no existing transaction found"); 當調用 methodA 時, methodB 則加入到 methodA 的事務中,事務地執行。 l PROPAGATION_REQUIRES_NEW 總是開啟一個新的事務。如果一個事務已經存在,則將這個存在的事務掛起。 當單獨調用 methodB 時,相當于把 methodb 聲明為 REQUIRED 。開啟一個新的事務,事務地執行。 當調用 methodA 時 情況有些大不一樣 . 相當于下面的效果。 在這里,我把 ts1 稱為外層事務, ts2 稱為內層事務。從上面的代碼可以看出, ts2 與ts1 是兩個獨立的事務,互不相干。 Ts2 是否成功并不依賴于 ts1 。如果 methodA 方法在調用 methodB 方法后的 doSomeThingB 方法失敗了,而 methodB 方法所做的結果依然被提交。而除了 methodB 之外的其它代碼導致的結果卻被回滾了。 使用PROPAGATION_REQUIRES_NEW, 需要使用 JtaTransactionManager 作為事務管理器。 l PROPAGATION_NOT_SUPPORTED 總是非事務地執行,并掛起任何存在的事務。 當單獨調用 methodB 時,不啟用任何事務機制,非事務地執行。 當調用 methodA 時,相當于下面的效果 使用 PROPAGATION_NOT_SUPPORTED, 也需要使用 JtaTransactionManager 作為事務管理器。 l PROPAGATION_NEVER 總是非事務地執行,如果存在一個活動事務,則拋出異常 單獨調用methodB ,則非事務的執行。 調用 methodA 則會拋出異常 l PROPAGATION_NESTED 如果一個活動的事務存在,則運行在一個嵌套的事務中 . 如果沒有活動事務 , 則按 TransactionDefinition.PROPAGATION_REQUIRED 屬性執行 這是一個嵌套事務 , 使用 JDBC 3.0 驅動時 , 僅僅支持 DataSourceTransactionManager 作為事務管理器。需要 JDBC 驅動的 java.sql.Savepoint 類。有一些 JTA 的事務管理器實現可能也提供了同樣的功能。 使用 PROPAGATION_NESTED ,還需要把 PlatformTransactionManager 的nestedTransactionAllowed 屬性設為 true; 而 nestedTransactionAllowed 屬性值默認為false; 如果單獨調用 methodB 方法,則按 REQUIRED 屬性執行。 如果調用 methodA 方法,相當于下面的效果 當 methodB 方法調用之前,調用 setSavepoint 方法,保存當前的狀態到 savepoint 。如果 methodB 方法調用失敗,則恢復到之前保存的狀態。但是需要注意的是,這時的事務并沒有進行提交,如果后續的代碼 (doSomeThingB() 方法 ) 調用失敗,則回滾包括 methodB 方法的所有操作。 嵌套事務一個非常重要的概念就是內層事務依賴于外層事務。外層事務失敗時,會回滾內層事務所做的動作。而內層事務操作失敗并不會引起外層事務的回滾。 PROPAGATION_NESTED 與 PROPAGATION_REQUIRES_NEW 的區別: 它們非常類似 , 都像一個嵌套事務,如果不存在一個活動的事務,都會開啟一個新的事務。使用PROPAGATION_REQUIRES_NEW 時,內層事務與外層事務就像兩個獨立的事務一樣,一旦內層事務進行了提交后,外層事務不能對其進行回滾。兩個事務互不影響。兩個事務這是一個真正的嵌套事務。同時它需要 JTA 事務管理器的支持。 使用 PROPAGATION_NESTED 時,外層事務的回滾可以引起內層事務的回滾。而內層事務的異常并不會導致外層事務的回滾,它是一個真正的嵌套事務。 DataSourceTransactionManager 使用 savepoint 支持PROPAGATION_NESTED 時,需要 JDBC 3.0 以上驅動及 1.4 以上的 JDK 版本支持。其它的JTA TrasactionManager 實現可能有不同的支持方式。 PROPAGATION_REQUIRED 應該是我們首先的事務傳播行為。它能夠滿足我們大多數的事務需求。
參考這篇文章: http://blog.csdn.net/bluishglc/article/details/6632280 一。Maven的執行方式 maven對構建(build)的過程進行了抽象和定義,這個過程被稱為構建的生命周期(lifecycle)。生命周期(lifecycle)由多個階段(phase)組成,每個階段(phase)會掛接一到多個goal。goal是maven里定義任務的最小單元,goal分為兩類,一類是綁定phase的,就是執行到某個phase,那么這個goal就會觸發,另外一類不綁定,就是單獨任務,這就相當于ant里的target。
1。以phase來構建 例如: mvn clean mvn compile mvn test mvn package 表明maven會執行到某個生命周期(lifecycle)的某個階段(phase) 這個phase以及它前面所有phase綁定的目標(goal)都會執行, 每個phase都會邦定maven默認的goal或者沒有goal, 或者自定義的goal。 也可以通過傳入參數跳過(skip)某些phase,例如: mvn install -Dmaven.test.skip=true 1。以goal來構建 這類就是沒有綁定phase的goal,但是這類goal卻通常會有個執行前提,就是project必須執行到某個phase, 那么執行這個goal,其實也會觸發maven執行到前提要求的phase。 例如jetty:run是個非綁定phase的goal,它的前提是 test-compile,這個前提是由plugin的代碼邏輯制定的/** * @goal run * @requiresDependencyResolution runtime * @execute phase="test-compile" * @description Runs jetty6 directly from a maven project */ public class Jetty6RunMojo extends AbstractJettyRunMojo { ... }
二。Maven lifecycle, phase概覽 Maven預設了三個Lifecycle ,各包含了下列Phases.- Clean Lifecycle
- Default Lifecycle
- validate
- initialize
- generate-sources
- process-sources
- generate-resources
- process-resources
- compile
- process-classes
- generate-test-sources
- process-test-sources
- process-test-resources
- test-compile
- process-test-classes
- test
- prepare-package
- package
- pre-integration-test
- integration-test
- post-integration-test
- verify
- install
- deploy
- Site Lifecycle
- pre-site
- site
- post-site
- site-deploy
1.Window
- java -classpath .;jar1;jar2 MainClass
注意: -classpath參數必須放于前面。
- java -jar jar1
jar包的MANIFEST.MF文件:
Manifest-Version: 1.0
Main-Class: com.Main1
Class-Path: jar1.jar;jar2.jar
注意: 使用-jar參數,那么主jar包必須含有MANIFEST.MF信息,并且指定Main-Class & Class-Path。命令行的-classpath參數將被忽略
2.Linux 區別: 目錄分隔符由\變成/ jar包分隔符由;變成: Window測試環境是Sun java version "1.6.0_14" 其他版本沒有驗證
1.綁定本地接口,自動生成代理對象 復制下面鏈接代碼 // Endpoint Address String endpointAddress = "http://localhost:8111/helloWorld"; // Add a port to the Service service.addPort(PORT_NAME, SOAPBinding.SOAP11HTTP_BINDING, endpointAddress); HelloService hw = service.getPort(HelloService.class);
java -Dhttp.proxyHost=127.0.0.1 -Dhttp.proxyPort=8888 -Dhttps.proxyHost=127.0.0.1 -Dhttps.proxyPort=8888
Java Keytool Commands for Creating and ImportingThese commands allow you to generate a new Java Keytool keystore file, create a CSR, and import certificates. Any root or intermediate certificates will need to be imported before importing the primary certificate for your domain. - Generate a Java keystore and key pair
keytool -genkey -alias mydomain -keyalg RSA -keystore keystore.jks -keysize 2048 - Generate a certificate signing request (CSR) for an existing Java keystore
keytool -certreq -alias mydomain -keystore keystore.jks -file mydomain.csr - Import a root or intermediate CA certificate to an existing Java keystore
keytool -import -trustcacerts -alias root -file Thawte.crt -keystore keystore.jks - Import a signed primary certificate to an existing Java keystore
keytool -import -trustcacerts -alias mydomain -file mydomain.crt -keystore keystore.jks - Generate a keystore and self-signed certificate (see How to Create a Self Signed Certificate using Java Keytool for more info)
keytool -genkey -keyalg RSA -alias selfsigned -keystore keystore.jks -storepass password -validity 360 -keysize 2048
Java Keytool Commands for CheckingIf you need to check the information within a certificate, or Java keystore, use these commands. - Check a stand-alone certificate
keytool -printcert -v -file mydomain.crt - Check which certificates are in a Java keystore
keytool -list -v -keystore keystore.jks - Check a particular keystore entry using an alias
keytool -list -v -keystore keystore.jks -alias mydomain
Other Java Keytool Commands- Delete a certificate from a Java Keytool keystore
keytool -delete -alias mydomain -keystore keystore.jks - Change a Java keystore password
keytool -storepasswd -new new_storepass -keystore keystore.jks - Export a certificate from a keystore
keytool -export -alias mydomain -file mydomain.crt -keystore keystore.jks - List Trusted CA Certs
keytool -list -v -keystore $JAVA_HOME/jre/lib/security/cacerts - Import New CA into Trusted Certs
keytool -import -trustcacerts -file /path/to/ca/ca.pem -alias CA_ALIAS -keystore $JAVA_HOME/jre/lib/security/cacerts
第一種方式:適合于全部HTML標簽
<acronym title="World Wide Web">
WWW
</acronym>
第二種方式:IMG之類的標簽例如:
<img src="#" alt="鼠標移動到上方會顯示并且未加載圖片時也會顯示">
第三種方式:input之類的標簽例如:
<input type="button" value="確定" title="鼠標移動到上方會顯示并且未加載圖片時也會顯示">
|
第一:簡單的使用axis2包自己實現調用
package common;
import javax.xml.namespace.QName;
import org.apache.axis2.AxisFault;
import org.apache.axis2.addressing.EndpointReference;
import org.apache.axis2.client.Options;
import org.apache.axis2.rpc.client.RPCServiceClient;
public class WebServiceUtils
{
// ----------------------------------------------------- Properties
public static int TIMEOUT = 100000;
// ----------------------------------------------------- Constructors
// ----------------------------------------------------- Methods
/**
*
* 調用axis2的webservice的方法
*
* @return
*/
@SuppressWarnings("unchecked")
static public Object[] invokeWebService( String url, String nameSpace, String method, Object[] args, Class[] returnTypes )
throws AxisFault
{
RPCServiceClient serviceClient = new RPCServiceClient();
Options options = serviceClient.getOptions();
EndpointReference targetEPR = new EndpointReference( url );
options.setTo( targetEPR );
options.setTimeOutInMilliSeconds( TIMEOUT );
QName opName = new QName( nameSpace, method );
Object[] results = serviceClient.invokeBlocking( opName, args, returnTypes );
return results;
}
}
第二:
public static OMElement getEchoOMElement() {
OMFactory fac = OMAbstractFactory.getOMFactory();
OMNamespace omNs = fac.createOMNamespace(
"http://example1.org/example1", "example1");
OMElement method = fac.createOMElement("echo", omNs);
OMElement value = fac.createOMElement("Text", omNs);
value.addChild(fac.createOMText(value, "Axis2 Echo String "));
method.addChild(value);
return method;
}
public static void main(String[] args) {
try {
OMElement payload = ClientUtil.getEchoOMElement();
Options options = new Options();
options.setTo(targetEPR);
options.setAction("urn:echo");
//Blocking invocation
ServiceClient sender = new ServiceClient();
sender.setOptions(options);
OMElement result = sender.sendReceive(payload);
System.out.println(result);
System.out.println(options.getTo());
} catch (AxisFault axisFault) {
axisFault.printStackTrace();
}
}
第三:
利用插件生成客戶端
private static String URL="http://localhost:8080/axis2/services/WeatherService";
public static void main(String[] args) throws RemoteException {
try {
WeatherServiceStub stub;
if (args != null && args.length != 0) {
stub = new WeatherServiceStub(args[0]);
} else {
stub = new WeatherServiceStub(URL);
}
WeatherServiceStub.SetWeather setWether = new WeatherServiceStub.SetWeather();
WeatherServiceStub.Weather wether = new WeatherServiceStub.Weather();
wether.setForecast("east");
wether.setRain(true);
wether.setTemperature(12.3f);
wether.setForecast("big");
setWether.setWeather(wether);
stub.setWeather(setWether);
WeatherServiceStub.GetWeatherResponse gw = new WeatherServiceStub.GetWeatherResponse();
System.out.println(gw.get_return());
} catch (AxisFault e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
本文部分來自CSDN博客,轉載請標明出處:http://blog.csdn.net/yhhah/archive/2009/05/07/4158487.aspx
IE的 script 元素支持onreadystatechange事件,不支持onload事件。
FF的script 元素不支持onreadystatechange事件,只支持onload事件。
如果要在一個<script src="xx.js"> 加載完成執行一個操作,FF使用onload事件就行了,IE下則要結合onreadystatechange事件和this.readyState
var loadScript = function(fileName,callback) {
var scriptTag = document.createElement("script");
scriptTag.src = fileName;
document.body.appendChild(scriptTag);
if (callback) {
scriptTag.onload = callback;//ff
scriptTag.onreadystatechange = function()//ie
{
if (scriptTag.readyState == "loaded") {
callback();
}
}
}
}
關鍵是查詢v$locked_object
select sess.sid,
sess.serial#,
lo.oracle_username,
lo.os_user_name,
ao.object_name,
lo.locked_mode
from v$locked_object lo,
dba_objects ao,
v$session sess
where ao.object_id = lo.object_id and lo.session_id = sess.sid;
或者
select * from v$session t1, v$locked_object t2 where t1.sid = t2.SESSION_ID;
殺掉進程:
alter system kill session 'sid,serial#';
--創建臨時表空間
create temporary tablespace dbuser_temp
tempfile 'D:\oracle\product\10.1.0\oradata\btx\dbuser_temp01.dbf'
size 32m
autoextend on
next 32m maxsize 2048m
extent management local;
--創建數據表空間
create tablespace dbuser_data
logging
datafile 'D:\oracle\product\10.1.0\oradata\btx\dbuser_data01.dbf'
size 32m
autoextend on
next 32m maxsize 2048m
extent management local;
--或者自己控制增長規則
--pctincreate表示下一次增長是前一次增長的110%
create tablespace dbuser_data logging datafile 'D:/oracle/product/10.1.0/oradata/btx/DBUSER_DATA01.DBF' size 32m autoextend on next 5m maxsize unlimited default storage (initial 32m next 5m pctincrease 10);
--修改表空間
alter tablespace dbuser_data add datafile 'D:/oracle/product/10.1.0/oradata/btx/DBUSER_DATA02.DBF' size 32m autoextend on next 5m maxsize unlimited;
--創建用戶與指定默認數據表空間與默認臨時表空間
create user dbuser identified by dbuser
default tablespace dbuser_data
temporary tablespace dbuser_temp;
--修改用戶表空間
alter user dbuser default tablespace dbuser_data temporary tablespace dbuser_temp;
--為用戶賦權
grant connect,resource to dbuser;
修改表空間
查詢oracle表空間使用狀況
SELECT b.tablespace_name "表空間名",total 表空間大小,free 表空間剩余大小,
(total-free) 表空間使用大小,
ROUND((total-free)/total,4)*100 "使用率 %"
FROM (SELECT tablespace_name,SUM(bytes) free FROM DBA_FREE_SPACE
GROUP BY tablespace_name ) a,
(SELECT tablespace_name,SUM(bytes) total FROM DBA_DATA_FILES
GROUP BY tablespace_name) b
WHERE a.tablespace_name=b.tablespace_name ;
恢復表數據:
alter table 表名 enable row movement;
flashback table 表名 TO TIMESTAMP to_timestamp('2009-08-07 18:34:00','yyyy-mm-dd hh24:mi:ss');
恢復存儲過程:
select text from dba_source as of timestamp to_timestamp('2009-03-06 09:45:00', 'YYYY-MM-DD HH24:MI:SS') where owner='IPRA' and name= 'P_IPACCHECK_NC' order by line;
需要sys用戶
否則不夠權限
或者登錄數據庫所在主機,使用數據庫管理者的系統用戶登錄
視圖:(受權限過濾了)
all_tables 所有表
all_indexs 所有索引
all_tab_columns 所有列,可以查看列的類型
(dba權限包括所有)
dba_tables
dba_tab_columns
dba_free_space 各對象的剩余空間
dba_data_files 各數據空間的文件信息
dba_tablespaces 表空間信息
常用字符函數
函數
|
描述
|
LOWER(char)
|
將字符串表達式char中的所有大寫字母轉換為小寫字母
|
UPPER(char)
|
將字符串表達式char中的所有小寫字母轉換為大寫字母
|
INITCAP(char)
|
首字母轉換成大寫
|
SUBSTR(char,start,length)
|
返回字符串表達式char中從第start開始的length個字符
|
LENGTH(char)
|
返回字符串表達式char的長度
|
LTRIM(char)
|
去掉字符串表達式char后面的空格
|
ASCII(char)
|
取char的ASCII值
|
CHAR(number)
|
取number的ASCII值
|
REPLACE(char,str1,str2)
|
將字符串中所有str1換成str2
|
INSTR(char1,char2,start,times)
|
在char1字符串中搜索char2字符串,start為執行搜索操作的起始位置,times為搜索次數
|
常用日期函數
函數
|
描述
|
SYSDATE
|
返回系統當前日期和時間
|
NEXT_DAY(day,char)
|
返回day指定的日期之后并滿足char指定條件的第一個日期,char所指條件只能為星期幾
|
LAST_DAY(day)
|
返回day日期所指定月份中最后一天所對應的日期
|
ADD_MONTH(day,n)
|
返回day日期在n個月后(n為正數)或前(n為負數)的日期
|
MONTH_BETWEEN(day1,day2)
|
返回day1日期和day2日期之間相差得月份
|
ROUND(day[,fmt])
|
按照fmt指定格式對日期數據day做舍入處理,默認舍入到日
|
TRUNC(day,[,fmt])
|
按照fmt指定格式對日期數據day做舍入處理,默認截斷到日
|
數據類型轉換函數
函數
|
描述
|
TO_CHAR
|
將一個數字或日期轉換成字符串
|
TO_NUMBER
|
將字符型數據轉換成數字型數據
|
TO_DATE
|
將字符型數據轉換為日期型數據
|
CONVERT
|
將一個字符串從一個字符集轉換為另一種字符集
|
CHARTORowid
|
將一個字符串轉換為Rowid數據類型
|
RowIDTOCHAR
|
將一個Rowid數據類型轉換為字符串
|
NEXTTORAW
|
將一個十六進制字符串轉換為RAW數據類型
|
RAWTOHEX
|
將一個RAW類型的二進制數據類型轉換為一個十六進制表達的字符串
|
TO_MULTI_BYTE
|
將一個單字節字符串轉換為多字節字符串
|
TO_SINGLE_BYTE
|
將一個多字節字符串轉換為單字節字符串
|
集合函數
函數
|
描述
|
AVG
|
計算一列值的平均值
|
COUNT
|
統計一列中值的個數
|
MAX
|
求一列值中的最大值
|
MIN
|
求一列值中的最小值
|
SUM
|
計算一列值的總和
|
STDDEV
|
計算一列值的標準差
|
VARIANCE
|
計算一列值的方差
|
1、
encodeURIComponent(”[string]“)
decodeURIComponent(”[encodedString]“)
2、
encodeURI(”[string]“)
decodeURI(”[encodedString]“)
3、
escape(”[string]“)
unescape(”[encodedString]“)
1、對每個字節進行編碼;
2、空格轉為”+”號;
3、安全字符不編碼。安全字符:大小寫英文字母(a-z以及A-Z) 阿拉伯數字(0-9) \’ ( ) * - . _ !
4、其他字節以十六進制顯示并加”%”前綴,例如用%25代表%號。
設置客戶端字符集:
# 常用中文字符集
set NLS_LANG=SIMPLIFIED CHINESE_CHINA.ZHS16GBK
# 常用unicode字符集
set NLS_LANG=american_america.AL32UTF8
exp 用戶名/密碼@主機 file=導出文件的文件名 tables=(逗號分割表名) log=aibsm.log feedback=200
1.Json的對象形式
{
property0 : true, //property0是一個布爾型的值
property1 : 0, //property1是一個數值型的值
property2 : "123", //property2是一個字符串型的值
property3 : function(){...} //property3是一個函數
}
使用key-value對構造json對象,注意屬性的key和value使用“:”分開,屬性之間使用“,”分開,注意最后的屬性沒有“,”,什么符號都不要有。將此結構直接賦值給js的對象,則可以使用這個對象調用這些屬性。
例如:var obj1 = {
property0 : true, //property0是一個布爾型的值
property1 : 0, //property1是一個數值型的值
property2 : "123", //property2是一個字符串型的值
property3 : function(){...}, //property3是一個函數
property4 : { p1 : p1Value, p2 : p2Value } //property4本身又是一個對象
}
那么可以調用
alert(obj1.property0);
obj1.property3();
……
在Java Web開發中,服務端負責輸出這串字符到jsp頁面的js,就可以使用了。
關鍵的是,字符串中可能具有js需要避免的特殊字符,建議查看一下spring的JavascriptUtils的javaScriptEscape方法就知道如何做啦
如果是Ajax調用的話,就是用prototype庫的方法,將字符串轉換為json對象
new Ajax.Request(" http://url/", {
method: "get",
onSuccess: function(transport) {
var json = transport.responseText.evalJSON();
// TODO: document.write(json.xxx);
}
prototype庫的官網: http://prototypejs.org/
});
2. Json的數組形式
其實js中的數組更像是一個Map對象,因為它的key不只是整數,還可以是字符串。
var array;
array["key0"] = key0Value;
array["key1"] = key1Value;
摘要: 基本javascript事件的列表介紹 閱讀全文
摘要: 首先介紹一個網站,我很多書本都是在上面下載的,很好。http://www.freebookspot.in/
我現在學習的書本是:Pro Javascript Design Pattern
首先簡單地為優雅的Javascript代碼開個頭
運用設計模式的三大原因:
可維護性
溝通交流性
性能追求
不使用設計模式的兩大原因:
復雜性
性能追求
閱讀全文
|